From 14e3dc387b7aab3d3f7e7c515402faa0524d9736 Mon Sep 17 00:00:00 2001 From: Kris Thielemans Date: Tue, 2 Jul 2024 20:38:44 +0000 Subject: [PATCH 1/3] git ignore output/ and other files --- .gitignore | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index 65210eb..8875dc4 100644 --- a/.gitignore +++ b/.gitignore @@ -1,10 +1,14 @@ data/ +output/ tmp*/ -errr.txt +err*.txt info.txt -warn.txt +warn*.txt __pycache__/ *.s *.hs *~ *.bak +*.ahv +*.hv +*.v \ No newline at end of file From 68756d408bf7e5853cf903950a48b8bd784d0e86 Mon Sep 17 00:00:00 2001 From: Kris Thielemans Date: Tue, 2 Jul 2024 20:49:33 +0000 Subject: [PATCH 2/3] import petric no longer reads data Set data_dirs_metrics, as opposed to calling get_data() for all datasets. Fixes #31 --- petric.py | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/petric.py b/petric.py index 135db80..0f6c397 100755 --- a/petric.py +++ b/petric.py @@ -152,8 +152,8 @@ def get_data(srcdir=".", outdir=OUTDIR, sirf_verbosity=0): STIR.set_verbosity(sirf_verbosity) # set to higher value to diagnose problems STIR.AcquisitionData.set_storage_scheme('memory') # needed for get_subsets() - _ = STIR.MessageRedirector(str(outdir / 'BSREM_info.txt'), str(outdir / 'BSREM_warnings.txt'), - str(outdir / 'BSREM_errors.txt')) + _ = STIR.MessageRedirector(str(outdir / 'info.txt'), str(outdir / 'warnings.txt'), + str(outdir / 'errors.txt')) acquired_data = STIR.AcquisitionData(str(srcdir / 'prompts.hs')) additive_term = STIR.AcquisitionData(str(srcdir / 'additive_term.hs')) mult_factors = STIR.AcquisitionData(str(srcdir / 'mult_factors.hs')) @@ -169,18 +169,16 @@ def get_data(srcdir=".", outdir=OUTDIR, sirf_verbosity=0): if SRCDIR.is_dir(): - data_metrics_pairs = [ - (get_data(srcdir=SRCDIR / "Siemens_mMR_NEMA_IQ", outdir=OUTDIR / "mMR_NEMA"), + data_dirs_metrics = [ + (SRCDIR / "Siemens_mMR_NEMA_IQ", OUTDIR / "mMR_NEMA", [MetricsWithTimeout(outdir=OUTDIR / "mMR_NEMA", transverse_slice=72, coronal_slice=109)]), - (get_data(srcdir=SRCDIR / "NeuroLF_Hoffman_Dataset", outdir=OUTDIR / "NeuroLF_Hoffman"), + (SRCDIR / "NeuroLF_Hoffman_Dataset", OUTDIR / "NeuroLF_Hoffman", [MetricsWithTimeout(outdir=OUTDIR / "NeuroLF_Hoffman", transverse_slice=72)]), - (get_data(srcdir=SRCDIR / "Siemens_Vision600_thorax", - outdir=OUTDIR / "Vision600_thorax"), [MetricsWithTimeout(outdir=OUTDIR / "Vision600_thorax")])] + (SRCDIR / "Siemens_Vision600_thorax", OUTDIR / "Vision600_thorax", + [MetricsWithTimeout(outdir=OUTDIR / "Vision600_thorax")])] else: log.warning("Source directory does not exist: %s", SRCDIR) - data_metrics_pairs = [(None, [])] -# first dataset -data, metrics = data_metrics_pairs[0] + data_dirs_metric = [(None, None, [])] if __name__ == "__main__": from docopt import docopt @@ -188,7 +186,8 @@ def get_data(srcdir=".", outdir=OUTDIR, sirf_verbosity=0): logging.basicConfig(level=getattr(logging, args["--log"].upper())) from main import Submission, submission_callbacks assert issubclass(Submission, Algorithm) - for data, metrics in data_metrics_pairs: + for srcdir, outdir, metrics in data_dirs_metric: + data = get_data(srcdir=srcdir, outdir=outdir) metrics[0].reset() # timeout from now algo = Submission(data) try: From ee948efaf7e03cb750b21e59bcbc18e1c2e2593f Mon Sep 17 00:00:00 2001 From: Kris Thielemans Date: Tue, 2 Jul 2024 23:14:45 +0100 Subject: [PATCH 3/3] typos, and re-instate setting first dataset Co-authored-by: Casper da Costa-Luis --- petric.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/petric.py b/petric.py index 0f6c397..28aa468 100755 --- a/petric.py +++ b/petric.py @@ -178,15 +178,19 @@ def get_data(srcdir=".", outdir=OUTDIR, sirf_verbosity=0): [MetricsWithTimeout(outdir=OUTDIR / "Vision600_thorax")])] else: log.warning("Source directory does not exist: %s", SRCDIR) - data_dirs_metric = [(None, None, [])] + data_dirs_metrics = [(None, None, [])] -if __name__ == "__main__": +if __name__ != "__main__": + srcdir, outdir, metrics = data_dirs_metrics[0] + data = get_data(srcdir=srcdir, outdir=outdir) + metrics[0].reset() +else: from docopt import docopt args = docopt(__doc__) logging.basicConfig(level=getattr(logging, args["--log"].upper())) from main import Submission, submission_callbacks assert issubclass(Submission, Algorithm) - for srcdir, outdir, metrics in data_dirs_metric: + for srcdir, outdir, metrics in data_dirs_metrics: data = get_data(srcdir=srcdir, outdir=outdir) metrics[0].reset() # timeout from now algo = Submission(data)