Title: | Analysis of Ecotoxicology |
---|---|
Description: | A simple approach to using a probit or logit analysis to calculate lethal concentration (LC) or time (LT) and the appropriate fiducial confidence limits desired for selected LC or LT for ecotoxicology studies (Finney 1971; Wheeler et al. 2006; Robertson et al. 2007). The simplicity of 'ecotox' comes from the syntax it implies within its functions which are similar to functions like glm() and lm(). In addition to the simplicity of the syntax, a comprehensive data frame is produced which gives the user a predicted LC or LT value for the desired level and a suite of important parameters such as fiducial confidence limits and slope. Finney, D.J. (1971, ISBN: 052108041X); Wheeler, M.W., Park, R.M., and Bailer, A.J. (2006) <doi:10.1897/05-320R.1>; Robertson, J.L., Savin, N.E., Russell, R.M., and Preisler, H.K. (2007, ISBN: 0849323312). |
Authors: | Benjamin L Hlina [aut, cre] |
Maintainer: | Benjamin L Hlina <[email protected]> |
License: | GPL-3 | file LICENSE |
Version: | 1.4.4 |
Built: | 2025-01-05 03:17:31 UTC |
Source: | https://github.com/benjaminhlina/ecotox |
This dataset contains the amount of responding/dead lamprey from 1 to 12 h of exposure to the piscicide, 3-trifluoromethyl-4-nitrophenol (TFM), for the calculated LC50s at each month for the 2011 seasonal larval sea lamprey TFM toxicity data.
lamprey_time
lamprey_time
A tibble containing 44 rows and 7 columns.
nominal TFM dose(mg/L)
averaged measured TFM dose (mg/L) over 12 h of exposures
month in which toxicity test occurred
duration of exposure in hours
number of lamprey that responded over 12 h exposure to TFM
number of lamprey that survived over 12 h exposure to TFM
total number of lamprey that were exposed to TFM over 12 h
For each month, new lamprey were collected from the deer creek, MI, and were randomly assigned to a tank for exposure to the piscicide, 3-trifluoromethyl-4-nitrophenol (TFM). The LC50 at each month was then calculated and the amount of responding/dead lamprey from 1 to 12 h was recorded.
Hlina, B.L., Birceanu, O., Robinson, C.S., Dhiyebi, H., Wilkie, M.P. In Reivew. Seasonal Variation in the Sensitivity of Invasive Sea Lampreys to the Lampricide TFM: Importance of Energy Reserves and Temperature. North American Journal of Fisheries Management
This dataset contains 2011 seasonal larval sea lamprey exposed to the piscicide, 3-trifluoromethyl-4-nitrophenol (TFM) toxicity data.
lamprey_tox
lamprey_tox
A tibble containing 64 rows and 7 columns.
nominal TFM dose (mg/L)
tank assignment
month in which toxicity test occurred
averaged measured TFM dose (mg/L) over 12 h of exposure
number of lamprey that responded over 12 h exposure to TFM
number of lamprey that survived over 12 h exposure to TFM
total number of lamprey that were exposed to TFM over 12 h
For each month, new lamprey were collected from the Deer Creek, MI, and were randomly assigned to a tank for exposure to varying doses of the piscicide, 3-trifluoromethyl-4-nitrophenol (TFM).
Hlina, B.L., Birceanu, O., Robinson, C.S., Dhiyebi, H., Wilkie, M.P. In Reivew. Seasonal Variation in the Sensitivity of Invasive Sea Lampreys to the Lampricide TFM: Importance of Energy Reserves and Temperature. North American Journal of Fisheries Management
Calculates lethal concentration (LC) and its fiducial confidence limits (CL) using a logit analysis according to Finney 1971, Wheeler et al. 2006, and Robertson et al. 2007.
LC_logit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE)
LC_logit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE)
formula |
an object of class |
data |
an optional data frame, list or environment (or object coercible by as.data.frame to a data frame) containing the variables in the model. If not found in data, the variables are taken from environment(formula), typically the environment from which |
p |
Lethal Concentration (LC) values for given p, example will return a LC50 value if p equals 50. If more than one LC value wanted specify by creating a vector. LC values can be calculated down to the 1e-16 of a percentage (e.g. LC99.99). However, the tibble produced can round to nearest whole number. |
weights |
vector of 'prior weights' to be used in the fitting process. Only needs to be supplied if you are taking the response / total for your response variable within the formula call of |
subset |
allows for the data to be subseted if desired. Default set to |
log_base |
default is |
log_x |
default is |
het_sig |
significance level from person's chi square goodness-of-fit test that is used to decide if a heterogeneity factor is used. |
conf_level |
adjust confidence level as necessary or |
conf_type |
default is |
long_output |
default is |
Returns a tibble with predicted LC for given p level, lower CL (LCL), upper CL (UCL), Pearson's chi square goodness-of-fit test (pgof), slope, intercept, slope and intercept p values and standard error, and LC variance.
Finney, D.J., 1971. Probit Analysis, Cambridge University Press, Cambridge, England, ISBN: 052108041X
Wheeler, M.W., Park, R.M., and Bailey, A.J., 2006. Comparing median lethal concentration values using confidence interval overlap or ratio tests, Environ. Toxic. Chem. 25(5), 1441-1444.10.1897/05-320R.1
Robertson, J.L., Savin, N.E., Russell, R.M. and Preisler, H.K., 2007. Bioassays with arthropods. CRC press. ISBN: 9780849323317
head(lamprey_tox) # within the dataframe used, control dose, unless produced a value # during experimentation, are removed from the dataframe, # as glm cannot handle values of infinite. Other statistical programs # make note of the control dose but do not include within analysis # calculate LC50 and LC99 for May m <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # OR m1 <- LC_logit(cbind(response, survive) ~ log10(dose), p = c(50, 99), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # view calculated LC50 and LC99 for seasonal toxicity of a pisicide, # to lamprey in 2011 m # they are the same m1 # dose-response curve can be plotted using 'ggplot2' # Uncomment the below lines to run create plots # library(ggplot2) # lc_may <- subset(lamprey_tox, month %in% c("May")) # p1 <- ggplot(data = lc_may[lc_may$nominal_dose != 0, ], # aes(x = log10(dose), y = (response / total))) + # geom_point() + # geom_smooth(method = "glm", # method.args = list(family = binomial(link = "logit")), # aes(weight = total), colour = "#FF0000", se = TRUE) # p1 # calculate LC50s and LC99s for multiple toxicity tests, June, August, and September j <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) a <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "August")) s <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "September")) # group results together in a dataframe to plot with 'ggplot2' results <- rbind(m[, c(1, 3:8, 11)], j[,c(1, 3:8, 11)], a[, c(1, 3:8, 11)], s[, c(1, 3:8, 11)]) results$month <- factor(c(rep("May", 2), rep("June", 2), rep("August", 2), rep("September", 2)), levels = c("May", "June", "August", "September")) # p2 <- ggplot(data = results, aes(x = month, y = dose, # group = factor(p), fill = factor(p))) + # geom_col(position = position_dodge(width = 0.9), colour = "#000000") + # geom_errorbar(aes(ymin = LCL, ymax = UCL), # size = 0.4, width = 0.06, # position = position_dodge(width = 0.9)) # p2
head(lamprey_tox) # within the dataframe used, control dose, unless produced a value # during experimentation, are removed from the dataframe, # as glm cannot handle values of infinite. Other statistical programs # make note of the control dose but do not include within analysis # calculate LC50 and LC99 for May m <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # OR m1 <- LC_logit(cbind(response, survive) ~ log10(dose), p = c(50, 99), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # view calculated LC50 and LC99 for seasonal toxicity of a pisicide, # to lamprey in 2011 m # they are the same m1 # dose-response curve can be plotted using 'ggplot2' # Uncomment the below lines to run create plots # library(ggplot2) # lc_may <- subset(lamprey_tox, month %in% c("May")) # p1 <- ggplot(data = lc_may[lc_may$nominal_dose != 0, ], # aes(x = log10(dose), y = (response / total))) + # geom_point() + # geom_smooth(method = "glm", # method.args = list(family = binomial(link = "logit")), # aes(weight = total), colour = "#FF0000", se = TRUE) # p1 # calculate LC50s and LC99s for multiple toxicity tests, June, August, and September j <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) a <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "August")) s <- LC_logit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "September")) # group results together in a dataframe to plot with 'ggplot2' results <- rbind(m[, c(1, 3:8, 11)], j[,c(1, 3:8, 11)], a[, c(1, 3:8, 11)], s[, c(1, 3:8, 11)]) results$month <- factor(c(rep("May", 2), rep("June", 2), rep("August", 2), rep("September", 2)), levels = c("May", "June", "August", "September")) # p2 <- ggplot(data = results, aes(x = month, y = dose, # group = factor(p), fill = factor(p))) + # geom_col(position = position_dodge(width = 0.9), colour = "#000000") + # geom_errorbar(aes(ymin = LCL, ymax = UCL), # size = 0.4, width = 0.06, # position = position_dodge(width = 0.9)) # p2
Calculates lethal concentration (LC) and its fiducial confidence limits (CL) using a probit analysis according to Finney 1971, Wheeler et al. 2006, and Robertson et al. 2007.
LC_probit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE)
LC_probit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE)
formula |
an object of class |
data |
an optional data frame, list or environment (or object coercible by as.data.frame to a data frame) containing the variables in the model. If not found in data, the variables are taken from environment(formula), typically the environment from which |
p |
Lethal Concentration (LC) values for given p, example will return a LC50 value if p equals 50. If more than one LC value wanted specify by creating a vector. LC values can be calculated down to the 1e-16 of a percentage (e.g. LC99.99). However, the tibble produced can round to nearest whole number. |
weights |
vector of 'prior weights' to be used in the fitting process. Only needs to be supplied if you are taking the response / total for your response variable within the formula call of |
subset |
allows for the data to be subseted if desired. Default set to |
log_base |
default is |
log_x |
default is |
het_sig |
significance level from person's chi square goodness-of-fit test (pgof) that is used to decide if a heterogeneity factor is used. |
conf_level |
adjust confidence level as necessary or |
conf_type |
default is |
long_output |
default is |
Returns a tibble with predicted LC for given p level, lower CL (LCL), upper CL (UCL), Pearson's chi square goodness-of-fit test (pgof), slope, intercept, slope and intercept p values and standard error, and LC variance.
Finney, D.J., 1971. Probit Analysis, Cambridge University Press, Cambridge, England, ISBN: 052108041X
Wheeler, M.W., Park, R.M., and Bailey, A.J., 2006. Comparing median lethal concentration values using confidence interval overlap or ratio tests, Environ. Toxic. Chem. 25(5), 1441-1444.10.1897/05-320R.1
Robertson, J.L., Savin, N.E., Russell, R.M. and Preisler, H.K., 2007. Bioassays with arthropods. CRC press. ISBN: 9780849323317
head(lamprey_tox) # within the dataframe used, control dose, unless produced a value # during experimentation, are removed from the dataframe, # as glm cannot handle values of infinite. Other statistical programs # make note of the control dose but do not include within analysis # calculate LC50 and LC99 m <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # OR m1 <- LC_probit(cbind(response, survive) ~ log10(dose), p = c(50, 99), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # view calculated LC50 and LC99 for seasonal toxicity of a pisicide, # to lamprey in 2011 m # these are the same m1 # dose-response curve can be plotted using 'ggplot2' # library(ggplot2) # lc_may <- subset(lamprey_tox, month %in% c("May")) # p1 <- ggplot(data = lc_may[lc_may$nominal_dose != 0, ], # aes(x = log10(dose), y = (response / total))) + # geom_point() + # geom_smooth(method = "glm", # method.args = list(family = binomial(link = "probit")), # aes(weight = total), colour = "#FF0000", se = TRUE) # p1 # calculate LC50s and LC99s for multiple toxicity tests, June, August, and September j <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) a <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "August")) s <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "September")) # group results together in a dataframe to plot with 'ggplot2' results <- rbind(m[, c(1, 3:8, 11)], j[,c(1, 3:8, 11)], a[, c(1, 3:8, 11)], s[, c(1, 3:8, 11)]) results$month <- factor(c(rep("May", 2), rep("June", 2), rep("August", 2), rep("September", 2)), levels = c("May", "June", "August", "September")) # p2 <- ggplot(data = results, aes(x = month, y = dose, # group = factor(p), fill = factor(p))) + # geom_col(position = position_dodge(width = 0.9), colour = "#000000") + # geom_errorbar(aes(ymin = LCL, ymax = UCL), # size = 0.4, width = 0.06, # position = position_dodge(width = 0.9)) # p2
head(lamprey_tox) # within the dataframe used, control dose, unless produced a value # during experimentation, are removed from the dataframe, # as glm cannot handle values of infinite. Other statistical programs # make note of the control dose but do not include within analysis # calculate LC50 and LC99 m <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # OR m1 <- LC_probit(cbind(response, survive) ~ log10(dose), p = c(50, 99), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) # view calculated LC50 and LC99 for seasonal toxicity of a pisicide, # to lamprey in 2011 m # these are the same m1 # dose-response curve can be plotted using 'ggplot2' # library(ggplot2) # lc_may <- subset(lamprey_tox, month %in% c("May")) # p1 <- ggplot(data = lc_may[lc_may$nominal_dose != 0, ], # aes(x = log10(dose), y = (response / total))) + # geom_point() + # geom_smooth(method = "glm", # method.args = list(family = binomial(link = "probit")), # aes(weight = total), colour = "#FF0000", se = TRUE) # p1 # calculate LC50s and LC99s for multiple toxicity tests, June, August, and September j <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) a <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "August")) s <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "September")) # group results together in a dataframe to plot with 'ggplot2' results <- rbind(m[, c(1, 3:8, 11)], j[,c(1, 3:8, 11)], a[, c(1, 3:8, 11)], s[, c(1, 3:8, 11)]) results$month <- factor(c(rep("May", 2), rep("June", 2), rep("August", 2), rep("September", 2)), levels = c("May", "June", "August", "September")) # p2 <- ggplot(data = results, aes(x = month, y = dose, # group = factor(p), fill = factor(p))) + # geom_col(position = position_dodge(width = 0.9), colour = "#000000") + # geom_errorbar(aes(ymin = LCL, ymax = UCL), # size = 0.4, width = 0.06, # position = position_dodge(width = 0.9)) # p2
Calculates lethal time (LT) and its fiducial confidence limits (CL) using a logit analysis according to Finney 1971, Wheeler et al. 2006, and Robertson et al. 2007.
LT_logit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, long_output = TRUE)
LT_logit(formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, long_output = TRUE)
formula |
an object of class |
data |
an optional data frame, list or environment (or object coercible by as.data.frame to a data frame) containing the variables in the model. If not found in data, the variables are taken from environment(formula), typically the environment from which |
p |
Lethal time (LT) values for given p, example will return a LT50 value if p equals 50. If more than one LT value wanted specify by creating a vector. LT values can be calculated down to the 1e-16 of a percentage (e.g. LT99.99).However, the tibble produced can and will round to nearest whole number. |
weights |
vector of 'prior weights' to be used in the fitting process. Only needs to be supplied if you are taking the response / total for your response variable within the formula call of |
subset |
allows for the data to be subseted if desired. Default set to |
log_base |
default is |
log_x |
default is |
het_sig |
significance level from person's chi square goodness-of-fit test that is used to decide if a heterogeneity factor is used. |
conf_level |
Adjust confidence level as necessary or |
long_output |
default is |
Returns a tibble with predicted LT for given p level, lower CL (LCL), upper CL (UCL), LCL, Pearson's chi square goodness-of-fit test (pgof), slope, intercept, slope and intercept p values and standard error, and LT variance.
Finney, D.J., 1971. Probit Analysis, Cambridge University Press, Cambridge, England, ISBN: 052108041X
Wheeler, M.W., Park, R.M., and Bailey, A.J., 2006. Comparing median lethal concentration values using confidence interval overlap or ratio tests, Environ. Toxic. Chem. 25(5), 1441-1444.10.1897/05-320R.1
Robertson, J.L., Savin, N.E., Russell, R.M. and Preisler, H.K., 2007. Bioassays with arthropods. CRC press. ISBN: 9780849323317
head(lamprey_time) results <- LT_logit((response / total) ~ log10(hour), p = c(50, 99), weights = total, data = lamprey_time, subset = c(month == "May")) # view calculated LT50 and LT99 for seasonal # toxicity of a piscicide, 3-trifluoromethyl-4-nitrophenol, to lamprey in 2011 results # dose-response curve can be plotted using 'ggplot2'
head(lamprey_time) results <- LT_logit((response / total) ~ log10(hour), p = c(50, 99), weights = total, data = lamprey_time, subset = c(month == "May")) # view calculated LT50 and LT99 for seasonal # toxicity of a piscicide, 3-trifluoromethyl-4-nitrophenol, to lamprey in 2011 results # dose-response curve can be plotted using 'ggplot2'
Calculates lethal time (LT) and its fiducial confidence limits (CL) using a probit analysis according to Finney 1971, Wheeler et al. 2006, and Robertson et al. 2007.
LT_probit( formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE )
LT_probit( formula, data, p = NULL, weights = NULL, subset = NULL, log_base = NULL, log_x = TRUE, het_sig = NULL, conf_level = NULL, conf_type = NULL, long_output = TRUE )
formula |
an object of class |
data |
an optional data frame, list or environment (or object coercible by as.data.frame to a data frame) containing the variables in the model. If not found in data, the variables are taken from environment(formula), typically the environment from which |
p |
Lethal time (LT) values for given p, example will return a LT50 value if p equals 50. If more than one LT value wanted specify by creating a vector. LT values can be calculated down to the 1e-16 of a percentage (e.g. LT99.99). However, the tibble produced can and will round to nearest whole number. |
weights |
vector of 'prior weights' to be used in the fitting process. Only needs to be supplied if you are taking the response / total for your response variable within the formula call of |
subset |
allows for the data to be subseted if desired. Default set to |
log_base |
default is |
log_x |
default is |
het_sig |
significance level from person's chi square goodness-of-fit test that is used to decide if a heterogeneity factor is used. |
conf_level |
Adjust confidence level as necessary or |
conf_type |
default is |
long_output |
default is |
Returns a tibble with predicted LT for given p level, lower CL (LCL), upper CL (UCL), LCL, Pearson's chi square goodness-of-fit test (pgof), slope, intercept, slope and intercept p values and standard error, and LT variance.
Finney, D.J., 1971. Probit Analysis, Cambridge University Press, Cambridge, England, ISBN: 052108041X
Wheeler, M.W., Park, R.M., and Bailey, A.J., 2006. Comparing median lethal concentration values using confidence interval overlap or ratio tests, Environ. Toxic. Chem. 25(5), 1441-1444.10.1897/05-320R.1
Robertson, J.L., Savin, N.E., Russell, R.M. and Preisler, H.K., 2007. Bioassays with arthropods. CRC press. ISBN: 9780849323317
head(lamprey_time) results <- LT_probit((response / total) ~ log10(hour), p = c(50, 99), weights = total, data = lamprey_time, subset = c(month == "May")) # view calculated LT50 and LT99 for seasonal # toxicity of a piscicide, 3-trifluoromethyl-4-nitrophenol, to lamprey in 2011 results # dose-response curve can be plotted using 'ggplot2'
head(lamprey_time) results <- LT_probit((response / total) ~ log10(hour), p = c(50, 99), weights = total, data = lamprey_time, subset = c(month == "May")) # view calculated LT50 and LT99 for seasonal # toxicity of a piscicide, 3-trifluoromethyl-4-nitrophenol, to lamprey in 2011 results # dose-response curve can be plotted using 'ggplot2'
Calculates a ratio test to compare two LC or LT values from two separate probit or logit models. This function is based on the ratio test developed in Wheeler et al. 2006. 10.1897/05-320R.1 which has been suggested as a replacement to the common method of comparing confidence intervals to determine differences.
ratio_test(model_1, model_2, percentage = NULL, type = NULL, compare = NULL, log_base = NULL, log_x = TRUE, obj_type = NULL, conf_type = NULL)
ratio_test(model_1, model_2, percentage = NULL, type = NULL, compare = NULL, log_base = NULL, log_x = TRUE, obj_type = NULL, conf_type = NULL)
model_1 |
first model used in the ratio test. Should be an object of either a probit or logit model created using the |
model_2 |
second model used in the ratio test. Should be an object of either a
probit or logit model created using the |
percentage |
either a single value or a vector for given LC or LT percentage desired to compare.
Percentage is the same value used for the argument |
type |
Link type needs to be specified to either |
compare |
Supply a character string to be used in the output letting the user know what models the LCs or LTs are being compared. Default output is "Model 1 - Model 2". See example. |
log_base |
default is |
log_x |
default is |
obj_type |
default is |
conf_type |
default is |
A tibble with percentage
for the LC or LT value desired for the above percentage argument, dose_1
and dose_2
displayed calculated backtransformed or untransformed doses for the desired LC or LT values. Standard Error (se
), Z test statistic (test_stat
) and p_value
determined using Z test statistic as determined using formulas in Wheeler et al. 2006.
.
Wheeler, M.W., Park, R.M., and Bailey, A.J., 2006. Comparing median lethal concentration values using confidence interval overlap or ratio tests, Environ. Toxic. Chem. 25(5), 1441-1444.10.1897/05-320R.1
# view lamprey_tox data head(lamprey_tox) # using glm() to detemine LC values using probit model for May and June m <- glm((response / total) ~ log10(dose), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May"), weights = total, family = binomial(link = "probit")) j <- glm((response / total) ~ log10(dose), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June"), weights = total, family = binomial(link = "probit")) # now that both May and June models have been made. use ratio_test to # compare LC50 values or whatever LC values of interest. ratios <- ratio_test(model_1 = m, model_2 = j, percentage = 50, compare = "May - June") # view ratio test results ratios # you can also use LC_probit to create the models and use ratio test m_1 <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) j_1 <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) ratios_2 <- ratio_test(model_1 = m_1, model_2 = j_1, percentage = 50, compare = "May - June", obj_type = "df") ratios_2
# view lamprey_tox data head(lamprey_tox) # using glm() to detemine LC values using probit model for May and June m <- glm((response / total) ~ log10(dose), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May"), weights = total, family = binomial(link = "probit")) j <- glm((response / total) ~ log10(dose), data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June"), weights = total, family = binomial(link = "probit")) # now that both May and June models have been made. use ratio_test to # compare LC50 values or whatever LC values of interest. ratios <- ratio_test(model_1 = m, model_2 = j, percentage = 50, compare = "May - June") # view ratio test results ratios # you can also use LC_probit to create the models and use ratio test m_1 <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "May")) j_1 <- LC_probit((response / total) ~ log10(dose), p = c(50, 99), weights = total, data = lamprey_tox[lamprey_tox$nominal_dose != 0, ], subset = c(month == "June")) ratios_2 <- ratio_test(model_1 = m_1, model_2 = j_1, percentage = 50, compare = "May - June", obj_type = "df") ratios_2