How to split DICOM to individual slices?

12 visualizaciones (últimos 30 días)
Wasna Madushanka Ediri Arachchi
Wasna Madushanka Ediri Arachchi el 4 de En. de 2018
Respondida: Gautam el 7 de Mzo. de 2025
Here I have attached a stacked dicom file comprising 28 slices. How can I save individual dicom files for each slice?

Respuestas (1)

Gautam
Gautam el 7 de Mzo. de 2025
To save individual DICOM files for each slice from a stacked DICOM file in MATLAB, you can use the "dicomread" function to read the stacked DICOM file and then iterate through each slice to save it as a separate DICOM file using the "dicomwrite" function.
stackedFileName = 'path_to_stacked_dicom.dcm';
volumeData = dicomread(stackedFileName);
info = dicominfo(stackedFileName);
numSlices = size(volumeData, 3);
for sliceIdx = 1:numSlices
sliceData = volumeData(:, :, sliceIdx);
info.InstanceNumber = sliceIdx;
info.SliceLocation = sliceIdx; % Update slice location if necessary
% Construct a filename for the slice
sliceFileName = sprintf('slice_%02d.dcm', sliceIdx);
% Write the slice to a new DICOM file
dicomwrite(sliceData, sliceFileName, info);
end

Categorías

Más información sobre DICOM Format en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by