From fd4681ef333aaca81ed5c713ab03c9703d480440 Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 11:01:56 +0000 Subject: [PATCH 1/6] Prep for release, test 3.13 compatibility --- .github/workflows/push_pr.yml | 2 +- CHANGELOG.md | 6 ++++++ setup.py | 1 + 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/.github/workflows/push_pr.yml b/.github/workflows/push_pr.yml index f05b272..05bc3fb 100644 --- a/.github/workflows/push_pr.yml +++ b/.github/workflows/push_pr.yml @@ -12,7 +12,7 @@ jobs: strategy: matrix: os: ["ubuntu-latest"] - python-version: [ "3.9", "3.10", "3.11", "3.12"] + python-version: [ "3.9", "3.10", "3.11", "3.12", "3.13"] steps: - uses: actions/checkout@v4 with: diff --git a/CHANGELOG.md b/CHANGELOG.md index e8c49f4..1c66664 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ This document contains the Spec2nii release history in reverse chronological order. +0.8.5 (Thursday 31st October 2024) +---------------------------------- +- Add special case handling for DICOM dkd_svs_mslaser_msspnav sequence +- More GE HBCD sequence adjustments. +- Python 3.13 compatibility and testing, scipy dependency now >=1.13 + 0.8.4 (Monday 23rd September 2024) ------------------------------- - GE HBCD sequence adjustments. diff --git a/setup.py b/setup.py index 61871f0..b1e1972 100644 --- a/setup.py +++ b/setup.py @@ -31,6 +31,7 @@ "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: 3.12", + "Programming Language :: Python :: 3.13", "License :: OSI Approved :: BSD License", "Operating System :: OS Independent"], python_requires='>=3.9', From b7fbf1dbac3391a845d1a81ec115e28b7c3e0622 Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 13:13:00 +0000 Subject: [PATCH 2/6] Wheels for python 3.13 not availible for scipy 1.13, bump to >=1.14 --- CHANGELOG.md | 2 +- requirements.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1c66664..b02c574 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,7 +4,7 @@ This document contains the Spec2nii release history in reverse chronological ord ---------------------------------- - Add special case handling for DICOM dkd_svs_mslaser_msspnav sequence - More GE HBCD sequence adjustments. -- Python 3.13 compatibility and testing, scipy dependency now >=1.13 +- Python 3.13 compatibility and testing, scipy dependency now >=1.14 0.8.4 (Monday 23rd September 2024) ------------------------------- diff --git a/requirements.yml b/requirements.yml index 9fb0486..7a99eea 100644 --- a/requirements.yml +++ b/requirements.yml @@ -4,7 +4,7 @@ dependencies: - pydicom==3.*;python_version>="3.10" - pydicom==2.4.*;python_version<"3.10" - pyMapVBVD>=0.6.0 - - scipy>=1.13 + - scipy>=1.14 - brukerapi>=0.1.8 - pandas - nifti-mrs>=1.3.2 From dec149e94ff3eb533f5227d5d3f2df60bc08446d Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 13:29:24 +0000 Subject: [PATCH 3/6] Change test install strategy to avoid pypi conda conflicts. --- .github/workflows/push_pr.yml | 2 +- CHANGELOG.md | 2 +- requirements.yml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/push_pr.yml b/.github/workflows/push_pr.yml index 05bc3fb..719efd3 100644 --- a/.github/workflows/push_pr.yml +++ b/.github/workflows/push_pr.yml @@ -39,5 +39,5 @@ jobs: shell: bash -l {0} run: | conda install pytest h5py - pip install . + pip install --no-deps . pytest -k "not orientation" tests diff --git a/CHANGELOG.md b/CHANGELOG.md index b02c574..1c66664 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,7 +4,7 @@ This document contains the Spec2nii release history in reverse chronological ord ---------------------------------- - Add special case handling for DICOM dkd_svs_mslaser_msspnav sequence - More GE HBCD sequence adjustments. -- Python 3.13 compatibility and testing, scipy dependency now >=1.14 +- Python 3.13 compatibility and testing, scipy dependency now >=1.13 0.8.4 (Monday 23rd September 2024) ------------------------------- diff --git a/requirements.yml b/requirements.yml index 7a99eea..9fb0486 100644 --- a/requirements.yml +++ b/requirements.yml @@ -4,7 +4,7 @@ dependencies: - pydicom==3.*;python_version>="3.10" - pydicom==2.4.*;python_version<"3.10" - pyMapVBVD>=0.6.0 - - scipy>=1.14 + - scipy>=1.13 - brukerapi>=0.1.8 - pandas - nifti-mrs>=1.3.2 From a449f905bf85ef3b4df8ff5ad8b24c335ace7e38 Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 13:49:29 +0000 Subject: [PATCH 4/6] Fix mistake in pytest call for orientation marker. --- .github/workflows/push_pr.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/push_pr.yml b/.github/workflows/push_pr.yml index 719efd3..7491d5d 100644 --- a/.github/workflows/push_pr.yml +++ b/.github/workflows/push_pr.yml @@ -40,4 +40,4 @@ jobs: run: | conda install pytest h5py pip install --no-deps . - pytest -k "not orientation" tests + pytest -m "not orientation" tests From 8e97a3a7fc28080ec83c7d7d0a8f2fbd6f3081db Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 13:58:43 +0000 Subject: [PATCH 5/6] Try adding PIL as dependency. --- .github/workflows/push_pr.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/push_pr.yml b/.github/workflows/push_pr.yml index 7491d5d..0e85c55 100644 --- a/.github/workflows/push_pr.yml +++ b/.github/workflows/push_pr.yml @@ -38,6 +38,6 @@ jobs: - name: Run pytest shell: bash -l {0} run: | - conda install pytest h5py + conda install pytest h5py pillow pip install --no-deps . pytest -m "not orientation" tests From 81ac3ef5b2f202058bdf0f57717bc78789236aaa Mon Sep 17 00:00:00 2001 From: wtclarke Date: Thu, 31 Oct 2024 14:37:55 +0000 Subject: [PATCH 6/6] move from package_resources to importlib.resources for python 3.12+ compat --- spec2nii/bruker.py | 57 ++++++++++++++++++++++++---------------------- 1 file changed, 30 insertions(+), 27 deletions(-) diff --git a/spec2nii/bruker.py b/spec2nii/bruker.py index 9bf2d0e..a3367f7 100644 --- a/spec2nii/bruker.py +++ b/spec2nii/bruker.py @@ -7,7 +7,7 @@ Copyright (C) 2021 Institute of Scientific Instruments of the CAS, v. v. i. """ import os -import pkg_resources +import importlib.resources as importlib_resources import warnings from datetime import datetime @@ -64,40 +64,43 @@ def yield_bruker(args): 2/ Directory - function yields data and properties and data of all datasets compliant to the queries """ - # get location of the spec2nii Bruker properties configuration file - bruker_properties_path = pkg_resources.resource_filename('spec2nii', 'bruker_properties.json') - bruker_fid_override_path = pkg_resources.resource_filename('spec2nii', 'bruker_fid_override.json') - # get a list of queries to filter datasets queries = _get_queries(args) - # case of Bruker dataset - if os.path.isfile(args.file): - d = Dataset( - args.file, - property_files=[bruker_fid_override_path, bruker_properties_path], - parameter_files=['method']) - try: - d.query(queries) - except FilterEvalFalse: - raise ValueError(f'Bruker dataset {d.path} is not suitable for conversion to mrs_nifti') - yield from _proc_dataset(d, args) - - # case of folder containing Bruker datasets - elif os.path.isdir(args.file): - - # process individual datasets - for dataset in Folder(args.file, dataset_state={ - "parameter_files": ['method'], - "property_files": [bruker_properties_path] - }).get_dataset_list_rec(): - with dataset as d: + # get location of the spec2nii Bruker properties configuration file + ref1 = importlib_resources.files('spec2nii') / 'bruker_properties.json' + ref2 = importlib_resources.files('spec2nii') / 'bruker_fid_override.json' + + with importlib_resources.as_file(ref1) as bruker_properties_path: + with importlib_resources.as_file(ref2) as bruker_fid_override_path: + + # case of Bruker dataset + if os.path.isfile(args.file): + d = Dataset( + args.file, + property_files=[bruker_fid_override_path, bruker_properties_path], + parameter_files=['method']) try: d.query(queries) except FilterEvalFalse: - continue + raise ValueError(f'Bruker dataset {d.path} is not suitable for conversion to mrs_nifti') yield from _proc_dataset(d, args) + # case of folder containing Bruker datasets + elif os.path.isdir(args.file): + + # process individual datasets + for dataset in Folder(args.file, dataset_state={ + "parameter_files": ['method'], + "property_files": [bruker_properties_path] + }).get_dataset_list_rec(): + with dataset as d: + try: + d.query(queries) + except FilterEvalFalse: + continue + yield from _proc_dataset(d, args) + def _get_queries(args): """