Package 'TAMMsupport'

Title: Streamline working with Terminal Area Management Modules
Description: A convenient tool for interfacing with Terminal Area Manamagement Modules (TAMMs) in R environments.
Authors: Collin Edwards [aut, cre] , Ty Garber [aut]
Maintainer: Collin Edwards <[email protected]>
License: MIT + file LICENSE
Version: 0.1.0
Built: 2025-01-08 02:52:41 UTC
Source: https://github.com/cbedwards-dfw/TAMMsupport

Help Index


Parse excel address including sheet

Description

Helper function to parse full excel address into sheet, row, column. Removes ⁠'⁠ from sheet names. If given a cell range, returns only the address of the first cell.

Usage

address_parser(address)

Arguments

address

Character string of excel address, including sheet.

Value

list, with ⁠$sheet⁠ giving sheet name, ⁠$rows⁠ givng the row number, ⁠$cols⁠ giving the column number.

Examples

address_parser("SPS!AS3")
address_parser("'Input Page'!$B$30")

Format chunks of dataframe to present as %s, round digits

Description

Format chunks of dataframe to present as %s, round digits

Usage

chunk_formater_percenter(df, block.ranges, percent.digits = 1)

Arguments

df

dataframe of sheet to apply formatting to.

block.ranges

vector of characters specifying blocks of cells (in excel nomenclature) to format as %s

percent.digits

Decimal place to round to in percent

Value

Formatted version of df


Format chunks of dataframe to round digits

Description

Format chunks of dataframe to round digits

Usage

chunk_formater_rounder(df, block.ranges, digits = 1)

Arguments

df

dataframe of sheet to apply formatting to.

block.ranges

vector of characters specifying blocks of cells (in excel nomenclature) to format as %s

digits

Decimal place to round to.

Value

Formatted version of df


Generates clean read of TAMM limiting stock sheet

Description

Effectively a wrapper function for read_limiting_stock with some formatting added in. Filters to unmarked naturals, just present ER values.

Usage

clean_limiting_stock(filename)

Arguments

filename

Name (and path) for TAMM files

Value

dataframe


Compare differences in input sheets of two TAMM files

Description

Summarizes the differences in input sheets and returns them as a tibble.

Usage

compare_chinook_inputs(
  file1,
  file2,
  digits.signif = 4,
  trim.cols = TRUE,
  diff.only = TRUE
)

Arguments

file1

Filename of first TAMM file

file2

Filename of second TAMM file

digits.signif

How many digits should be rounded to before looking for differences? Without this, miniscule excel numerical differences (e.g. differing by 0.000000001) can get picked up and overwhelm the meaningful differences.

trim.cols

Should columns that contain no differences be cut from the results? Defaults to TRUE.

diff.only

Should entries that do not contain differences be replaced by "" to help spot differences? Defaults to TRUE.

Value

Tibble of differences in the input files; only rows with differences are included. row_name variable gives the row name in the TAMM file, and column names match excel column names.


Filters a dataframe to Washington State fisheries.

Description

Adapted from framrsquared::filter_wa(), but (a) only for Chinook (at present), and (b) uses TAMM fishery ids, so includes ids 72 and 73. Includes code for COHO based on FRAM ids. filter_tamm_wa() uses attributes to specify chinook or coho. To directly filter for chinook or coho, use filter_tamm_wa_chin() or filter_tamm_wa_coho().

Usage

filter_tamm_wa(.data)

filter_tamm_wa_chin(.data)

filter_tamm_wa_coho(.data)

Arguments

.data

Dataframe generated within this package

Details

a fishery_id column name.

Examples

## Not run: 
fram_dataframe |> filter_wa()

## End(Not run)

Identify all cells in Excel sheet or sheets with matching cell colors

Description

Designed for tracking the status of TAMM inputs, which are typically color coded. Searches through specified sheet or sheets, looking for cells whose colors match the target_cell argument. Returns a condensed list of those entries.

Usage

find_color_matches(file, target_cell, sheets = "Input Page")

Arguments

file

Character string of excel file name, including path if relevant

target_cell

Character string of excel address of cell with the cell shading of interest (e.g., "B4")

sheets

character string or character vector of sheets to search through

Value

tibble summarizing entries with the color of interest, including sheet, row and column ids, and row name (entry of first column in sheet)

Examples

## Not run: 
file = "chin tamms/Chin2023_Final.xlsx"
find_color_matches(file, "B20")

## End(Not run)

Chinook fishery information

Description

