Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TADA_CalculateTotalNP should use TADA.MonitoringLocationIdentifier if it exists in data frame #475

Open
6 tasks
cristinamullin opened this issue Jun 4, 2024 · 2 comments

Comments

@cristinamullin
Copy link
Collaborator

cristinamullin commented Jun 4, 2024

Is your feature request related to a problem? Please describe.

Currently, the TADA_FindNearbySites identifies sites within some buffer distance of each other and assigns them a TADA.MonitoringLocationIdentifier which concatenates the two original MonitoringLocationIdentifier's, but it does not automatically harmonize them to one site's metadata (name, latitude, longitude, organization, and many more... ??). This is difficult when subsequent functions (like total NP summation) depend upon monitoring location identifier as a grouping variable to define total N or total P summations.

Which site metadata (name, latitude, longitude and...??) should TADA_CalculateTotalNP assign these totals to if they should come from multiple nearby sites?

Describe the solution you'd like

The TADA_CalculateTotalNP in Transformations.R already mentions the TADA_FindNearbySites function (lines 233 and 319) but it is not directly used within the function yet.

To start/for now, TADA_CalculateTotalNP can be updated as follows:

  • When creating new rows with the TN and TP results, TADA_CalculateTotalNP could use the TADA.MonitoringLocationIdentifier if it exists in the data frame as a grouping variable by default, and use MonitoringLocationIdentifier instead if TADA.MonitoringLocationIdentifier does not exist (meaning TADA_FindNearbySites was not run first & is not applicable).
  • Metadata does not need to be carried through to the new row and users can go back to original rows to see metadata from the two different sites/organizations.

Describe alternatives you've considered

This option is more complicated and if needed, could be created as a separate issue to address later after further discussions with the TADA Working Group about requirements.

  • Additional site metadata (name, latitude, longitude, organization(s), and...??) could be carried through to the new row.

Option A: The function could have an organization hierarchy like the duplicate functions and could preferentially pick the best-ranked organization to provide the key metadata (both for organization and site metadata elements) needed to merge sites to one. Result information should remain distinct.

Option B: The function could concatenate site and organization metadata to carry both through to the new row.

Reminders for TADA contributors addressing this issue

New features should include all of the following work:

  • Update the function/code.

  • Document all code using comments to describe what is does.

  • Create tests in tests folder.

  • Create help file using roxygen2 above code.

  • Create working examples in help file (via roxygen2).

  • Add to or update appropriate vignette (or create new one).

@cristinamullin cristinamullin changed the title TADA_CalculateTotalNP should use TADA_MonitoringLocationID if it exists in data frame TADA_CalculateTotalNP should use TADA_MonitoringLocationIdentifier if it exists in data frame Jun 11, 2024
@cristinamullin cristinamullin changed the title TADA_CalculateTotalNP should use TADA_MonitoringLocationIdentifier if it exists in data frame TADA_CalculateTotalNP should use TADA.MonitoringLocationIdentifier if it exists in data frame Jun 11, 2024
@cristinamullin
Copy link
Collaborator Author

@hillarymarler this is related to the discussion we had about creating TADA.MonitoringLocationIdentifier as part of autoclean at the start. Once that is implemented, then all TADA functions including this one can reference that instead of the original MonitoringLocationIdentifier.

@hillarymarler
Copy link
Collaborator

I will work on this as part of the pull request that also creates TADA.MonitoringLocationIdentifier

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants