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

Add configuration for DESPIAD project #572

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

Conversation

p-j-smith
Copy link
Contributor

@p-j-smith p-j-smith commented Dec 12, 2024

Description

Closes #571
Closes #530

  • add project config for DESPIAD
  • add tag operation files for CT and PET
  • use base, CT, then PET tag operation files for anonymisation
  • ensure all resources sharing a StudyInstanceUID in Orthanc Raw are exported (they may exist as separate resources in Orthanc Raw if they have different StudyIDs, but are combined into a single resource in Orthanc Anon as the StudyID tag is deleted) This has already been fixed in Improve anon logging and anonymise all matching studies at once #582

Type of change

Please delete options accordingly to the description.

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • This change requires a documentation update

Suggested Checklist

  • I have performed a self-review of my own code.
  • I have made corresponding changes to the documentation.
  • My changes generate no new warnings.
  • I have commented my code, particularly in hard-to-understand areas.
  • I have passed on my local host device. (see further details at the CONTRIBUTING document)
  • Make sure your branch is up-to-date with main branch. See CONTRIBUTING for a general example to syncronise your branch with the main branch.
  • I have requested review to this PR.
  • I have addressed and marked as resolved all the review comments in my PR.
  • Finally, I have selected squash and merge

this is because resources sharing the same StudyInstanceUID in Orthanc Raw will be combined into a single resource in Orthanc Anon.
Previously, we would try to export each resource after anonymisation, but this meant other resources sharing the same StudyInstanceUID were not exported.
Copy link

codecov bot commented Dec 12, 2024

Codecov Report

Attention: Patch coverage is 76.71233% with 17 lines in your changes missing coverage. Please review.

Project coverage is 87.24%. Comparing base (4af6ed0) to head (a7c5917).

Files with missing lines Patch % Lines
pixl_dcmd/src/pixl_dcmd/main.py 55.88% 15 Missing ⚠️
..._core/src/core/project_config/pixl_config_model.py 92.00% 2 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main     #572      +/-   ##
==========================================
- Coverage   87.51%   87.24%   -0.28%     
==========================================
  Files          76       76              
  Lines        3437     3489      +52     
==========================================
+ Hits         3008     3044      +36     
- Misses        429      445      +16     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@p-j-smith p-j-smith marked this pull request as ready for review January 15, 2025 10:34
Copy link
Contributor Author

@p-j-smith p-j-smith left a comment

Choose a reason for hiding this comment

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

do we know the allowed_manufactures we should add for each project?

@@ -194,7 +194,9 @@ def ids_for_parameterised_test(val: pathlib.Path) -> str:


@pytest.mark.parametrize(
("yaml_file"), PROJECT_CONFIGS_DIR.glob("*.yaml"), ids=ids_for_parameterised_test
("yaml_file"),
PROJECT_CONFIGS_DIR.glob("test-*.yaml"),
Copy link
Contributor Author

Choose a reason for hiding this comment

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

no longer testing anonymisation using the non-test project configs. If we want to test all project configs, we need to add:

allowed_manufacturers:
  - regex: "^company"
    exclude_series_numbers: []

to all configs, unless there's a nicer way to do it?

Copy link
Contributor

@stefpiatek stefpiatek Jan 21, 2025

Choose a reason for hiding this comment

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

I think for the existing projects we can just allow all manufacturers, as that's what was implicitly done. We do have a test that ensures all configs are valid though right?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

ah yeah that's fair, and for DESPIAD shall we limit to known manufacturers? And yeah we have a separate test to check configs are valid

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I've allowed all manufacturers for the existing configs, and added them back to the test_anonymise_and_validate_dicom tests

Copy link
Contributor

@stefpiatek stefpiatek left a comment

Choose a reason for hiding this comment

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

Looking good, but I think we need to be careful about despiad series to filter out. At least checking an example from each manufacturer for each modality to ensure that we're not exporting burned in PID

Comment on lines +29 to +31
allowed_manufacturers:
- regex: ".*"
exclude_series_numbers: []
Copy link
Contributor

Choose a reason for hiding this comment

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

I think we should go through and find out all of the manufacturers before we allow the all through, as CT can have burned in data

- regex: ".*"
exclude_series_numbers: []

min_instances_per_series: 1
Copy link
Contributor

Choose a reason for hiding this comment

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

Are we expecting any single instances? If not I'd suggest 2 so that screenshots aren't uploaded

- regex: ".*" # allow all manufacturers
exclude_series_numbers: []

min_instances_per_series: 1
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
min_instances_per_series: 1
min_instances_per_series: 2

Comment on lines +25 to +27
allowed_manufacturers:
- regex: ".*" # allow all manufacturers
exclude_series_numbers: []
Copy link
Contributor

Choose a reason for hiding this comment

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

I think our template shouldn't allow all through, because that opens us up to exporting series which are burned in. But adding in canon's 8000 series to exclude is a good idea

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.

Add config for DESPIAD PIXL pipeline for CT data
3 participants