Mapping of fishery_id to fishery name for Chinook salmon, taken from the Fishery table of the Chinook FRAM database.

Usage

fishery_chinook_fram

Format

A data frame with 74 rows and 5 columns:

species

Species name

version_number
fishery_id

Chinook fishery id number in FRAM

fishery_name

Chinook fishery name in FRAM

fishery_title

consistent and more human readable version of fishery_name

Source

2024 Pre-Season Chinook DB.mdb


Coho fishery information

Description

Mapping of fishery_id to fishery name for Coho salmon, taken from the Fishery table of the Coho FRAM database.

Usage

fishery_coho_fram

Format

A data frame with 198 rows and 5 columns:

species

Species name

version_number
fishery_id

Coho fishery id number in FRAM

fishery_name

Coho fishery name in FRAM

fishery_title

consistent and more human readable version of fishery_name

Source

2024NOF_CohoFRAMdatabase_distribution.mdb


relabel inconsistent fishery names in FRAM/TAMM

Description

With argument sep = TRUE, will return data frame with separate columns for the area and the the "class" (Net, Troll, Sport)

Usage

fishery_renamer(x, sep = FALSE)

Arguments

x

character vector of fishery names from TAMM or FRAM

sep

Should we return a dataframe with separate column for class of fishing? Defaults to FALSE

Value

#vector with cleaned fishery names OR dataframe with cleaned name (⁠$full⁠), area without fishery type (⁠$area⁠) and type of fishery (⁠$class⁠).


Modify list of Chinook TAMM spreadsheet dataframes to facilitate comparison.

Description

Modify list of Chinook TAMM spreadsheet dataframes to facilitate comparison.

Usage

format_key_tamm_sheets_chin(
  dat,
  percent.digits = 1,
  numeric.digits = 1,
  numeric.digits.small = 4
)

Arguments

dat

list of dataframes corresponding to the overview, limiting stock, and inputs tabs. Must be named ⁠$overview⁠, ⁠$limiting⁠, and ⁠$input⁠

percent.digits

Optional, number of decimal places to round percentages to before comparison. Defaults to 1.

numeric.digits

Optional, number of decimal places to round non-percentage numerics to before comparison. Applied to numbers that are expected to have natural units of whole numbers (e.g. numbers of fish). Defaults to 1.

numeric.digits.small

Optional, number of decimal places to round non-percentage numerics to before comparison. Applied to numbers that are expected to be small (e.g. rates, proportions) Defaults to 4.

Value

list of dataframes with same structure as dat, contents modified.


Modify list of Coho TAMM spreadsheet dataframes to facilitate comparison.

Description

Modify list of Coho TAMM spreadsheet dataframes to facilitate comparison.

Usage

format_key_tamm_sheets_coho(
  dat,
  percent.digits = 2,
  numeric.digits = 1,
  numeric.digits.small = 4
)

Arguments

dat

list of dataframes corresponding to the overview, limiting stock, and inputs tabs. Must be named ⁠$overview⁠, ⁠$limiting⁠, and ⁠$input⁠

percent.digits

Optional, number of decimal places to round percentages to before comparison. Defaults to 1.

numeric.digits

Optional, number of decimal places to round non-percentage numerics to before comparison. Applied to numbers that are expected to have natural units of whole numbers (e.g. numbers of fish). Defaults to 1.

numeric.digits.small

Optional, number of decimal places to round non-percentage numerics to before comparison. Applied to numbers that are expected to be small (e.g. rates, proportions) Defaults to 4.

Value

list of dataframes with same structure as dat, contents modified.


Format TAMM overview for easy printing

Description

Format TAMM overview for easy printing

Usage

format_overview(dat.overview)

Arguments

dat.overview

dataframe of TAMM overview page, as produced by read_overview()

Value

list with the formatted data, a vector of indent information, and a vector of bolding information.


Add spaces to excel formulas for readability

Description

Helper function to add spaces to excel formulas to improve readability. Can also add newlines based on a character or regular expression

Usage

formula_formater(x, newline_breakpoint = NULL)

Arguments

x

Character string containing an excel formula

newline_breakpoint

Pattern to identify locations for newlines. Could be a single character (e.g. "/") or a more complex regular expression (e.g., "[)][*-+/]" to add a newline after a combination of an end parathesis and an operator).

Value

character string

Examples

formula_formater("(SUM(A1:A4)*5/11)/(B3-B4)")
formula_formater("(SUM(A1:A4)*5/11)/(B3-B4)", newline_breakpoint = "/")
formula_formater("(SUM(A1:A4)*5/11)/(B3-B4)", newline_breakpoint = "[*-+/]")

