Generic accessors for EcoGenetics objects
These functions provide basic access to the slots of any object of the formal classes defined in EcoGenetics. In addition, for ecogen objects a replace method is defined for the accessor, which enables basic processing of individual slots.
# S4 method for ecogen ecoslot.XY(X) ecoslot.XY(object, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.XY(object, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.P(X) # S4 method for ecogen ecoslot.P(X) ecoslot.P(object, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.P(object, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.G(X) # S4 method for ecogen ecoslot.G(X) ecoslot.G(object, G.processed = TRUE, order.G = FALSE, type = c("codominant", "dominant"), ploidy = 2, sep, ncod = NULL, missing = c("0", "NA", "MEAN"), NA.char = "NA", poly.level = 5, rm.empty.ind = FALSE, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.G(object, G.processed = TRUE, order.G = FALSE, type = c("codominant", "dominant"), ploidy = 2, sep, ncod = NULL, missing = c("0", "NA", "MEAN"), NA.char = "NA", poly.level = 5, rm.empty.ind = FALSE, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.A(X) # S4 method for ecogen ecoslot.A(X) # S4 method for ecogen ecoslot.A(object) <- value ecoslot.E(X) # S4 method for ecogen ecoslot.E(X) ecoslot.E(object, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.E(object, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.S(X) # S4 method for ecogen ecoslot.S(X) ecoslot.S(object, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.S(object, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.C(X) # S4 method for ecogen ecoslot.C(X) ecoslot.C(object, use.object.names = FALSE, order.rows = FALSE) <- value # S4 method for ecogen ecoslot.C(object, use.object.names = FALSE, order.rows = FALSE) <- value ecoslot.OUT(X, ...) # S4 method for ecogen ecoslot.OUT(X, ...) ecoslot.OUT(object) <- value # S4 method for ecogen ecoslot.OUT(object) <- value int.ecoslot.INT(X) int.ecoslot.INT(object) <- value ecoslot.ALTER(X) ecoslot.ANALYSIS(X) ecoslot.ANOVA.MLM(X) ecoslot.AVERAGE(X) ecoslot.BREAKS(X) ecoslot.CARDINAL(X) ecoslot.COND(X) ecoslot.CONNECTED(X) ecoslot.DF1(X) ecoslot.DF2(X) ecoslot.DISTMETHOD(X) ecoslot.EXP(X) ecoslot.FREQUENCIES(X) ecoslot.IN(X) ecoslot.LOGMEAN(X) ecoslot.LWR(X) ecoslot.MEAN(X) ecoslot.METHOD(X) ecoslot.MLM(X) ecoslot.MODEL(X) ecoslot.MULTI(X) ecoslot.NAMES(X) ecoslot.NONZERO(X) ecoslot.NONZEROIND(X) ecoslot.NSIM(X) ecoslot.OBS(X) ecoslot.OBS.RES(X) ecoslot.PADJUST(X) ecoslot.PAR(X) ecoslot.PAR.VAL(X) ecoslot.POLY.DEG(X) ecoslot.POP(X) ecoslot.PREDICTIONS(X) ecoslot.PVAL(X) ecoslot.RES(X) ecoslot.ROW.SD(X) ecoslot.SELF(X) ecoslot.SP(X) ecoslot.SUMMARY.MLM(X) ecoslot.TEST(X) ecoslot.TREES(X) ecoslot.UPPR(X) ecoslot.W(X) ecoslot.XY(X)
X | Any S4 object of the formal classes defined in EcoGenetics. |
---|---|
object | Object of class ecogen. |
use.object.names | Logical. Use the names stored in the object for the assigned data frame? This argument can be combined with order.rows if the order of the individuals do not match to the order of the other elements in the object. If the names stored in the object are empty, in all the cases they will be set to the names of the assigned data frame. |
order.rows | Order rows of the object after assignnment to align individuals? This argument can be used when use.object.names is TRUE. Otherwise, it will not have effect in the function. |
value | Single object or a list of objects to assign. Multiple objects v1, v2, ...vn must be passed as a list : list(v1, v2, ...vn). |
G.processed | If TRUE, the slot G will include a processed data frame ( removed non informative loci (the data non available for all the individuals), removed non polymorphic loci (for dominant data) and ordered alleles in ascending order. |
order.G | Genotypes must be ordered in G slot? Default FALSE. |
type | Marker type: "codominant" or "dominant". |
ploidy | Ploidy of the G data frame. Default ploidy = 2. |
sep | Character separating alleles. Default option is no character separating alleles. |
ncod | Number of characters coding each allele. |
missing | Missing data treatment ("0", "NA", or "MEAN") for the A slot. Missing elements are set to 0 in the default option. missing elements are recoded as "NA" or the mean allelic frequency across individuals in "NA" and "MEAN" options, respectively. |
NA.char | Character simbolizing missing data in the input. Default is "NA". |
poly.level | Polymorphism threshold in percentage (0 - 100), for remotion of non polymorphic loci (for dominant data). Default is 5 (5%). |
rm.empty.ind | Remotion of noninformative individuals (rows of "NAs"). Default if FALSE. |
... | Arguments for G or OUT slots of ecogen objects (see Details). |
An object of class NULL
of length 0.
The accessor notation in EcoGenetics consists of the prefix "ecoslot." followed by the name of the slot of interest. E.g., to access the slot "IN" of the object "X", type ecoslot.IN(X).
For example, the class eco.correlog of the function eco.correlog
has the slots OUT, IN, BREAKS CARDINAL, etc.
An object X of class eco.correlog, generated with this function,
has access to these slots using:
ecoslot.OUT(X), ecoslot.IN(X), ecoslot.BREAKS(X) and ecoslot.CARDINAL(X),
respectively.
----------------------------------------------------------------------- FOR ECOGEN CLASS ONLY:
- The accessors in objects of class ecogen
have a double usage. First, the extraction of data included in a slot (get mode).
Second, the assignment of data (set mode). The data assigned
to ecogen objects using this method is properly pre-processed.
- The get mode is defined for ecoslot.XY, ecoslot.P, ecoslot.G, ecoslot.A, ecoslot.E, ecoslot.S and ecoslot.OUT. For any ecogen object X, type ecoslot.SLOT(X), where SLOT is the slot of interest: ecoslot.XY(X), ecoslot.P(X), ecoslot.G(X), ecoslot.A(X), ecoslot.E(X), ecoslot.S(X) and ecoslot.OUT(X, ...). In the latter, the three dots (...) are objects in the slot OUT.
- The set mode is a replacement method, i.e., the assignation ecoslot.SLOT(X) <- VALUE is defined for the ecogen class.
For a generic ecogen object "eco", the defined replacement methods are:
1. ecoslot.P(eco) <- P data frame
2. ecoslot.G(eco, ...) <- G data frame
#' In this case the three dots (...) consist of the following variables that can be passed to the function:
- G.processed
- order.G
- type
- ploidy
- sep
- ncod
- missing
- NA.char
- poly.level
- rm.empty.ind
See the arguments of ecogen
for details about these values, and the
Examples section for details about usage.
IMPORTANT: The assignation of data in the slot G, creates automatically the slot A. An accessor is defined for the slot A only in get mode (to get the data frame in this slot, but not for replacement purposes). The slot A cannot be replaced with accessors and is generated when a genetic data frame is assigned to the slot G.
3. ecoslot.E(eco) <- E data frame
4. ecoslot.S(eco) <- S data frame
5. ecoslot.C(eco) <- C data frame
6. ecoslot.OUT(eco, value) <- results to store in the slot OUT. Here, value means any object(s). Several objects can be passed as a list. See the section Examples.
# NOT RUN { #-------------- # GENERAL USE #-------------- # Example 1 data(eco.test) ## Test with phenotypic traits (example of ?eco.correlog) moran <- eco.correlog(Z=eco[["P"]][,1], XY = eco[["XY"]], method = "I", smax=10, size=1000) # the slots are accesed with the generic format: # ecoslot. + name of the slot + (name of the object) ecoslot.OUT(moran) # slot OUT ecoslot.BREAKS(moran) # slot BREAKS #---------------------------------------------- # SPECIFIC USE OF ACCESSORS WITH ECOGEN OBJECTS #---------------------------------------------- #1) GET MODE # Example 2 # Example with G data of class "data.frame", corresponding to # microsatellites of a diploid organism. eco <- ecogen(XY = coordinates, P = phenotype, G = genotype, E = environment, S = structure, order.G = TRUE) eco # Access to the slots ecoslot.XY(eco) ecoslot.P(eco) ecoslot.G(eco) ecoslot.A(eco) ecoslot.E(eco) ecoslot.S(eco) ecoslot.C(eco) ecoslot.OUT(eco) # For ecogen objects, the double square brackets ("[[") # are symbolic abbreviations of the accessors: ecoslot.XY(eco) # is identical to: eco[["XY"]] #2) SET MODE (REPLACEMENT OF SLOTS) # Example 3 eco <- ecogen(XY = coordinates, P = phenotype) eco ecoslot.G(eco, order.G = TRUE) <- genotype # this is identical to eco[["G", order.G=TRUE]] <- genotype ecoslot.E(eco) <- environment ecoslot.S(eco) <- structure # Storing the data of Example 1 in the slot OUT ecoslot.OUT(eco) <- moran # Storing several data singers <- c("carlos_gardel", "billie_holiday") golden.number <- (sqrt(5) + 1) / 2 ecoslot.OUT(eco) <- list(singers, golden.number) # several objects must be passed as a list # In get mode, ecoslot.OUT has a double behavior: # when only the name of the ecogen object is passed to # the accessor, it has an overview method, # returning a data frame with the objects # stored and their classes ecoslot.OUT(eco) # ecoslot.OUT in get mode, has two arguments: # ecoslot.OUT(object, ...) # here, the three dots (...) means any object(s) stored in the slot OUT. ecoslot.OUT(eco, "moran", "singers") # In double square brackets notation, this is equivalent to eco[["OUT"]][c("moran", "singers")] # This is, it works as a list and have no overview method eco[["OUT"]] eco[["OUT"]]["moran"] # ecoslot.OUT in set mode, has two arguments: # ecoslot.OUT(object, value) # here value means object(s) to store in the slot OUT. Several objects # must be passed as a list. # The names of the input data is recoded in case of # duplicates ecoslot.OUT(eco) <- singers ecoslot.OUT(eco) ecoslot.OUT(eco) <- list(singers, singers, singers) ecoslot.OUT(eco) # The set operation is equivalent with double square brackets eco[["OUT"]] <- list(singers, c(1,2,3)) ecoslot.OUT(eco) # }