| Type: | Package | 
| Title: | Process and Report 'GreenFeed' Data | 
| Version: | 1.3.1 | 
| Maintainer: | Guillermo Martinez-Boggio <gmartinezboggio@ucdavis.edu> | 
| Description: | Provides tools for downloading, processing, and reporting daily and finalized 'GreenFeed' data. | 
| License: | GPL (≥ 3) | 
| Encoding: | UTF-8 | 
| RoxygenNote: | 7.3.2 | 
| Imports: | dplyr, ggplot2, httr, lubridate, purrr, readr, readxl, rmarkdown, shiny, stats, stringr, tidyr | 
| Depends: | R (≥ 2.10) | 
| Suggests: | knitr, testthat (≥ 3.0.0) | 
| Config/testthat/edition: | 3 | 
| BugReports: | https://github.com/GMBog/greenfeedr/issues | 
| URL: | https://github.com/GMBog/greenfeedr | 
| VignetteBuilder: | knitr | 
| NeedsCompilation: | no | 
| Packaged: | 2025-09-05 18:57:20 UTC; GuillermoMartinez | 
| Author: | Guillermo Martinez-Boggio | 
| Repository: | CRAN | 
| Date/Publication: | 2025-09-05 19:50:02 UTC | 
Compare Preliminary and Finalized 'GreenFeed' Data
Description
Compare preliminary and finalized 'GreenFeed' data.
Arguments
| prelimrep | a data frame with preliminary 'GreenFeed' data | 
| finalrep | a data frame with finalized 'GreenFeed' data | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
Value
Data frame including records removed from preliminary and final reports
Examples
# Datasets with preliminary and finalized GreenFeed data
prelimrep <- system.file("extdata", "StudyName_GFdata.csv", package = "greenfeedr")
finalrep <- system.file("extdata", "StudyName_FinalReport.xlsx", package = "greenfeedr")
data <- compare_gfdata(
  prelimrep,
  finalrep,
  start_date = "2024-05-13",
  end_date = "2024-05-20"
)
Convert 'GreenFeed' Unit Number
Description
Processes the parameter unit to format it correctly as a comma-separated string, regardless of whether it is provided as a numeric, character, or list/vector.
Usage
convert_unit(unit, t)
Arguments
| unit | Number of the 'GreenFeed' unit(s). Can be a numeric, character, list, or vector. | 
| t | Type of function (opts: 1 and 2). | 
Value
A character string of the unit(s) in the correct comma-separated format.
Examples
# Example 1: Providing unit as a character vector
unit <- c("592", "593")
convert_unit(unit, 1)
# Example 2: Providing unit as a single numeric
unit <- 592
convert_unit(unit, 1)
# Example 3: Providing unit as a comma-separated character string
unit <- "592, 593"
convert_unit(unit, 1)
# Example 4: Providing unit as a list
unit <- list(592, 593)
convert_unit(unit, 1)
Download data from 'API'
Description
Download all types of 'GreenFeed' from 'API'
Usage
download_data(
  user,
  pass,
  d,
  type = 2,
  unit = NULL,
  start_date = NULL,
  end_date = NULL
)
Value
A dataframe
Examples
# Please replace "your_username" and "your_password" with your actual 'GreenFeed' credentials.
# By default, the function downloads the preliminary 'GreenFeed' data,
# if raw data is needed use options: "feed", "rfid", or "cmds"
download_data(
  user = "your_username",
  pass = "your_password",
  d = "visits",
  type = 2,
  unit = c(304, 305),
  start_date = "2024-01-01",
  end_date = Sys.Date()
)
Check date format and transform in a usable one
Description
Check date format. If the format is wrong ('NA') an error message is printed, else it will formatted the date in the correct way (YYYY-MM-DD)
Usage
ensure_date_format(date_input)
Arguments
| date_input | Date included as input | 
Value
A character string representing the date in 'YYYY-MM-DD' format
Examples
# Example of correct date formats
ensure_date_format("2024-08-30") # "2024-08-30"
ensure_date_format("30/08/2024") # "2024-08-30"
# Example of incorrect date formats
tryCatch(
  {
    ensure_date_format("Aug-30")
  },
  error = function(e) {
    message(e$message)
  }
)
Evaluate all combination of parameters
Description
Evaluate parameters that best fit your 'GreenFeed' data
Usage
eval_gfparam(data, start_date, end_date, gas = "CH4")
Arguments
| data | a data frame with preliminary or finalized 'GreenFeed' data | 
| start_date | a character string representing the start date of the study (format: "dd/mm/yyyy") | 
| end_date | a character string representing the end date of the study (format: "dd/mm/yyyy") | 
| gas | a character with the type of gas to evaluate the parameters | 
Value
A data frame with the mean, SD, and CV for gas production using all possible combination of parameters
Examples
file <- readr::read_csv(system.file("extdata", "StudyName_GFdata.csv", package = "greenfeedr"))
eval <- eval_gfparam(data = file,
                     start_date = "2024-05-13",
                     end_date = "2024-05-20",
                     gas = "CH4"
                    )