Format vector of mixed characters to present numbers as percents

Description

Intended for internal use within formatting functions. Note that percents in excel are read in as proportions in R – this makes them percents to make saved files more readable.

Usage

fun_percenter(x, percent.digits)

Arguments

x

Character vector, presumably containing some entries that are numbers in character form

percent.digits

Number of digits to round to after converting to percents

Value

character vector with individual entries converted to percentages and rounded as appropriate.


Format vector of mixed characters to round numbers to specified digits

Description

Intended for internal use within formatting functions.

Usage

fun_rounder(x, digits)

Arguments

x

Character vector, presumably containing some entries that are numbers in character form

digits

Number of digits to round numeric items to


Print table of overview using kable and kableExtra

Description

Uses output of format_overview()

Usage

kable_overview(dat.overview, ind.indent, col.bold)

Arguments

dat.overview

formatted data, first item of format_overview() output

ind.indent

Vector of indices that need indenting to match TAMM overview formatting. Second item of format_overview() output

col.bold

vector of names for bolding to match TAMM overview formatting. Third item of format_overview() output.

Value

html table


Calculate and format edges from traced objects

Description

Helper function to find all references in list created within tracer_formula, and create a simple dataframe representing all the "edges" of the traced network (that is, all the connections between cells). Gets called in trace_formula() to generate the ⁠$references⁠ component of the output.

Usage

make_tracer_edges(address_list)

Arguments

address_list

The ⁠$raw.tracing⁠ component of the results of a trace_formula() call.

Value

tibble. ⁠$from⁠ is the index of the cell that is referenced, ⁠$to⁠ is hte index of the cell that is doing the referencing ⁠$from_name⁠ and ⁠$to_name⁠ are the excel addresses of the same.


Visualize excel formula tracing

Description

[Experimental]

Usage

make_tracer_network(tracer_list, save_path = NULL, newline_breakpoint = NULL)

Arguments

tracer_list

Output of a trace_formula() call.

save_path

Optional, defaults to NULL. Provide a file path + name to save an html of the visualization. Make sure file name ends in .html.

newline_breakpoint

Optional character string used to add breakpoints to formulas to improve readability. Can be simple character or regular expression; See formula_formater for details and examples.

Details

Render the dependency network created in trace_formula(); optionally save this to an interactive .html.

Value

interactive visNetwork object

Examples

## Not run: 
trace_network = trace_formula(path = "NOF material/NOF 2024/NOF 2/Chin1624.xlsx",
cell.start = "SPSmrkd!AS20")
make_tracer_network(trace_network)

## End(Not run)

List cells and contents from traced objects

Description

Helper function to parse list created within trace_formula into a tibble with each cell represented by a row. Called in trace_formula() to generate the ⁠$cells⁠ component of the output.

Usage

make_tracer_nodes(address_list)

Arguments

address_list

The ⁠$raw.tracing⁠ component of the results of a trace_formula() call.

Value

tibble summarizing each cell in the tracing. See trace_formula() for details.


Quick helper function to format vectors that contain text and ERs

Description

Quick helper function to format vectors that contain text and ERs

Usage

quick_er_format(x)

Arguments

x

character vector


Translate excel-style cell range to vector of cell addresses.

Description

Primarily intended as a helper function for trace_formula(), but could be useful for other excel tasks. Drops $ and ⁠'⁠ symbols from addresses to simplify parsing.

Usage

range_splitter(address)

Arguments

address

Character string of excel cell range, as in "B10:C15" or "'Input Sheet'!AS30:AS40"

Value

vector of individual excel-style cell addresses within that range

Examples

range_splitter("B10:C15")
range_splitter("'Input Sheet'!$AS30:$AS40")

Read Chinook TAMM files to extract the key sheets

Description

Read Chinook TAMM files to extract the key sheets

Usage

read_key_tamm_sheets_chin(xlsxFile)

Arguments

xlsxFile

#Tamm file name

Value

List of dataframes: ⁠$overview⁠, ⁠$limiting⁠, and ⁠$input⁠


Read Chinook TAMM files to extract the key sheets

Description

Read Chinook TAMM files to extract the key sheets

Usage

read_key_tamm_sheets_coho(xlsxFile)

Arguments

xlsxFile

#Tamm file name

Value

List of dataframes: ⁠$two⁠, ⁠$tami⁠, and ⁠$wacoast⁠


