fw-gear-dicom-splitter


Namefw-gear-dicom-splitter JSON
Version 2.0.3 PyPI version JSON
download
home_pageNone
SummaryDICOM splitter based on unique tags, or localizers
upload_time2024-11-22 14:56:14
maintainerNone
docs_urlNone
authorFlywheel
requires_python<4,>=3.11
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # DICOM Splitter

This gear is meant to split DICOM archives into two or more archives.  The main use
cases for this gear are if,

* There are one or more localizers (scouts, etc.) mixed in with primary images
* There are multiple Series in one archive.
* The archive is multiphasic with respect to slice location (geometry split)
* The archive has non uniform image orientations (geometry split)
* Some field varies across the archive and you have reason to the archive based on that
  field (Note: This "group by" option is exclusive if a previous geometry split is performed)

The gear is set to do the first two above by default, i.e. it will extract a
localizer(s) from the archive, and it will extract each unique SeriesInstanceUID into
its own archive.

## Usage

### Inputs

* __dicom__ : DICOM archive input

### Configuration

* __debug__ (boolean, default False): Include debug output.
* __delete_input__ (boolean, default True): Delete input if DICOM is successfully
split.
* __extract_localizer__ (boolean, default True): Whether or not to extract localizer
from archive.
* __group_by__ (string, default "SeriesInstanceUID"): Comma separated list of DICOM
tags to split the archive on.
* __max_geometric_splits__ (integer, default 4): Maximum number of splits to perform
by image orientation and/or position. If < 0, max will be ignored.
* __tag__ (string, default "splitter"): The tag to be added on input file upon run
completion.
* __tag-single-output__ (string, default ""): In addition to the tag applied to all
files above, apply a second tag to a single output so that a downstream gear rule can
run on the acquisition once splitter finishes. Default empty, no tag will be applied.
* __zip-single-dicom__ (string, default "match"): Zip single DICOM outputs.
Options are `"no"`, `"match"`.

### Outputs

The gear will output nothing if no splitting action was taken.  Otherwise it will output
a variable number of archives depending on the input and configuration named with the
following pattern:

`series-<SeriesNumber>_<Modality>_<SeriesDescription>_<GroupByTags>[_localizer]`, where

* `SeriesNumber` is the value of the `SeriesNumber` tag across the archive.  By default
  the largest sized archive (by number of slices) will retain the original
  `SeriesNumber` and additional archives will be incremented by `1000 + i`, where `i` is
  the index of the archive in a list of total archives.
* `SeriesDescription` is the value of the `SeriesDescription` tag across the archive
* `GroupByTags` is an underscore separated list of all tags appearing in the `group_by` list,
  and their corresponding value in that archive. Tags "SeriesInstanceUID" and "SeriesNumber"
  are not included even if they appear in the `group_by` list.
* `Modality` is the value of the `Modality` tag across the archive
* If the series is a localizer, `_localizer` will be appended.

## Version 2.0.0 Breaking Change

