Nothing
# Copyright (C) 2018 Sebastian Sosa, Ivan Puga-Gonzalez, Hu Feng He, Xiaohua Xie, Cédric Sueur
#
# This file is part of Animal Network Toolkit Software (ANTs).
#
# ANT is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# ANT is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#' @title P-value
#' @description Calculation of the p-value based on a posterior distribution through data permutations.
#' @param metrics an integer vector of permuted statistical values of interest
#' @param histogram if \emph{true}, an histogram of the posterior distribution is ploted. The observed metric is also ploted.
#' @return
#' \itemize{
#' \item An integer vector of left and rigth p-values, if \emph{metrics} is an integer vector and if \emph{histogram} is \emph{false}.
#' \item An integer vector of left and rigth p-values and an histogram of the posterior distribution, if \emph{metrics} is an integer vector and if \emph{histogram} is \emph{false}.
#' }
#' @details Due to data dependency, a valuable p-value in social networking has to be computed through a null model approach.
#' @return a numeric vector.
#' @author Sebastian Sosa, Ivan Puga-Gonzalez.
#' @references Farine, D. R. (2017). A guide to null models for animal social network analysis. Methods in Ecology and Evolution.
#' @references Sosa, S. (2018). Social Network Analysis, \emph{in}: Encyclopedia of Animal Cognition and Behavior. Springer.
#' @keywords interanl
stat.p <- function(metrics, histogram = FALSE) {
### Vector with permuted values, first element is observed value
if (is.vector(metrics)) {
v <- metrics[1]
v_perm <- metrics[-1]
}
### List with permuted values, first element is observed value
if (is.data.frame(metrics)) {
v <- metrics[1, ]
v_perm <- metrics[-1, ]
}
## Calculate p-value on the left side
p_valuevalue_left_side <- sum(v_perm < v) / length(v_perm)
p_valuevalue_right_side <- sum(v_perm > v) / length(v_perm)
## create histogram from permuted values
if (histogram == TRUE) {
histo <- histogram(v, v_perm)
p <- c("p-value_left_side" = p_valuevalue_left_side, "p-value_left_side" = p_valuevalue_right_side)
return(list("p-values" = p, "histogram" = histo))
}
else {
return(p = c("p-value_left_side" = p_valuevalue_left_side, "p-value_left_side" = p_valuevalue_right_side))
}
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.