Read TAMM limiting stock complete tab

Description

Reads in the table, adds fishery type information.

Usage

read_limiting_stock(filename, longform = FALSE)

Arguments

filename

Tamm name (and path)

longform

Should results be in long form (good for R stuff) (TRUE) or replicate the structure of the TAMM sheet (FALSE). Logical, defaults to FALSE.

Value

data frame summarizing the TAMM limiting stock tab.


Extract and format management criterion from Chinook TAMM

Description

Extract and format management criterion from Chinook TAMM

Usage

read_management_chin(file)

Arguments

file

filename, including filepath if appropriate

Value

Tibble, with ⁠$management_name⁠ giving the name of the management criteria as specified in the TAMM, ⁠$management_criteria⁠ giving a list of dataframes with the associated management criteria, formatted appropriately, and ⁠$notes⁠ giving a list of character vectors with notes (if any) to help interpret the criteria.

Examples

## Not run: 
cur.management = read_management_chin("Code Inputs/Pre-Season/TAMMs/2013_Final W_BP7.1.xlsx")

## End(Not run)

Read overview sheet from TAMM and return key stock

Description

Read overview sheet from TAMM and return key stock

Usage

read_overview(path)

Arguments

path

filename (including path) to Chinook TAMM

Value

dataframe


Read overview sheet from TAMM and return all stock

Description

The stock column of the overview tab uses R-unfriendly approaches to store season, overall stock name, and individual stocks in the stock column of the TAMM. read_overview_complete splits these into separate columns: season, primary_stock, and stock. For three stock (Green, Puyallup, Skokomish), the tamm presents model predictions across two rows with a single stock name due to merged cells. The stock column in the output preserves this information; the entry corresponding to the second row has the suffix "_row2".

Usage

read_overview_complete(path)

Arguments

path

filename (including path) to Chinook TAMM

Value

Dataframe containing all infomration from cells A2:H34 of the "ER_ESC_Overview_New" sheet.


[Experimental]

Description

Extract Treaty and Nontreaty numbers from "2A_CU&M_H+N" TAMM sheet. For Elwha and Dungeoness, separate allocations are calculated using column O of the JDF tab

Usage

read_tnt_allocation_chin(xlsxFile)

Arguments

xlsxFile

Character vector. Filename (including path) for chinook TAMM

Details

Currently provides dataframe with stock.original column identifying the stock based on their names in the TAMM, and stock.clean with more human-readable names (which are generally consistent with other stock names, like those used to label the management criterion).

Value

dataframe with the treaty and nontreaty mortalities at each stock.


Convenience function for formatting TAMM management criterion chunks

Description

Internal tool to simplify converting TAMM sheet to stock management criterion lists. See read_management_chin() for example use.

Usage

reformat_management(
  df,
  cols.percent,
  rows.percent = NULL,
  rows.header = 2,
  notes = NULL
)

Arguments

df

dataframe trimmed from TAMM management page to just the relevant stock's criterion.

cols.percent

Column numbers for columns that should be converted to percents.

rows.percent

Character vector of row sub-stock names identifying rows (if any) that should be translated to percents. Defaults to NULL. Developed to accomodate "CERC (SUS)" in Snohomish.

rows.header

How many rows are used to make up the header? Defaults to 2, but sometimes header block in TAMM is 1 row.

notes

Optional. Character vector, each item of which is a separate note associated with this stock. Generally based on comments in excel doc, can also feed in "extra" rows from TAMM that contain caveats.

Value

Stock management criterion list, containing dataframe extracted from TAMM and notes hard-coded in based on TAMM cell comments.


Convert string of number to numeric

Description

Helper function to check an atomic string and convert to numeric if it contains a legal number.

Usage

safe_convert_numeric(x)

Arguments

x

character string

Value

Input formatted as character string or numeric

Examples

safe_convert_numeric("AS20-BC2")
safe_convert_numeric("10.5")

Chinook stock information

Description

Mapping of stock_id to stock name for Chinook salmon, taken from the Stock table of the Chinook FRAM database.

Usage

stock_chinook_fram

Format

A data frame with 78 rows and 7 columns:

species

Species name

stock_version
stock_id

Chinook stock id number in FRAM

production_region_number
management_unit_number
stock_name

Chinook stock name in FRAM

stock_long_name

stock_name but more human readable

Source

2024 Pre-Season Chinook DB.mdb


Coho stock information

Description

