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 CheckDataMixin #568

Closed

Conversation

fzimmermann89
Copy link
Member

@fzimmermann89 fzimmermann89 commented Nov 29, 2024

This adds a new Mixin for Dataclasses that checks the types of the fields.
If the fields are Annotated with a (newly added) Annotation, specifying either its data type or shape, this will also be checked.

After some discussions following #495, this is now optional. None of the core reshaping or indexing functions will depend on these checks, but the will be performed afterwards. If this ever becomes an issue, removing the mixin from the dataclass will only remove the checks.
This is IMHO the best way to check that certain invariants are true after reshaping or indexing in a readable and maintable way.
An alternative I considered was using data class descriptors instead of Annotated and perform the check in the set of the descriptors. But this would make the checking code fundamental to the data classes, instead of just a checking addon that can be removed.

One can specify the expected shape of a field using the syntax of jaxtyping.

There is also a context manager to disable checks temporarily.
By default, when exiting the context, the suspended checks will be performed. So one can first create a wrongly shaped data class, reshape it, and on exit it is ensured that the fields follow the rules. This behavior can also be disabled to disable checks in a part of the code completely.

The string parsing etc happens on import time, not at creation time.
Parts of the shape checks are cached, so running the same invariants check multiple times without substantial changes to the shapes will be fast.

I also removed some __future__.annotation imports, as they stringify all type annotations. Instead, we should either fix the dependencies, use stringified annotations (these cannot be runtime checked) or wait for PEP 649/749

