Skip to main content

De-identification procedure that descibes how to de-identify DICOM files

Project description

Grand-Challenge DICOM De-Identification Procedure

CI

This repository contains the code that generate the procedure for the Grand-Challenge.org de-identification methods. The procedure describes which action needs to be taken for a DICOM tag in order to be de-identified.

It is based on the DICOM Basic Profile of the Standard DICOM de-identification profile but customized for the use on the Grand-Challenge platform.

More information about de-identification choices can be found in the standard-operation procedure.

Procedure Usage

For JavaScript you can use the ESM + UDM bundles via the npmjs package:

The procedure.json has two lookups: firstly by SOPClassUID and secondly by the data element tag. This results in a "default" action that is to be executed for the data element in question. The action can be any of:

Code Action
"D" replace with a non-zero length value that may be a dummy value and consistent with the VR
"Z" replace with a zero length value, or a non-zero length value that may be a dummy value and consistent with the VR
"X" remove
"K" keep (unchanged for non-Sequence Attributes, cleaned for Sequences)
"C" clean, that is replace with values of similar meaning known not to contain identifying information and consistent with the VR
"U" replace with a non-zero length UID that is internally consistent within a set of Instances
"R" reject the entire DICOM file

For Python you can use the PyPi package: https://pypi.org/project/grand-challenge-dicom-de-id-procedure/

$ pip install grand-challenge-dicom-de-id-procedure

To load the procedure import it as follows:

from grand_challenge_dicom_de_id_procedure import procedure

# Check the version
print(procedure["version"])

# Get an action for tag (0008,0005) of SOPClassUID "1.2.840.10008.5.1.4.1.1.2" (CT image)
action = procedure["sopClass"]["1.2.840.10008.5.1.4.1.1.2"]["tag"]["(0008,0005)"]["default"]

print(action) # "K"

Procedure Building

First, install uv you should then be able to run the any of the following make commands:

$ make base

Which will create the base procedure, see Action logic below for details.

$ make candidate

Which will merge BASE + MANUAL procedures to generate a CANDIDATE procedure. The MANUAL procedure is a hand-crafted action list for each DICOM tag that is unset in the BASE procedure.

$ make worklist

Which will generate a reStructuredText that describes the tags for which no action has been set in the CANDIDATE procedure.

These will need to be addressed before we can generate the final procedure.

$ VERSION="2025.06.0" make final

Finally, above will run all the earlier make targets (i.e. base, candidate, worklist) and then use the CANDIDATE procedure to build the distributable FINAL procedure Including a VERSION, as specified.

Procedure Release

Calling make final with a VERSION also inserts the version in the relevant Python and NPM package configuration. The actual package(s) release is done via GitHub actions. The steps are:

  1. Ensure that main contains the latest version you would like to release
  2. Create and publish a release on GitHub, creating a new tag
    • Versioning dated-semver and follows format YYYY.0M.MINOR, where YYYY is the year 0M is the month with zero padding and MINOR is the version bump within that month (starting at '0'). For instance 2025.02.0.
  3. GitHub actions to publish the new package(s) automatically starts when a release is published
  4. Once everything is published, the dependency needs to be updated downstream (e.g. in Grand-Challenge)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file grand_challenge_dicom_de_id_procedure-2025.8.1.tar.gz.

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.8.1.tar.gz
Algorithm Hash digest
SHA256 97e6fcc1d815bb2adad5f1cfa78f0d88da0b55bb167c2d9bfcc917ae8bdc49de
MD5 4721e4c8c9aacaad4840013bbe03e436
BLAKE2b-256 772b2f9f5293395a6763b3b228c94a9822f282b6828451fb5c6762d958011f13

See more details on using hashes here.

Provenance

The following attestation bundles were made for grand_challenge_dicom_de_id_procedure-2025.8.1.tar.gz:

Publisher: release.yml on DIAGNijmegen/rse-grand-challenge-dicom-de-id-procedure

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file grand_challenge_dicom_de_id_procedure-2025.8.1-py3-none-any.whl.

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 638355c14d188401a744ac8ec5a79937005a97d5e7bfbe253e33a09d9282efea
MD5 611d72cd409179f892f41c617717b1df
BLAKE2b-256 2a0780ee0da2da8297dbd3e1c2b69e88b99ff6dc214dabdd32e0e75c56e2ae1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for grand_challenge_dicom_de_id_procedure-2025.8.1-py3-none-any.whl:

Publisher: release.yml on DIAGNijmegen/rse-grand-challenge-dicom-de-id-procedure

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page