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 a 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 Converts Socprog data frame
#' @description Converts socprog 'Group mode' data frame (one scan per line with several individuals observed during the scan)
#' @param df a 'dyadic' or 'group' data frame socprog format
#' @param id an integer or string indicating the column of ids
#' @param scan an integer or string vector indicating the column of the scans
#' @param sep a character indicating the type of sepration between individuals inside one scan
#' @return a data frame in socprog format.
#' @author Sebastian Sosa, Ivan Puga-Gonzalez
#' @examples
#' head(sim.socprog)
#' convert.socprog(sim.socprog,id=3,scan=c(1,2),sep=";")
convert.socprog <- function(df, id, scan, sep = ";") {
# Find columns ids corresponding to individuals----------------------
col.id <- df.col.findId(df, id)
# Create a new column in case of argument scan is multiple columns----------------------
df <- df.ctrlFactor(df, scan)
col.scan <- ncol(df)
# Vectorize socprog data frame according to separator----------------------
r <- apply(df, 1, function(x, col.id, col.scan, sep) {
ID <- strsplit(x[col.id], split = sep)
scan <- rep(x[col.scan], length(ID))
return(data.frame(scan, ID, row.names = NULL))
}, col.id, col.scan, sep)
return(do.call("rbind", r))
}
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.