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

Features #380

Open
wants to merge 123 commits into
base: main
Choose a base branch
from
Open

Features #380

wants to merge 123 commits into from

Conversation

kkappler
Copy link
Collaborator

@kkappler kkappler commented Mar 22, 2025

This PR is part of a larger change involving mt_metadata, mth5, and mtpy-v2.

The primary goal of the PR is to add the capability to extract features from MTH5 data, store the features in MTH5, and show an example workflow where the features can be applied to generate weights in data processing.

Also, significant reorganization of processing tools has been done, including the migration of processing support tools to mth5 from aurora.

  • The programatically-generated processing config will be validated against a stored json
    • This will become part of the testing flow and allow for a processing_configuration_template.json to be used as examples of how to specify features and weights calculations.

TODO

  • The processing parameters template can be modified so we add some weighting by coherence
    • augment processing_configuration_template.json with the weights structure from issue Data Weightings in EMTF #61
    • The above fails to load  mt_metadata.base.metadata | set_attr_from_name | weights.ex.combination_style is not in the current standards.  To properly add the attribute use add_base_attribute.
  • FCCoherence needs to be added to mt_metadata as a feature
    • It will be an xarray with dims time, and frequency.
    • The frequency axis will come from mth5.processing.spectre.frequency_band_helpers, using ( log_spaced_frequencies and bands_of_constant_q to build broad coherence bands.
    • The metadata for specifying this is in mt_metadata/features/standards/fc_coherence.json
    • The features can be packed into the mth5 beforehand, or they can be computed on the fly
    • In either case, we need to write the parameters that define the bands, and the feature name into the processing_config_template
  • Aurora will read in the updated processing config, and compute the weights .. to do this we will still need somewhere to put the thresholding info, a suggested format for a weights block is here
  • An integrated test will be developed in aurora to run an example workflow with feature weights (test_feature_weighting.py)'.
  • That test will use a processing config test_processing_config_with_weights_block.json, currently stored in aurora/config

- also, pytest was complaining about it locally, and it doesn't seem worth looking into
- these don't hurt and make the flow slightly more robust
- make prewhitening correction depend only on keyword, not all decimation params
- this requires reinstalling mt_metadata over mtpy
- I'm not sure whether or not to comment out the aurora install ..
... this may get quite complicated.  This push is a test to see how complicated
- rename extra_pre_fft_detrend_type to per_window_detrend_type
- add explicit assignment of per_window_detrend_type="linear" in config creator
kujaku11 and others added 30 commits March 21, 2025 16:09
- several methods are about to be moved from mth5/timeseries/spectre to mth5/processing/spectre
- tests passing locally before this commit
- will make changes with mth5 on `fix_issue_291` branch, and test locally again before merging PR on mth5 and then push aurora
- it is now in helper functions, and at least a bit easier to maintain
- also config.decimation_info is now a property, not a method
- also minor changes, typehinting and TODOs
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.

2 participants