首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >西门子CT剂量报告/患者协议PixelData

西门子CT剂量报告/患者协议PixelData
EN

Stack Overflow用户
提问于 2017-09-24 02:46:49
回答 1查看 216关注 0票数 0

我试图从西门子的剂量报告中提取dicom PixelData,但它只包含零。使用GE剂量报告,我读取数据时使用pydicom或simpleITK没有任何问题。你知道为什么西门子的报告只包含零吗?

谢谢!

已经走到这一步了,但是角色是一团糟,我不知道还能做什么。

代码语言:javascript
复制
import dicom 
import numpy as np
import matplotlib.pyplot as plt

f="patient-protocol.dcm"
ds=dicom.read(f)  
overlay_px_data = ds[0x6000, 0x3000].value  
rows = ds[0x6000, 0x0010].value  
cols=ds[0x6000, 0x0011].value

arr=np.fromstring(overlay_px_data, dtype="uint8")  
arr=np.unpackbits(arr)  
arr=np.reshape(arr, (rows, cols))

plt.imshow(arr, cmap="gray")  
plt.show() 

dose-image

EN

回答 1

Stack Overflow用户

发布于 2017-09-25 15:38:30

代码语言:javascript
复制
i_overlay = 1
n_bits = 8


# On (60xx,3000) are stored ovelays.
# First is (6000,3000), second (6002,3000), third (6004,3000),
# and so on.
dicom_tag1 = 0x6000 + 0*i_overlay

overlay_raw = data[0x6000,0x3000].value

# On (60xx,0010) and (60xx,0011) is stored overlay size
rows = data[0x6000,0x0010].value # rows = 512
cols = data[0x6000,0x0011].value # cols = 512

decoded_linear = np.zeros(len(overlay_raw)*n_bits)

# Decoding data. Each bit is stored as array element
for i in range(1,len(overlay_raw)):
    for k in range (0,n_bits):
        byte_as_int = overlay_raw[i]
        decoded_linear[i*n_bits + k] = (byte_as_int >> k) & 0b1


overlay = np.reshape(decoded_linear,[rows,cols])

plt.imshow(overlay)
plt.show()

找到了目前的解决方案。编辑了一点代码(删除ord()),一个numpy解码解决方案会更好/更好。

code source link

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46383118

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档