Extract and average the best supported models from a phylogenetic path analysis.

average(phylopath, cut_off = 2, avg_method = "conditional", ...)

Arguments

phylopath

An object of class phylopath.

cut_off

The CICc cut-off used to select the best models. Use Inf to average over all models. Use the best() function to only use the top model, or choice() to select any single model.

avg_method

Either "full" or "conditional". The methods differ in how they deal with averaging a path coefficient where the path is absent in some of the models. The full method sets the coefficient (and the variance) for the missing paths to zero, meaning paths that are missing in some models will shrink towards zero. The conditional method only averages over models where the path appears, making it more sensitive to small effects. Following von Hardenberg & Gonzalez-Voyer 2013, conditional averaging is set as the default.

...

Arguments to pass to phylolm::phylolm and phylolm::phyloglm. Provide boot = K parameter to enable bootstrapping, where K is the number of bootstrap replicates. If you specified other options in the original phylo_path call you don't need to specify them again.

Value

An object of class fitted_DAG.

Examples

  candidates <- define_model_set(
    A = NL ~ RS,
    B = RS ~ NL + BM,
    .common = c(LS ~ BM, DD ~ NL, NL ~ BM)
  )
  p <- phylo_path(candidates, rhino, rhino_tree)
  summary(p)
#>   model k  q    C     p CICc delta_CICc     l     w
#> A     A 6  9 6.11 0.910 26.1       0.00 1.000 0.639
#> B     B 5 10 4.78 0.905 27.3       1.14 0.566 0.361

  # Models A and B have similar support, so we may decide to take
  # their average.

  avg_model <- average(p)
  # Print the average model to see coefficients, se and ci:
  avg_model
#> $coef
#>    BM        LS         RS        NL        DD
#> BM  0 0.4973937 -0.4090362 0.4501512 0.0000000
#> LS  0 0.0000000  0.0000000 0.0000000 0.0000000
#> RS  0 0.0000000  0.0000000 0.5280685 0.0000000
#> NL  0 0.0000000  0.8743998 0.0000000 0.6285344
#> DD  0 0.0000000  0.0000000 0.0000000 0.0000000
#> attr(,"class")
#> [1] "matrix" "DAG"   
#> 
#> $se
#>    BM         LS         RS         NL         DD
#> BM  0 0.08934185 0.09167814 0.07591749 0.00000000
#> LS  0 0.00000000 0.00000000 0.00000000 0.00000000
#> RS  0 0.00000000 0.00000000 0.05726520 0.00000000
#> NL  0 0.00000000 0.09436255 0.00000000 0.08006703
#> DD  0 0.00000000 0.00000000 0.00000000 0.00000000
#> 
#> $lower
#>    BM        LS         RS        NL        DD
#> BM  0 0.3222869 -0.5887220 0.3013557 0.0000000
#> LS  0 0.0000000  0.0000000 0.0000000 0.0000000
#> RS  0 0.0000000  0.0000000 0.4158308 0.0000000
#> NL  0 0.0000000  0.6894526 0.0000000 0.4716059
#> DD  0 0.0000000  0.0000000 0.0000000 0.0000000
#> 
#> $upper
#>    BM        LS         RS        NL        DD
#> BM  0 0.6725005 -0.2293503 0.5989468 0.0000000
#> LS  0 0.0000000  0.0000000 0.0000000 0.0000000
#> RS  0 0.0000000  0.0000000 0.6403062 0.0000000
#> NL  0 0.0000000  1.0593470 0.0000000 0.7854629
#> DD  0 0.0000000  0.0000000 0.0000000 0.0000000
#> 
#> attr(,"class")
#> [1] "fitted_DAG"

  if (FALSE) {
  # Plot to show the weighted graph:
  plot(avg_model)

  # One can see that an averaged model is not necessarily a DAG itself.
  # This model actually has a path in two directions.

  # Note that coefficients that only occur in one of the models become much
  # smaller when we use full averaging:

  coef_plot(avg_model)
  coef_plot(average(p, method = 'full'))
  }