Genone {AVGAS} | R Documentation |
Gathering useful information for first generation
Description
This function automatically ranks all candidate interaction effects under Strong, Weak, or No heredity condition, compare and obtain first generation candidate models. The selected models will be re-ordered so that main effects come first, followed by interaction effects. Only two-way interaction effects will be considered.
Usage
Genone(
X,
y,
heredity = "Strong",
nmain.p,
r1,
r2,
sigma = NULL,
interaction.ind = NULL,
lambda = 10,
q = 40,
allout = "No",
interonly = "No",
pi1 = 0.32,
pi2 = 0.32,
pi3 = 0.32,
aprob = 0.9,
dprob = 0.9,
aprobm = 0.1,
aprobi = 0.9,
dprobm = 0.9,
dprobi = 0.1
)
Arguments
X |
Input data. An optional data frame, or numeric matrix of dimension
|
y |
Response variable. A |
heredity |
Whether to enforce Strong, Weak, or No heredity. Default is "Strong". |
nmain.p |
A numeric value that represents the total number of main effects
in |
r1 |
A numeric value indicating the maximum number of main effects. |
r2 |
A numeric value indicating the maximum number of interaction effects. |
sigma |
The standard deviation of the noise term. In practice, sigma is usually unknown. In such case, this function automatically estimate sigma using root mean square error (RMSE). Default is NULL. Otherwise, users need to enter a numeric value. |
interaction.ind |
A two-column numeric matrix containing all possible
two-way interaction effects. It must be generated outside of this function
using |
lambda |
A numeric value defined by users. Default is 10. For guidance on selecting an appropriate value, please refer to the Details section. |
q |
A numeric value indicating the number of models in each generation (e.g., the population size). Default is 40. |
allout |
Whether to print all outputs from this function. A "Yes" or "No" logical vector. Default is "No". See Value section for details. |
interonly |
Whether or not to consider fitted models with only two-way interaction effects. A “Yes" or "No" logical vector. Default is "No". |
pi1 |
A numeric value between 0 and 1, defined by users. Default is 0.32.
For guidance on selecting an appropriate value, please refer to |
pi2 |
A numeric value between 0 and 1, defined by users. Default is 0.32.
For guidance on selecting an appropriate value, please refer to |
pi3 |
A numeric value between 0 and 1, defined by users. Default is 0.32.
For guidance on selecting an appropriate value, please refer to |
aprob |
A numeric value between 0 and 1, defined by users. The addition probability during mutation. Default is 0.9. |
dprob |
A numeric value between 0 and 1, defined by users. The deletion probability during mutation. Default is 0.9. |
aprobm |
A numeric value between 0 and 1, defined by users. The main effect addition probability during addition. Default is 0.1. |
aprobi |
A numeric value between 0 and 1, defined by users. The interaction effect addition probability during addition. Default is 0.9. |
dprobm |
A numeric value between 0 and 1, defined by users. The main effect deletion probability during deletion. Default is 0.9. |
dprobi |
A numeric value between 0 and 1, defined by users. The interaction effect deletion probability during deletion. Default is 0.1. |
Value
A list of output. The components are:
newparents |
New parents models used for t+1-th generation. A numeric matrix
of dimension |
parents_models |
A numeric matrix containing all fitted models from
|
parents_models_cleaned |
A numeric matrix containing fitted models from
|
InterRank |
Rank of all candidate interaction effects. A two-column numeric matrix. The first column contains indices of ranked two-way interaction effects, and the second column contains its corresponding ABC score. |
See Also
initial
, cross
, mut
, ABC
, and Extract
.
Examples
# allout = "No"
set.seed(0)
nmain.p <- 4
interaction.ind <- t(combn(4,2))
X <- matrix(rnorm(50*4,1,0.1), 50, 4)
epl <- rnorm(50,0,0.01)
y <- 1+X[,1]+X[,2]+X[,1]*X[,2]+epl
g1 <- Genone(X, y, nmain.p = 4, r1= 3, r2=3,
interaction.ind = interaction.ind, q = 5)
# allout = "Yes"
g2 <- Genone(X, y, nmain.p = 4, r1= 3, r2=3,
interaction.ind = interaction.ind, q = 5, allout = "Yes")