Mapping of stock_id to stock name for Coho salmon, taken from the Stock table of the Coho FRAM database.

Usage

stock_coho_fram

Format

A data frame with 78 rows and 7 columns:

species

Species name

stock_version
stock_id

Coho stock id number in FRAM

production_region_number
management_unit_number
stock_name

Coho stock name in FRAM

stock_long_name

stock_name but more human readable

Source

2024NOF_CohoFRAMdatabase_distribution.mdb


Generate summary comparison of any number of TAMM files

Description

Intended use case is to compare low, mid, and high ocean option.

Usage

tamm_compare(
  tamm.names,
  tamm.path = getwd(),
  fisheries = NULL,
  clean = TRUE,
  overwrite = TRUE
)

Arguments

tamm.names

character vector of the three tamm files to compare (including .xlsx suffix).

tamm.path

Absolute path to directory containing the tamm file. here::here() can be useful in identifying appropriate path. Character atomic; defaults to current working directory.

fisheries

Optional, numeric vector of fishery IDs to filter to before plotting fishery-specific ER for each stock. Defaults to NULL (no filtering).

clean

Should the intermediate .qmd files used to make the report be deleted afterwards? Logical, defaults to TRUE. Set to FALSE to explore the .qmd files underlying the report.

overwrite

Should the intermediate .qmd files or the final report be overwritten if those files already exist?; Logical, defaults to TRUE.

Value

Nothing

Examples

## Not run: 
tamm.path <- "C:/Users/edwc1477/Documents/WDFW FRAM team work/NOF material/NOF 2024/FRAM"
tamm.names <- c("Chin1024.xlsx", "Chin1124.xlsx", "Chin1224.xlsx")
tamm_compare3(tamm.names = tamm.names, tamm.path = tamm.path)

## End(Not run)

Generate summary comparison of 3 TAMM files

Description

Intended use case is to compare low, mid, and high ocean option.

Usage

tamm_compare3(tamm.names, tamm.path = getwd(), clean = TRUE, overwrite = TRUE)

Arguments

tamm.names

character vector of the three tamm files to compare (including .xlsx suffix).

tamm.path

Absolute path to directory containing the tamm file. here::here() can be useful in identifying appropriate path. Character atomic; defaults to current working directory.

clean

Should the intermediate .qmd files used to make the report be deleted afterwards? Logical, defaults to TRUE. Set to FALSE to explore the .qmd files underlying the report.

overwrite

Should the intermediate .qmd files or the final report be overwritten if those files already exist?; Logical, defaults to TRUE.

Value

Nothing

Examples

## Not run: 
tamm.path <- "C:/Users/edwc1477/Documents/WDFW FRAM team work/NOF material/NOF 2024/FRAM"
tamm.names <- c("Chin1024.xlsx", "Chin1124.xlsx", "Chin1224.xlsx")
tamm_compare3(tamm.names = tamm.names, tamm.path = tamm.path)

## End(Not run)

Compare key sheets of TAMM files

Description

Compare key sheets of TAMM files

Usage

tamm_diff(
  filename.1,
  filename.2,
  results.name,
  percent.digits = 1,
  numeric.digits = 1,
  numeric.digits.small = 4,
  dim.override = FALSE,
  wrap.text = FALSE
)

Arguments

filename.1

name of first TAMM file to compare. Include file path if file is not in working directory.

filename.2

name of second TAMM file to compare. Include file path if file is not in working directory.

results.name

name of output sheets. Include file path if save location is not in working directory.

percent.digits

Number of decimals to round percentages to before comparing. Defaults to 1.

numeric.digits

