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.2.tar.gz.

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.8.2.tar.gz
Algorithm Hash digest
SHA256 8b0e88a2fc9129f1ca462086e8736777e67e93726a40f49c21ac99af3fdfb820
MD5 66b6396f37cda2aa74f32078074d6162
BLAKE2b-256 a57b8b33a178a0def52825f7ed9118a98d285bba6cdd9ce59f88a1f53f9b67f7

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for grand_challenge_dicom_de_id_procedure-2025.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e2b9798eabe87e957f11885955b841440f90811ed08d18e3c7e5be761e6af355
MD5 3e831f35b0ef723fbd6593f3e28c3d81
BLAKE2b-256 923a055da722c4cceb6f61f2002e2e35a5e0ca6e9e1416be9ebd94e36fc27c9b

See more details on using hashes here.

Provenance

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