a
: 1.2 mm diameter, 50 mg/cc densityb
: 3.0 mm diameter, 50 mg/cc densityc-4x
: 5.0 mm diameter, 50 mg/cc densityd
: 1.2 mm diameter, 100 mg/cc densitye
: 3.0 mm diameter, 100 mg/cc densityf
: 5.0 mm diameter, 100 mg/cc densityh
: 1.2 mm diameter, 250 mg/cc densityi
: 3.0 mm diameter, 250 mg/cc densityk
: 5.0 mm diameter, 250 mg/cc densityl
: 1.2 mm diameter, 400 mg/cc densitym
: 3.0 mm diameter, 400 mg/cc densityn
: 5.0 mm diameter, 400 mg/cc density
Notice how the phantom is set up in a way for easy automatic segmentation. Specifically the phantom contains mostly background inserts and only one row of inserts for measurements, with the outer inserts of the highest density large inserts (n
) that are not meant for measurement but specifically just for detection of automatic segmentation. Then it contains another set of background inserts, then three measurement inserts with varying amounts of calcium (a
- n
)
NOTE: In order to avoid the effect of air as much as possible, the inserts were surrounded by silly putty that is specifically around the hounsfield unit (HU)/intensity of the CIRS background tissue (~ 50 HU). This is likely imperfect and will have some effect on the results, but it is much better that having air (~ -1000 HU)
The root folders (e.g. a, b, c-4x, d, e, ...) containing the data are all named according to the inserts they contain (see above). Within these folders there are many more subfolders, which I have not yet thoroughly investigated, but correspond to different scan parameters. For example, dual energy scans are indicated via "Spectral ..." and the corresponding monoenergetic reconstruction is indicated via "50 Mono", "60 Mono", etc. Slice thickness reconstructions are indicated via "0.5", "1.0", etc. Somewhere within the folder, cardiac phase reconstruction is indicated via the percentage. We also performed different types of reconstruction algorithms, e.g. filtered back projection, iterative, etc., but these are not indicated within the folders themselves, so this needs to be determined via the DICOM header or some other manner. Potentially, all of this information can be determined via the DICOM header.
The phantom is a dynamic phantom so the scans are all either 0, 60, or 90 beats per minute (bpm) [I THINK]. This is hopefully determined via the header too but I am not positive right now
See https://github.com/MolloiLab/dynamic/blob/main/ENG14920100%20Targets%20(1).pdf
This code base is using the Julia Language and DrWatson to make a reproducible scientific project named
dynamic
To (locally) reproduce this project, do the following:
- Download this code base. Notice that raw data are typically not included in the git-history and may need to be downloaded independently.
- Open a Julia console and do:
julia> using Pkg julia> Pkg.add("DrWatson") # install globally, for using `quickactivate` julia> Pkg.activate("path/to/this/project") julia> Pkg.instantiate()
This will install all necessary packages for you to be able to run the scripts and everything should work out of the box, including correctly finding local paths.
You may notice that most scripts start with the commands:
using DrWatson
@quickactivate "dynamic"
which auto-activate the project and enable local path handling from DrWatson.