Skip to contents

[Experimental] Generate bootstrapped confidence intervals and permutation based null distribution for MDS analysis. Output shows how much stress is reduced by adding an additional dimension to the MDS analysis of dissimilarity_matrix, and bootstrapped iterations of dissimilarity_matrix, compared with the stress reduction expected from a matrix with no meaningful structure. This function is inspired by pca_test(), but is less connected with statistical literature than that function. We currently reject additional dimensions is they reduce less stress than we would expect by chance. That is, when the distribution from the boostrapped analyses sits notably lower than the permuted distribution when plotted by plot_mds_test()

Usage

mds_test(
  dissimilarity_matrix,
  n_boots = 50,
  n_perms = 50,
  test_dimensions = 5,
  principal = TRUE,
  mds_type = "ordinal",
  spline_degree = 2,
  spline_int_knots = 2,
  ...
)

Arguments

dissimilarity_matrix

Square matrix of dissimilarity scores.

n_boots

Number of bootstrapping iterations (default: 25).

n_perms

Number of permutations (default: 25).

test_dimensions

Number of MDS dimensions to test for stress reduction (default: 5).

principal

Whether to apply principal axis transform to MDS (default: TRUE)

mds_type

What kind of MDS to apply, see smacof::smacofSym() (default: 'ordinal')

spline_degree

How many spline degrees when type is 'mspline' (default: 2)

spline_int_knots

How many internal knots when type is 'mspline' (default: 2)

...

Arguments passed to smacof::smacofSym()

Value

object of class mds_test_results, containing:

  • $stress_reduction a tibble containing

  • $n_boots Number of bootstrapping iterations.

  • $n_perms Number of permutation iterations

  • $mds_type Type of MDS analysis (type argument passed to smacof::smacofSym())

  • $principal Whether principal axis transformation is applied (passed to smacof::smacofSym())

Examples

# Apply interval MDS to `sim_matrix`, with 5 permutations and bootstraps
# testing up to 3 dimensions. In real usage, increase `n_boots` and `n_perms`
# to at least 50.
mds_test(
 smacof::sim2diss(sim_matrix, method="reverse"),
 n_boots = 5,
 n_perms = 5,
 test_dimensions = 3,
 mds_type = 'interval'
)
#> $stress_reduction
#> # A tibble: 33 × 6
#>    source    dims stress_dist cumulative lag_stress  diff
#>    <chr>    <int>       <dbl>      <dbl>      <dbl> <dbl>
#>  1 permuted     1       0.545          1      1     0.455
#>  2 permuted     1       0.545          2      1     0.455
#>  3 permuted     1       0.542          3      1     0.458
#>  4 permuted     1       0.545          4      1     0.455
#>  5 permuted     1       0.543          5      1     0.457
#>  6 permuted     2       0.365          1      0.545 0.180
#>  7 permuted     2       0.358          2      0.545 0.188
#>  8 permuted     2       0.360          3      0.542 0.182
#>  9 permuted     2       0.369          4      0.545 0.176
#> 10 permuted     2       0.365          5      0.543 0.177
#> # ℹ 23 more rows
#> 
#> $n_boots
#> [1] 5
#> 
#> $n_perms
#> [1] 5
#> 
#> $mds_type
#> [1] "interval"
#> 
#> $principal
#> [1] TRUE
#> 
#> attr(,"class")
#> [1] "mds_test_results"