NAFOdown is an R package designed to simplify the process of creating and updating NAFO documents. The package utilizes the bookdown package which facilitates the integration of Markdown syntax and R code and, as such, effectively provides a “one-stop-shop” tool through which analyses, plots, tables, and text can be written in parallel and knit into a stand-alone and reproducible document. Such a workflow minimizes the significant amount of manual effort associated with copying and pasting data, summary statistics and plots from one program to another. By linking input data directly with the body of the text and to figures and tables, documents can be automatically updated to include additional years of data; this may be of particular value to Designated Experts as they update interim monitoring reports and other assessment documents. This approach also minimizes the amount of time spent on formatting documents as the NAFOdown package, like the csasdown and thesisdown packages which this package is based on, includes templates that conform to formatting guidelines. Specifically, NAFOdown includes templates for producing SCR, STACFIS, and SCS documents in Word format. Here we demonstrate how to use this package.
The statistical computing program R is required to use the NAFOdown package and we highly recommend using RStudio to manage R projects. With RStudio installed a project can be started in an existing or new directory using the drop-down menus in Rstudio. After setting up a project, Rstudio will generate a .Rproj file which will automatically set the working directory to the project folder when this file is opened. This will simplify the process of telling R where to find the files needed for the report.
NAFOdown can be installed via GitHub using this code:
# install.packages("remotes")
remotes::install_github("nafc-assess/NAFOdown")
A skeleton of a NAFO document will be produced and stored in your working directory by running this code:
getwd() # this is where files and folders of the skeleton will be saved
NAFOdown::draft(report_type = "SCR")
The type of skeleton produced can be changed by changing the
report_type
argument from "SCR"
to "STACFIS"
or "SCS"
. The
components of the skeleton are outlined below. Note that all of the
files included in the skeleton are text based and can be opened and
edited using RStudio.
This is a key file that contains all the meta information that defines much of the formatting of the document as well as the information for the beginning of the document. Several of these items will need to be edited, such as the author, title, etc.
These are the .Rmd files for each section of the report. These files
will hold all the markdown text and R code (e.g. tables and figures)
needed to produce the document. Note that the SCR template includes a
series of .Rmd files (01_body.Rmd
, 02_references.Rmd
, and
03_appendix.Rmd
), as these reports can be extensive, while the STACFIS
and SCS templates are simpler and only includes a body.Rmd
file.
This file outlines the .Rmd files to be combined by bookdown. This is
also where some options are modified such as the prefix for table and
figure captions (e.g. Figure instead of Fig.). Depending on the use
case, specific components may not be needed and these files can be
excluded from the .Rmd file list contained within this file
(e.g. appendix.Rmd
). Alternatively, for extensive SCR documents, it
may be useful to create and specify separate 01_introduction.Rmd
,
02_methods.Rmd
, 03_results.Rmd
, and 04_discussion.Rmd
files in
lieu of one large 01_body.Rmd
.
This folder holds the style files for bibliographies, specified using a citation style language file (.csl). Currently, SCR documents will follow the Harvard citation format. This folder is not included in the STACFIS or SCS templates as references are rarely used.
BibTeX references are to be included in the refs.bib
file inside this
folder. BibTeX entries can be exported from most journal web-pages,
Google scholar and from reference managers such as
Zotero. Copy this text into the refs.bib
file and note the tag used for each entry as this is what will be used
to reference specific papers. Also consider using the Rstudio
citr add-in to simplify the insertion of
citations.
NAFOdown is built upon the bookdown package which is built upon R markdown. In short, R markdown provides a reproducible authoring framework for scientists as a single file can be used to embed chunks of code from R, and other coding languages, into a Markdown document. Markdown is a simple plain text formatting syntax that can be converted to a wide range of outputs, such as HTML and pdf. The format is easy-to-read and the fact that it detaches writing from formatting allows authors to focus on writing. Pairing R with Markdown creates a very flexible and efficient platform for producing a wide range of documents. See the bookdown book on bookdown for more details on its capabilities (https://bookdown.org/yihui/bookdown/).
Tables included in NAFO documents are often extensive and, as such, we
recommend the use of the
flextable package.
Tables produced using this package are highly customizable and a theme
function, NAFOdown::theme_nafotabs()
, has been added to this package
to facilitate consistent formatting of tables in NAFO documents.
NAFOdown also includes a ggplot2
theme, NAFOdown::theme_nafo()
to aid the consistent formatting of
figures. The theme is specific to the ggplot2 package because it is a
widely used package that is extremely flexible and capable of producing
figures typically used in NAFO documents. While theme_nafo()
provides
a consistent base format, the flexibility remains to customize
components to suit the specific requirements of the author though
modification of individual theme elements within the ggplot2 framework
(e.g. font size, legend formatting).
As noted above, several of the files need to be populated with content.
In most cases, the body.Rmd
file will hold most of the content and
take the most time to draft. Moreover, these documents may evolve over
time. Managing a series of drafts can be a cumbersome task and, as such,
we recommend that versions are tracked using a version control system
such as Git. Rstudio integrates nicely with Git and the hosting service
GitHub, and thereby provides a platform for syncing versions with an
online repository (i.e. this acts as a back-up and facilitates remote
collaboration). For a gentle guide to getting starting with using Git
and GitHub with R and RStudio, see http://happygitwithr.com/.
To render a NAFO report in Word format, open index.Rmd
in Rstudio and
click the “knit” button:
Documents can also be rendered in the R console, assuming the working
directory is set to the directory holding the index.Rmd
file, using
bookdown’s render
function:
bookdown::render_book("index.Rmd")
The rendered Word file will be saved in the _book/
directory. When all
files are populated with the necessary content, the output will look
similar to past documents:
While there is an initial cost to building these documents, they will be much easier to update following the addition of new data as all tables and figures should automatically update. This workflow will also improve the transparency and reproducibility of the work, especially if changes are tracked using git.
NAFO. (2020a). Greenland halibut in SA2 + Divs. 3KLMNO: conduct an update assessment, compute the TAC using the agreed HCR and determine whether exceptional circumstances are occurring (COM request #2). In Report of the Scientific Council, 28 May -12 June 2020, By correspondence. NAFO SCS Doc, 20/14, Pages 19–31. https://www.nafo.int/Portals/0/PDFs/sc/2020/scs20-14.pdf
NAFO. (2020b). Greenland Halibut (Reinhardtius hippoglossoides) in Subarea 2 + Divisions 3KLMNO. In Report of the Scientific Council, 28 May -12 June 2020, By correspondence. NAFO SCS Doc, 20/14, Pages 221–223. https://www.nafo.int/Portals/0/PDFs/sc/2020/scs20-14.pdf
Regular, P. M. (2020). Update of Base Case SSM for Greenland Halibut in NAFO Subarea 2 and Divisions 3KLMNO. NAFO SCR Doc, 20/050. https://www.nafo.int/Portals/0/PDFs/sc/2020/scr20-050.pdf
Regular, P. M., Rademeyr, R., D., V., D., B., and C., F. (2020). Correcting mis-calculated values of Jtarge**t for use in the Greenland halibut HCR. NAFO SCR Doc, 20/042. https://www.nafo.int/Portals/0/PDFs/sc/2020/scr20-042%20.pdf
Regular, P. M., Rideout, R. M., and W., I. D. (2020). Impact of missed strata on abundance-at-age estimates of Greenland halibut from the Canadian fall 2J3K and spring 3LNO surveys in 2018. NAFO SCR Doc, 20/005 REV. https://www.nafo.int/Portals/0/PDFs/sc/2020/scr20-005REV.pdf
Rogers, B., and Simpson, M. (2020). Canadian Research Report for 2019. NAFO SCS Doc, 20/11. https://www.nafo.int/Portals/0/PDFs/sc/2020/scs20-11.pdf
This is an open project and we welcome constructive feedback. Please report problems and/or make suggestions under the issues page. Also feel free to activity contribute to the package by submitting changes under the pull requests page. Please note that the NAFOdown project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.