Detect outliers in data using mean and standard deviation
Description
Detect outliers using the mean and standard deviation.
Usage
filter_within_range(v, cutoff)
Arguments
| v | A vector with data | 
| cutoff | A threshold or cutoff value that defines the range (e.g., 3) | 
Value
A logical vector of the same length as 'v', where each element is 'TRUE' if the corresponding value in 'v' falls within the specified range, and 'FALSE' otherwise.
Examples
# Sample data
data <- c(10, 12, 14, 15, 20, 25, 30, 100)
# Detect values within 3 standard deviations from the mean
filter_within_range(data, cutoff = 3)
# Result:
# [1] TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE
# Explanation: All values fall within 2.5 standard deviations from the mean.
# Detect values within 1 standard deviation from the mean
filter_within_range(data, cutoff = 1)
# Result:
# [1] TRUE TRUE TRUE TRUE TRUE TRUE TRUE FALSE
# Explanation: All values except 100 fall within 1 standard deviation from the mean.
Download Preliminary and Raw 'GreenFeed' Data via 'API'
Description
Downloads preliminary and raw 'GreenFeed' data from the 'C-Lock Inc.' server via an 'API'. Retrieves data based on specified parameters (login, date range, and units), and provides a CSV file with the 'GreenFeed' preliminary data.
Usage
get_gfdata(
  user,
  pass,
  d = "visits",
  type = 2,
  exp = NA,
  unit,
  start_date,
  end_date = Sys.Date(),
  save_dir = tempdir()
)
Arguments
| user | a character string representing the user name to logging into 'GreenFeed' system | 
| pass | a character string representing password to logging into 'GreenFeed' system | 
| d | a character string representing data to download (opts: "visits", "feed", "rfid", "cmds") | 
| type | a numeric representing the type of data to retrieve (1=finalized and 2=preliminary) | 
| exp | a character string representing study name or other study identifier. It is used as file name to save the data | 
| unit | numeric or character vector, or a list representing one or more 'GreenFeed' unit numbers | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| save_dir | a character string representing the directory to save the output file | 
Value
A CSV file with the specified data (visits or raw) saved in the provided directory.
Examples
# Please replace "your_username" and "your_password" with your actual 'GreenFeed' credentials.
# By default, the function downloads the preliminary 'GreenFeed' data,
# if raw data is needed use options: "feed", "rfid", or "cmds"
get_gfdata(
  user = "your_username",
  pass = "your_password",
  d = "visits",
  type = 2,
  exp = "StudyName",
  unit = c(304, 305),
  start_date = "2024-01-01",
  end_date = Sys.Date(),
  save_dir = tempdir()
)
Check for 'API' Credentials
Description
Check if necessary 'API' credentials are available in the environment.
Usage
has_credentials()
Value
A logical value: 'TRUE' if both 'API_USER' and 'API_PASS' environment variables are set (i.e., not 'NA'); 'FALSE' otherwise
Examples
# Example 1: When environment variables are set
Sys.setenv(API_USER = "my_username", API_PASS = "my_password")
has_credentials()
# Expected output: TRUE
# Example 2: When one or both environment variables are not set
Sys.unsetenv("API_USER")
Sys.unsetenv("API_PASS")
has_credentials()
# Expected output: FALSE
# Clean up by removing environment variables
Sys.unsetenv("API_USER")
Sys.unsetenv("API_PASS")
Process 'GreenFeed' Pellet Intakes
Description
Processes 'feedtimes' file from 'GreenFeed' system. Food drops are used to calculate pellet intakes per animal. Aggregates data to provide insights into the feeding behavior and pellet consumption of the animals during a study.
Arguments
| user | a character string representing the user name to logging into 'GreenFeed' system | 
| pass | a character string representing password to logging into 'GreenFeed' system | 
| unit | numeric or character vector or list representing one or more 'GreenFeed' unit numbers. The order should match with "feedtimes" files | 
| gcup | a numeric value representing the grams of pellets per cup. If dual-hopper you can define multiple grams per unit | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| save_dir | a character string representing the directory to save the output file | 
| rfid_file | a character string representing the file with individual IDs. The order should be Visual ID (col1) and RFID (col2) | 
| file_path | a character string or list representing files(s) with "feedtimes" from 'C-Lock Inc.' | 
Value
An Excel file with pellet intakes for all animals and days within the specified period is saved to save_dir. The file is named "Pellet_Intakes_YYYY-MM-DD_YYYY-MM-DD.csv".
Examples
# You should provide the 'feedtimes' file provided by C-Lock.
# it could be a list of files if you have data from multiple units to combine
path <- system.file("extdata", "feedtimes.csv", package = "greenfeedr")
# You must include the grams of pellets per cup based on the result obtained from the 10-drops test
# If the user include an rfid file, the structure should be in col1 AnimalName or Visual ID, and
# col2 the RFID or TAG_ID. The file could be save in different formats (.xlsx, .csv, or .txt).
RFIDs <- system.file("extdata", "RFID_file.csv", package = "greenfeedr")
pellin(
  unit = 1,
  gcup = 34,
  start_date = "2024-05-13",
  end_date = "2024-05-25",
  save_dir = tempdir(),
  rfid_file = RFIDs,
  file_path = path
)
Process Preliminary and Finalized 'GreenFeed' Data
Description
Processes and calculates daily and weekly averages of 'GreenFeed' data. Handles data filtering, aggregation, and summarization to facilitate further analysis.
Arguments
| data | a data frame with preliminary or finalized 'GreenFeed' data | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| param1 | an integer representing the number of records per day to be consider for analysis | 
| param2 | an integer representing the number of days with records per week to be consider for analysis | 
| min_time | an integer representing the minimum number of minutes for a records to be consider for analysis (default: 2 minutes) | 
| transform | A logical representing whether to transform gas production to L/d. If TRUE, gas will be converted from grams/day to liters/day. | 
| cutoff | an integer specifying the range for identifying outliers (default: 3 SD) | 
Value
A list of three data frames:
| filtered_data | data frame with filtered 'GreenFeed' data | 
| daily_data | data frame with daily processed 'GreenFeed' data | 
| weekly_data | data frame with weekly processed 'GreenFeed' data | 
Examples
file <- system.file("extdata", "StudyName_GFdata.csv", package = "greenfeedr")
datafile <- readr::read_csv(file)
gf_data <- process_gfdata(
  data = datafile,
  start_date = "2024-05-13",
  end_date = "2024-05-25",
  param1 = 2,
  param2 = 3,
  min_time = 2
)
head(gf_data)
Process RFID Data
Description
Processes RFID data from animals in the study.
Usage
process_rfid_data(rfid_file)
Arguments
| rfid_file | Path or data frame containing RFID data. | 
Value
A data frame with standardized column names ('FarmName' and 'RFID'). If the input is invalid or if no valid data is provided, the function returns 'NULL'.
Examples
# Example with a data frame
df <- data.frame(
  V1 = c("Farm1", "Farm2", "Farm3"),
  V2 = c("12345", "67890", "54321")
)
processed_df <- process_rfid_data(df)
message(processed_df)
# Example with invalid input
invalid_data <- process_rfid_data(NULL)
# Expected output: message "RFID is NA. It is recommended to include it." and NULL
message(invalid_data)
Download and Report 'GreenFeed' Data
Description
Generates a PDF report of preliminary and finalized 'GreenFeed' data. The report includes: number of animals using 'GreenFeed' and plots with distribution of records and gas production. If the preliminary option is used, the data is retrieved from the 'C-Lock Inc.' server through an 'API', otherwise the data processed by 'C-Lock Inc.' must be provided to generate the report.
Arguments
| input_type | a character string representing type of data (options: "preliminary" and "finalized") | 
| exp | a character string representing study name or other study identifier. It is used as file name to save the data | 
| unit | numeric or character vector, or a list representing one or more 'GreenFeed' unit numbers | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| save_dir | a character string representing the directory to save the output file | 
| plot_opt | a character string representing the gas(es) to plot (options: "All", "CH4", "CO2", "O2", "H2") | 
| rfid_file | a character string representing the file with individual IDs. The order should be Visual ID (col1) and RFID (col2) | 
| user | a character string representing the user name to logging into 'GreenFeed' system. If input_type is "final", this parameter is ignored | 
| pass | a character string representing password to logging into 'GreenFeed' system. If input_type is "final", this parameter is ignored | 
| file_path | A list of file paths containing the final report(s) from the 'GreenFeed' system. If input_type is "prelim", this parameter is ignored | 
Value
A CSV file with preliminary 'GreenFeed' data and a PDF report with a description of the preliminary or finalized data
Examples
# Please replace "your_username" and "your_password" with your actual 'GreenFeed' credentials.
# The data range must be fewer than 180 days
# Example without rfid_file (by default NA)
report_gfdata(
  user = "your_username",
  pass = "your_password",
  input_type = "preliminary",
  exp = "StudyName",
  unit = 1,
  start_date = "2023-01-01",
  end_date = Sys.Date(),
  save_dir = tempdir(),
  plot_opt = "All"
)
Launch the Greenfeedr Shiny App locally
Description
This function launches the Greenfeedr Shiny app on your computer.
Usage
run_app()
Run the 'greenfeedr' Shiny App locally
Description
Launches the 'greenfeedr' Shiny application on your computer. The app provides an interactive interface for 'GreenFeed' data analysis, visualization, and reporting.
Usage
run_gfapp()
Value
This function launches the Shiny app in your default web browser; it does not return a value.
Examples
## Not run: 
  greenfeedr::run_gfapp()
