This function calculates metric values for bugs and fish. Inputs are a data frame with SampleID and taxa with phylogenetic and autecological information (see below for required fields by community).
metric.values(
fun.DF,
fun.Community,
fun.MetricNames = NULL,
boo.Adjust = FALSE
)
Data frame of taxa (list required fields)
Community name for which to calculate metric values (bugs, fish, or algae)
Optional vector of metric names to be returned. If none are supplied then all will be returned.
Optional boolean value on whether to perform adjustments of values prior to scoring. Default = FALSE but will always be TRUE for fish metrics.
data frame of SampleID and metric values
No manipulations of the taxa are performed by this routine. All benthic macroinvertebrate taxa should be identified to genus level. Any non-count taxa should be identified in the "NonUnique" field as "N". To run the MSW genus level the taxa should be combined before calculating the metrics.
Both
* Index.Name = Name of index to be used; MBSS_Fish_2005, MBSS_Bugs_2005, MSW_Bugs_1999 (genus index).
Benthic Macroinvertebrates
Bug metric values assumes the following fields (all upper case)
* SITE = MBSS sample identifier.
* TAXON = MBSS benthic macroinvertebrate name.
* N_TAXA = Number of taxon collected in sample.
* EXCLUDE = Non-unique taxa (i.e., parent taxon with one or more children taxa present in sample). Logical field. TRUE = do not include in taxa richness metrics.
* STRATA_R = Benthic macroinvertebrate region (COASTAL, EPIEDMONT, or HIGHLAND).
* Phylogenetic fields
+ (PHYLUM), CLASS, ORDER, FAMILY, GENUS, OTHER_TAXA, TRIBE, FFG, HABIT, FINALTOLVAL07
Valid values for FFG: col, fil, pre, scr, shr, pie
Valid values for HABIT: BU, CB, CN, SP, SW
MSW data should be first combined to family level and EXCLUDE recalculated.
Additional fields needed:
+ FAM_TV (need to include all the same fields, just leave blank).
For the EXCLUDE column there is additional QC to account for common non-standard entries.
* "Y" or "yes" will convert to TRUE.
* "N", "no", NA, or "" will convert to FALSE.
Fish
Fish metric values assumes the following fields (all upper case)
* SITE = MBSS sample identifier.
* FIBISTRATA = Fish region (COASTAL, EPIEDMONT, WARM, COLD).
* ACREAGE = Catchment area in acres.
* LEN_SAMP = Length of stream sampled; typically 75-meters.
* AVWID = Average stream width (meters) for sampled site.
* SPECIES = MBSS fish taxa name.
* TOTAL = Number of fish collected in sample.
* TYPE = Fish group identifier (ALL CAPS); SCULPIN, DARTER, MADTOM, etc.
* TROPHIC_MBSS = MBSS tropic status designations (ALL CAPS); OM, GE, IS, IV, etc.
* PTOLR = Pollution tolerance level (ALL CAPS); T, I, NO TYPE.
The R library dplyr is required for this function.
# Metrics, MBSS Index, Fish
myIndex <- "MBSS.2005.Fish"
# Thresholds
thresh <- metrics_scoring
# get metric names for myIndex
(myMetrics.Fish <- as.character(droplevels(unique(thresh[thresh[,
"Index.Name"]==myIndex,"MetricName.Other"]))))
#> [1] "ABUNSQM" "NUMBENTSP" "PTOL" "PGEOMIV" "PROUND" "PABDOM"
#> [7] "BIOM_MSQ" "P_LITH" "P_IS" "PBROOK" "PSCULP"
# Taxa Data
myDF.Fish <- taxa_fish
myMetric.Values.Fish <- metric.values(myDF.Fish, "fish", myMetrics.Fish)
#View(myMetric.Values.Fish)
# Metrics, Index, Benthic Macroinvertebrates, genus
# (generate values then scores)
myIndex <- "MBSS.2005.Bugs"
# Thresholds
thresh <- metrics_scoring
# get metric names for myIndex
(myMetrics.Bugs.MBSS <- as.character(droplevels(unique(thresh[thresh[,
"Index.Name"]==myIndex,"MetricName.Other"]))))
#> [1] "ntaxa" "nept" "nephem" "pintol_urb" "pephem"
#> [6] "nscrape" "pclimb" "pchiron" "pcling" "ptany"
#> [11] "pscrape" "pswim" "pdipt"
# Taxa Data
myDF.Bugs.MBSS <- taxa_bugs_genus
myMetric.Values.Bugs.MBSS <- metric.values(myDF.Bugs.MBSS, "bugs",
myMetrics.Bugs.MBSS)
#View(myMetric.Values.Bugs.MBSS)
# Metrics, MSW Index, Benthic Macroinvertebrates, family
myIndex <- "MSW.1999.Bugs"
# Thresholds
thresh <- metrics_scoring
# get metric names for myIndex
(myMetrics.Bugs.MSW <- as.character(droplevels(unique(thresh[thresh[,
"Index.Name"]==myIndex,"MetricName.Other"]))))
#> [1] "ntaxa" "nept" "nephem" "ndipt" "pephem"
#> [6] "nintol_FAM" "becks"
# Taxa Data
myDF.Bugs.MSW <- taxa_bugs_family
myMetric.Values.Bugs.MSW <- metric.values(myDF.Bugs.MSW, "bugs",
myMetrics.Bugs.MSW)
#View(myMetric.Values.Bugs.MSW)