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.6.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.MM.MINOR, where YYYY is the year MM is the month with no-zero padding and MINOR is the version bump within that month (starting at '0'). For instance 2025.2.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.10.0.tar.gz.

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.10.0.tar.gz
Algorithm Hash digest
SHA256 2c91686b5d9d0541abee441cad2b2787760c11c8093335c3e98c7e6ad2e7e0d5
MD5 9c4e6fd43c5df3393b1d74424608190b
BLAKE2b-256 084e9b969291d643817dd1bdc0eadcc4c3f0edda950a847a36f73465ae1bb688

See more details on using hashes here.

Provenance

The following attestation bundles were made for grand_challenge_dicom_de_id_procedure-2025.10.0.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.10.0-py3-none-any.whl.

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e55ac6accd7e0e68ef16b63d6a6cb433f06170070778250b3769f6eaa33b8682
MD5 05ab5ab6a6752fc0de83b4402565672c
BLAKE2b-256 2102d04c6b0cbfc5436a19aa4ca7b7ae7f156bf64f6bf8d0f40430a2075ed62e

See more details on using hashes here.

Provenance

The following attestation bundles were made for grand_challenge_dicom_de_id_procedure-2025.10.0-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