## End(Not run)
Transform gas production
Description
Transform gas production from g/d to L/d
Usage
transform_gases(data)
Arguments
| data | a data frame with preliminary or finalized 'GreenFeed' data | 
Value
A data frame with the gases transform in L/d
Examples
file <- readr::read_csv(system.file("extdata", "StudyName_GFdata.csv", package = "greenfeedr"))
data <- transform_gases(data = file)
Process 'GreenFeed' Visits
Description
Processes 'GreenFeed' visits and food drops for a requested period. Generates a list of animals not visiting the 'GreenFeed' to manage them, and a description of animals visiting the 'GreenFeed'.
Arguments
| user | a character string representing the user name to logging into 'GreenFeed' system | 
| pass | a character string representing password to logging into 'GreenFeed' system | 
| unit | numeric or character vector or list representing one or more GreenFeed unit numbers. | 
| start_date | a character string representing the start date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| end_date | a character string representing the end date of the study (format: "DD-MM-YY" or "YYYY-MM-DD") | 
| rfid_file | a character string representing the file with individual RFIDs. The order should be Visual ID (col1) and RFID (col2) | 
| file_path | a character string or list representing files(s) with feedtimes from 'C-Lock Inc.' | 
Value
A list of two data frames:
| visits_per_day | Data frame with daily processed 'GreenFeed' data, including columns for VisualID, Date, Time, number of drops, and visits. | 
| visits_per_animal | Data frame with weekly processed 'GreenFeed' data, including columns for VisualID, total drops, total visits, mean drops, and mean visits. | 
Examples
# You should provide the feedtimes files.
# it could be a list of files if you have data from multiple units to combine
path <- system.file("extdata", "feedtimes.csv", package = "greenfeedr")
# If the user include an rfid file, the structure should be in col1 AnimalName or VisualID, and
# col2 the RFID or TAG_ID. The file could be save in different formats (.xlsx, .csv, or .txt).
RFIDs <- system.file("extdata", "RFID_file.csv", package = "greenfeedr")
data <- viseat(
  file_path = path,
  unit = 1,
  start_date = "2024-05-13",
  end_date = "2024-05-25",
  rfid_file = RFIDs
)