[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Nov 29, 2024
ghstack-source-id: f63c6910796c61db777cdf0246e1d5edaec4e352
ghstack-comment-id: 2506886010
Pull Request resolved: #568
Copy link
Contributor

github-actions bot commented Nov 29, 2024

📚 Documentation

📁 Download as zip
🔍 View online

[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Nov 29, 2024
ghstack-source-id: f5a1fcae72994dc5ded3fda918068364da7a2617
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Nov 29, 2024
ghstack-source-id: bf978f509e37434b2a6e5680aa5238a8f2fdc12f
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Dec 2, 2024
ghstack-source-id: d3ba8f70111d645e2e8e51108770c33ee6265861
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Dec 2, 2024
ghstack-source-id: 61cd0d71ca65c1df4665dfb1de46d4113f5620e4
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Dec 2, 2024
ghstack-source-id: 139c4abb3716fcedc462c2f593e1f073e6fb56d5
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Dec 2, 2024
ghstack-source-id: cfe2e7e770ef021524e16a1f1531ec451aab3c17
ghstack-comment-id: 2506886010
Pull Request resolved: #568
[ghstack-poisoned]
fzimmermann89 added a commit that referenced this pull request Dec 2, 2024
ghstack-source-id: 0a9bcb0d6d68dd93ef6016d994f7dca796777305
ghstack-comment-id: 2506886010
Pull Request resolved: #568
@fzimmermann89 fzimmermann89 mentioned this pull request Dec 16, 2024
[ghstack-poisoned]
[ghstack-poisoned]
@fzimmermann89 fzimmermann89 mentioned this pull request Dec 23, 2024
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
Copy link
Contributor

github-actions bot commented Feb 18, 2025

Coverage

Coverage Report
FileStmtsMissCoverMissing
src/mrpro
   _version.py6267%7–8
src/mrpro/algorithms/csm
   inati.py24196%44
   walsh.py16194%53
src/mrpro/algorithms/dcf
   dcf_voronoi.py55493%15, 55–56, 89
src/mrpro/algorithms/optimizers
   adam.py20195%101
   pdhg.py79396%177–178, 184
src/mrpro/algorithms/reconstruction
   DirectReconstruction.py281643%59–79, 93
   IterativeSENSEReconstruction.py13192%79
   Reconstruction.py502256%42, 54–56, 80–87, 108–117
   RegularizedIterativeSENSEReconstruction.py411759%97–101, 115–140
src/mrpro/data
   AcqInfo.py135497%39, 43, 47, 217
   CheckDataMixin.py3444088%90, 96, 98, 115, 123, 125, 127, 160–161, 184, 193, 210, 238, 254, 302, 307, 313–318, 348, 355, 446, 448, 480, 482, 484, 488, 504, 545, 550, 627, 649–653, 685, 726–729, 754
   CsmData.py28389%13, 82–84
   DcfData.py44882%16, 64, 76–81
   EncodingLimits.py73396%33, 123, 126
   IData.py60887%129, 142, 171–179
   IHeader.py961189%109, 112, 122, 125, 128, 131, 168–172
   KData.py2213186%113–114, 129, 136, 148–161, 170, 178, 187, 221, 243–245, 281–282, 337–348, 509, 511, 571, 586, 650, 659
   KHeader.py1412185%23, 108–114, 141, 189, 196–197, 200, 207, 224–231, 239–250
   KNoise.py311552%39–52, 56–61
   KTrajectory.py81594%207–211
   MoveDataMixin.py1401887%28, 126, 142, 156–158, 220, 336–338, 351, 430, 450–451, 453, 468–469, 471
   QData.py39782%42, 65–73
   Rotation.py7194394%101, 199, 336, 434, 478, 496, 583, 585, 594, 628, 630, 693, 770, 775, 778, 793, 810, 815, 891, 1079, 1084, 1087, 1111, 1115, 1243, 1245, 1253–1254, 1318, 1400, 1703, 1855, 1890, 1894, 2046, 2084, 2092, 2096, 2100–2104
   SpatialDimension.py2322191%34, 104, 141, 148, 154, 274–276, 289–291, 325, 343, 356, 369, 382, 395, 404–405, 420, 429
   acq_filters.py12192%47
src/mrpro/data/traj_calculators
   KTrajectoryCalculator.py27196%82
   KTrajectoryIsmrmrd.py27870%55–61, 66
src/mrpro/operators
   CartesianSamplingOp.py89397%118, 157, 280
   ConstraintsOp.py60297%46, 48
   EndomorphOperator.py32294%52, 58
   FiniteDifferenceOp.py27293%40, 105
   FourierOp.py73297%234, 239
   Functional.py77988%20–22, 117, 119, 226–228, 242
   GridSamplingOp.py136993%72–73, 82–83, 90–91, 94, 96, 98
   LinearOperator.py2001095%48, 107, 217, 244, 251, 292, 301, 309, 326, 361
   LinearOperatorMatrix.py1621988%82, 119, 152, 161, 166, 175–178, 191–194, 202–203, 208–209, 221, 310, 337, 364
   MultiIdentityOp.py13285%43, 48
   NonUniformFastFourierOp.py1771094%69, 96, 206, 208, 241, 243, 302, 356, 406, 411
   Operator.py79297%32, 88
   ProximableFunctionalSeparableSum.py39392%50, 103, 110
   SliceProjectionOp.py174895%45, 62, 64, 70, 206, 227, 260, 300
   WaveletOp.py119596%151, 169, 204, 209, 232
   ZeroPadOp.py16194%30
src/mrpro/utils
   filters.py62297%44, 49
   reshape.py91199%289
   slice_profiles.py47687%21, 37, 116–119, 152
   sliding_window.py34197%34
   split_idx.py10280%43, 47
   summarize_tensorvalues.py12925%22–31
   typing.py695520%9–235
   unit_conversion.py601477%32, 40, 42, 49, 51, 58, 60, 69, 80, 82, 101, 103, 124, 126
   zero_pad_or_crop.py31681%26, 30, 55, 58, 61, 64
TOTAL559350191% 

Tests Skipped Failures Errors Time
2452 0 💤 0 ❌ 0 🔥 1m 13s ⏱️

[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
@fzimmermann89 fzimmermann89 marked this pull request as ready for review February 27, 2025 23:19
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
[ghstack-poisoned]
This was referenced Feb 28, 2025
@PTB-MR PTB-MR deleted a comment from github-actions bot Mar 1, 2025
fzimmermann89 added a commit that referenced this pull request Mar 3, 2025
ghstack-source-id: 1d0833a1cc92c8d09ccac52869d6e415e80aaf5c
ghstack-comment-id: 2506886010
Pull Request resolved: #568
schote pushed a commit that referenced this pull request Mar 4, 2025
ghstack-source-id: 1d0833a1cc92c8d09ccac52869d6e415e80aaf5c
ghstack-comment-id: 2506886010
Pull Request resolved: #568
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.

1 participant