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

Tutorial on burn scar analysis using embeddings from partial inputs #149

Merged
merged 11 commits into from
Feb 9, 2024

Conversation

yellowcap
Copy link
Member

@yellowcap yellowcap commented Feb 5, 2024

This PR adds a tutorial on Burn scar analysis using embeddings from partial inputs

This notebook contains a complete example for how to run Clay. It combines the following three different aspects

  1. Create single-chip datacubes with time series data for a location and a date range
  2. Run the model with partial inputs, in this case RGB + NIR
  3. Study burn scares through the embeddings generated for that datacube

Closes #126
Closes #136

@weiji14 weiji14 enabled auto-merge (squash) February 5, 2024 18:39
@weiji14 weiji14 disabled auto-merge February 5, 2024 18:40
Copy link
Contributor

@weiji14 weiji14 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @yellowcap, mostly just minor suggestions. I'd re-run the notebooks again with the nearest-neighbour resampling to make sure the results don't change much. Also would be good if @lillythomas can check the PCA part since she's been working on that more recently.

docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
Comment on lines +283 to +295
"class ClayDataModuleRGB(ClayDataModule):\n",
" MEAN = [\n",
" 1369.03, # red\n",
" 1597.68, # green\n",
" 1741.10, # blue\n",
" 2858.43, # nir\n",
" ]\n",
" STD = [\n",
" 2026.96, # red\n",
" 2011.88, # green\n",
" 2146.35, # blue\n",
" 2016.38, # nir\n",
" ]\n",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should we document the mean/std values for all the bands (not just RGB+NIR) somewhere for v0? At least until we resolve #94?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added docs for this in #152

docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
docs/_toc.yml Outdated Show resolved Hide resolved
docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
docs/partial-inputs.ipynb Outdated Show resolved Hide resolved
@yellowcap yellowcap requested a review from weiji14 February 7, 2024 12:12
@lillythomas
Copy link
Contributor

This looks great @yellowcap good to see how you plotted the dates directly from the stack. That works well for single component scenarios, which should be largely sufficient for many stories. More complex ones might require somehting like what I did where I added the non-normalized dates to the batches such that embeddings can be labeled with dates in the plots.

Signal of the burn scars is clear. This looks good to merge. I'll incorporate some takeaways from this into my PR.

@yellowcap yellowcap merged commit 3f4210f into main Feb 9, 2024
4 checks passed
@yellowcap yellowcap deleted the partial-input-burn-scar branch February 9, 2024 08:20
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Create script to make mini datacubes Test partial input to Clay v0
3 participants