Note that versions of this gear prior to version 2.0.0 are named `splitter`. On the
release of version 2.0.0, the gear was renamed to `dicom-splitter` and all package
names, import statements, and other references were modified to reflect this rename.
Any software that depends on `dicom-splitter` should be updated with this breaking
change in mind.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "fw-gear-dicom-splitter",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4,>=3.11",
    "maintainer_email": null,
    "keywords": null,
    "author": "Flywheel",
    "author_email": "support@flywheel.io",
    "download_url": null,
    "platform": null,
    "description": "# DICOM Splitter\n\nThis gear is meant to split DICOM archives into two or more archives.  The main use\ncases for this gear are if,\n\n* There are one or more localizers (scouts, etc.) mixed in with primary images\n* There are multiple Series in one archive.\n* The archive is multiphasic with respect to slice location (geometry split)\n* The archive has non uniform image orientations (geometry split)\n* Some field varies across the archive and you have reason to the archive based on that\n  field (Note: This \"group by\" option is exclusive if a previous geometry split is performed)\n\nThe gear is set to do the first two above by default, i.e. it will extract a\nlocalizer(s) from the archive, and it will extract each unique SeriesInstanceUID into\nits own archive.\n\n## Usage\n\n### Inputs\n\n* __dicom__ : DICOM archive input\n\n### Configuration\n\n* __debug__ (boolean, default False): Include debug output.\n* __delete_input__ (boolean, default True): Delete input if DICOM is successfully\nsplit.\n* __extract_localizer__ (boolean, default True): Whether or not to extract localizer\nfrom archive.\n* __group_by__ (string, default \"SeriesInstanceUID\"): Comma separated list of DICOM\ntags to split the archive on.\n* __max_geometric_splits__ (integer, default 4): Maximum number of splits to perform\nby image orientation and/or position. If < 0, max will be ignored.\n* __tag__ (string, default \"splitter\"): The tag to be added on input file upon run\ncompletion.\n* __tag-single-output__ (string, default \"\"): In addition to the tag applied to all\nfiles above, apply a second tag to a single output so that a downstream gear rule can\nrun on the acquisition once splitter finishes. Default empty, no tag will be applied.\n* __zip-single-dicom__ (string, default \"match\"): Zip single DICOM outputs.\nOptions are `\"no\"`, `\"match\"`.\n\n### Outputs\n\nThe gear will output nothing if no splitting action was taken.  Otherwise it will output\na variable number of archives depending on the input and configuration named with the\nfollowing pattern:\n\n`series-<SeriesNumber>_<Modality>_<SeriesDescription>_<GroupByTags>[_localizer]`, where\n\n* `SeriesNumber` is the value of the `SeriesNumber` tag across the archive.  By default\n  the largest sized archive (by number of slices) will retain the original\n  `SeriesNumber` and additional archives will be incremented by `1000 + i`, where `i` is\n  the index of the archive in a list of total archives.\n* `SeriesDescription` is the value of the `SeriesDescription` tag across the archive\n* `GroupByTags` is an underscore separated list of all tags appearing in the `group_by` list,\n  and their corresponding value in that archive. Tags \"SeriesInstanceUID\" and \"SeriesNumber\"\n  are not included even if they appear in the `group_by` list.\n* `Modality` is the value of the `Modality` tag across the archive\n* If the series is a localizer, `_localizer` will be appended.\n\n## Version 2.0.0 Breaking Change\n\nNote that versions of this gear prior to version 2.0.0 are named `splitter`. On the\nrelease of version 2.0.0, the gear was renamed to `dicom-splitter` and all package\nnames, import statements, and other references were modified to reflect this rename.\nAny software that depends on `dicom-splitter` should be updated with this breaking\nchange in mind.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "DICOM splitter based on unique tags, or localizers",
    "version": "2.0.3",
    "project_urls": null,
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "dbea305c7eeeb69c2c90a0b30813d02d71528629cdcd7706b45c3604d042c443",
                "md5": "212cc421a799d0d791e9696a37d8bcfe",
                "sha256": "f5d72b5b874bbd0195d0fb7d63ccfe0d1ad5d6721f05968b5ee7f45a77f1c749"
            },
            "downloads": -1,
            "filename": "fw_gear_dicom_splitter-2.0.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "212cc421a799d0d791e9696a37d8bcfe",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4,>=3.11",
            "size": 23316,
            "upload_time": "2024-11-22T14:56:14",
            "upload_time_iso_8601": "2024-11-22T14:56:14.125180Z",
            "url": "https://files.pythonhosted.org/packages/db/ea/305c7eeeb69c2c90a0b30813d02d71528629cdcd7706b45c3604d042c443/fw_gear_dicom_splitter-2.0.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-22 14:56:14",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "fw-gear-dicom-splitter"
}
        
Elapsed time: 0.50090s