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)

Arguments

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).

Format

An object of class NULL of length 0.

Details

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.

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) # }