Number of decimals to round numbers to before comparing. Applied to cells which expect to be whole numbers (e.g. #s of fish). Defaults to 1.

numeric.digits.small

Number of decimals to round numbers to before comparing. Applied to cells which expect to be small decimals. Defaults to 4.

dim.override

Should we force comparisons even if one or more of the sheets don't have matching dimensions between the two files? Defaults to FALSE.

wrap.text

Should specific cells with long contents (e.g., input "Fishery Description" cells) use text wrapping? Defaults to FALSE

Details

If TAMM formatting is changes (e.g. the addition of rows, etc), make changes in the following areas:

  • read_key_tamm_sheets_SPECIES(): The range argument in each read_excel call should change to match the new dimensions of each sheet.

  • format_key_tamm_sheets_SPECIES(): These functions designate groups of cells to be Depending on the sheets that change, any amount of the content here may need to change. In the case of the inputs tab section, the cell ranges can be reported directly. Remember that we are separately designating cells which should be rounded to the nearest numeric.digits (generally measures of fish) and those that should be rounded to the nearest numeric.digits.small (generall proportions and rates; typically values that are less than 1.). Note that the earlier code was written before the more flexible chunk_formater_percenter and chunk_formater_rounder had been developed. If rewriting, lean into those tools, as they will streamline designating regions of cells for the various rounding criterion.

  • tamm_format_SHEETNAME() (for the sheet formatting functions relevant to that species): each individual sheet has custom formatting to generally match the corresponding TAMM sheets. If the locations of cells move, the changes to font size, addition of borders, etc, will also need to move. Note that tamm_format_limiting and tamm_format_overview were written before the development of the more flexible add_cell_borders, or the combined use of purrr::map and cell_range_translate. Look to tamm_format_input for relatively inputting of formatting. Consider developing other helper functions as needed (esp for merging).

Examples

## Not run: 
tamm_diff(
  filename.1 = here("FRAM/Chin1124.xlsx"),
  filename.2 = here("NOF 2/Chin2524.xlsx"),
  results.name = here("Chin 1124 vs Chin 2524.xlsx")
)

## End(Not run)

Compare key sheets of Chinook TAMM files

Description

Compare key sheets of Chinook TAMM files

Usage

tamm_diff_chin(
  filename.1,
  filename.2,
  results.name,
  percent.digits = 1,
  numeric.digits = 1,
  numeric.digits.small = 4,
  dim.override = FALSE,
  wrap.text = FALSE
)

Arguments

filename.1

name of first TAMM file to compare. Include file path if file is not in working directory.

filename.2

name of second TAMM file to compare. Include file path if file is not in working directory.

results.name

name of output sheets. Include file path if save location is not in working directory.

percent.digits

Number of decimals to round percentages to before comparing. Defaults to 1.

numeric.digits

Number of decimals to round numbers to before comparing. Applied to cells which expect to be whole numbers (e.g. #s of fish). Defaults to 1.

numeric.digits.small

Number of decimals to round numbers to before comparing. Applied to cells which expect to be small decimals. Defaults to 4.

dim.override

Should we force comparisons even if one or more of the sheets don't have matching dimensions between the two files? Defaults to FALSE.

wrap.text

Should specific cells with long contents (e.g., input "Fishery Description" cells) use text wrapping? Defaults to FALSE


Compare key sheets of Coho TAMM files

Description

Compare key sheets of Coho TAMM files

Usage

tamm_diff_coho(
  filename.1,
  filename.2,
  results.name,
  percent.digits = 2,
  numeric.digits = 1,
  numeric.digits.small = 4,
  dim.override = FALSE,
  wrap.text = FALSE
)

Arguments

filename.1

name of first TAMM file to compare. Include file path if file is not in working directory.

filename.2

name of second TAMM file to compare. Include file path if file is not in working directory.

results.name

name of output sheets. Include file path if save location is not in working directory.

percent.digits

Number of decimals to round percentages to before comparing. Defaults to 1.

numeric.digits

Number of decimals to round numbers to before comparing. Applied to cells which expect to be whole numbers (e.g. #s of fish). Defaults to 1.

numeric.digits.small

Number of decimals to round numbers to before comparing. Applied to cells which expect to be small decimals. Defaults to 4.

dim.override

Should we force comparisons even if one or more of the sheets don't have matching dimensions between the two files? Defaults to FALSE.

wrap.text

Should specific cells with long contents (e.g., input "Fishery Description" cells) use text wrapping? Defaults to FALSE


Apply final formatting to diff'd TAMM sheets

Description

Functions that add formatting to broadly replicate the formatting of the TAMM sheets. Colored foregrounds have been toned down to help change highlighting pop, and some of the complicated or superfluous formatting has been skipped.

Usage

tamm_format_overview(wb, diff.sheet, tabname = "overview")

tamm_format_limiting(wb, tabname = "limiting")

tamm_format_input(wb, tabname = "input", wrap.text = FALSE)

tamm_format_wacoast(wb, tabname = "wacoast")

Arguments

wb

openxlsx workbook object containing ⁠$overview⁠, limiting and ⁠$input⁠ sheets with the contents of diffing two TAMM files.

diff.sheet

For tamm_format_overview, the output of xldiff::sheet_comp of the overview tab. Used to programmatically bold the appropriate ERs based on the management objective.

tabname

Name of sheet in the wb to be modified. Defaults to correct value.

wrap.text

Should specific cells with long content use text wrapping? Defaults to FALSE.


Generate report of figures from TAMM file

Description

Generate report of figures from TAMM file

Usage

tamm_report(
  tamm.name,
  tamm.path = getwd(),
  clean = TRUE,
  overwrite = TRUE,
  additional.children = NULL,
  additional.support.files = NULL
)

Arguments

tamm.name

Name of tamm file (including .xlsx suffix). Character atomic

tamm.path

Absolute path to directory containing the tamm file. here::here() can be useful in identifying appropriate path. Character atomic; defaults to current working directory.

clean

Should the intermediate .qmd files used to make the report be deleted afterwards? Logical, defaults to TRUE. Set to FALSE to explore the .qmd files underlying the report.

overwrite

Should the intermediate .qmd files or the final report be overwritten if those files already exist?; Logical, defaults to TRUE.

additional.children

Optional argument with filepath(s) to additional quarto child documents (see Details). Defaults to NULL.

additional.support.files

Optional argument with filepath(s) to additional files needed by additional quarto documents. Files will be copied into the same directory as the TAMM for easy reading/use by additional.children quarto files, and then deleted after the report is generated

Details

This function generates a summary report of a single chinook TAMM (Terminal Area Management Module) file. The common use case is to call this function for a tamm, and then view the resulting html report (which will be generated in the same folder as the TAMM). However, this function also provides substantial flexibility in the form of optional user-created child quarto documents, which requires some additional context to develop and use.

tamm_report is implemented using a parameterized quarto report and a child quarto document, which are included in the package. The resulting report includes some broadly useful content – currently, a replication of the overview TAMM sheet and bar charts showing the breakdown of exploitation rates by fishery for each stock listed in the ⁠limiting stock complete⁠ TAMM sheet. However, individuals or organizations may consistently want additional, specific visualizations based on their own needs. For example, individual tribes may want to visualize impacts on a single stock, but use AEQ instead of ER rates. The tamm_report function is designed to integrate these extra components with the additional.children argument.

The basic principle is that the individual or group can write a reusable "child" .qmd file, see this explanation using Rmarkdown), which will effectively be inserted into the main report. As an example, we might create a simple additional child .qmd file called extra-tamm-child.qmd to include a small table summarizing a few key aspects of the Nooksack Earlies stock. The contents of that file are provided in the example below.

When we call tamm_report(), we can include as an argument ⁠additional.children = ⁠ with the file name (including file path) for our new file. In this way we can easily include this extra content any time we create a tamm report. If desired, multiple child files can be created, and additional.children can take a character vector with each child file name.

When writing child documents, formatting and chunks work akin to copy-pasting a section of a quarto file out of the main file. (To easily access the main quarto file, run tamm_report() with clean = FALSE, which will leave tamm-visualizer.qmd and tamm-visualizer-child.qmd files in the folder with the TAMM file). The child document will have access to key objects

  • dat.all: the output of read_limiting_stock with longform = TRUE called on the TAMM;

  • dat.overview: the output of of read_overview called on the TAMM;

  • and dat: the specific filtered and formatted version of the limiting stock data generated in the ⁠limiting stock tab⁠ chunk of tamm-visualizer.qmd and used in generating the unmarked natural stock exploitation rate figures. When developing a child document, it may be useful to create in the working environment versions of dat.all and dat.overview from an example TAMM to facilitate writing appropriate filters, plot-making code, etc. The primary quarto report loads in the tidyverse, framrsquared, kableExtra, and TAMMsupport packages, but you can include additional packages for the child documents as needed by adding ⁠library(packagename⁠ calls just like in any other context.

If the additional.children files need to read contents of additional files (or call children .qmd files of their own to streamline looping over stocks or fisheries), the file paths to these supplemental files can be provided in the ⁠additional.support files⁠ argument. These files will be copied into the same folder as the .qmd files, so the children quarto files can be written to access the supplemental files without dealing with file paths.

For questions/support in developing child documents to extend the report, contact Collin Edwards at WDFW.

Value

Nothing

Examples

## Not run: 
##### CONTENTS FOR extra-tamm-child.qmd #####-----------------------------
## Test section

Hypothetical world in which we want a table summarizing the impacts of three
fisheries on the "Nooksack Earlies" stock.

```{r}
kable(dat |> filter(stock == "Nooksack Earlies") |> filter(fishery_id %in% 16:18))
```
#### END CONTENTS FOR extra-tamm-child.qmd #####--------------------------

tamm.path = "C:/Users/edwc1477/Documents/WDFW FRAM team work/NOF material/NOF 2024/NOF 2"
tamm.name = "Chin2124.xslx"
tamm_report(tamm.name = "Chin2124.xlsx", tamm.path = tamm.path)
## Now with our extra content, presuming `extra-tamm-child.qmd` is saved in our documents folder
tamm_report(tamm.name = "Chin2124.xlsx", tamm.path = tamm.path,
  additional.children = "C:/Users/JohnDoe/Documents/extra-tamm-child.qmd")

## End(Not run)

Chinook timestep information stock information

Description

Mapping of timestep numbers to dates in the year, taken from the TimeStep table of the Chinook FRAM database

Usage

timestep_chinook_fram

Format

A data frame with 4 rows and 5 columns:

species

Species name

version_number
time_step_id

id number for the time step

time_step_name

Span of each timestep. Timesteps start on the first of the month, and end on the last of the month. Note that Oct-Apr-2 is highlighting that timestep 4 runs from October of the current year to April of the NEXT year (equivalent to timestep 1 of the following year).

time_step_title

time_step_name, but months are written out

Source

2024 Pre-Season Chinook DB.mdb


Coho timestep information stock information

Description

Mapping of timestep numbers to dates in the year, taken from the TimeStep table of the Chinook FRAM database

Usage

timestep_coho_fram

Format

A data frame with 5 rows and 5 columns:

species

Species name

version_number
time_step_id

id number for the time step

time_step_name

Span of each timestep. Timesteps start on the first of the month, and end on the last of the month.

time_step_title

time_step_name, but months are written out consistently

Source

2024NOF_CohoFRAMdatabase_distribution.mdb


Trace the calculations of a cell recursively through all referenced cells

Description

[Experimental]

Usage

trace_formula(
  path,
  cell.start,
  max.it = 5000,
  verbose = TRUE,
  split.ranges = FALSE
)

Arguments

path

Filepath of an excel file

cell.start

Character string of intiial cell in excel format. MUST include sheet name (e.g. "SPS!AS20", not "AS20")

max.it

Maximum iterations; used as a failsafe to ensure function eventually in case of circular error. Defaults to 5000; increase if actual dependency network is likely to have more than 5000 nodes.

verbose

Print cell addresses to console during tracing? Logical, defaults to FALSE.

split.ranges

When encountering a reference that includes a cell range, trace backwards for all cells (TRUE) or just the first cell in the range (FALSE)? Logical, defaults to FALSE. This option was added because sometimes formulas include sums across large ranges, ballooning the size of the resulting network. For building understanding, it is sometimes sufficient to trace only a representative from each referenced range, leading to smaller and simpler plots.

Value

"trace object" – list defining the dependency network.

⁠$cells⁠

tibble summarizing each of the cells in the dependency network, starting with the cell.start. Within this, ⁠$id⁠ is an index; ⁠$label⁠ is the cell address; ⁠$formula⁠ is the formula in that cell if there is a formula, otherwise it is the contents of the cell, ⁠$contents⁠ is the non-formula cell contents (i.e., if a formula is present, ⁠$contents⁠ will be the results of the formula); ⁠$is.formula⁠ is a logical identifying if this cell contains a formula, or is purely a numeric / string / etc contents; ⁠$addresses.referenced⁠ is a character vector of all excel addresses in ⁠$formula⁠, and sheet is the sheet associated with the current cell.

⁠$references⁠

is a tibble summarizing each of the edges of the dependency network – that is, all of the references in one cell to another. ⁠$from⁠ is the index of the cell that is referenced; ⁠$to⁠ is the index of the cell that is doing the referencing; ⁠$from_name⁠ and ⁠$to_name⁠ are the excel addresses of the same.

⁠$raw.tracing⁠

list created during tracing that forms the backbone of trace_formula. Intended for internal use; ⁠$cells⁠ and ⁠$references⁠ contains the important results here.

Examples

## Not run: 
trace_network = trace_formula(path = "NOF material/NOF 2024/NOF 2/Chin1624.xlsx",
 cell.start = "SPSmrkd!AS20")

## End(Not run)

Confirm object is dataframe

Description

Confirm object is dataframe

Usage

validate_data_frame(
  x,
  ...,
  arg = rlang::caller_arg(x),
  call = rlang::caller_env()
)

Arguments

x

Object to check

...

additional arguments

arg

name of argument in calling function, identified programmatically using rlang

call

name of calling function, identified programmatically using rlang