106人参与 • 2024-08-03 • vr
dicom 文件的结构,在网上有很多的学习资料,这里只介绍些容易混淆的概念,作为回看笔记。
dicom implicit vr little endian: 1.2.840.10008.1.2
dicom explicit vr little endian: 1.2.840.10008.1.2.1
dicom explicit vr big endian: 1.2.840.10008.1.2.2
jpeg_lossless_transfer_syntax: “1.2.840.10008.1.2.4.70”;
在dcmtk中,dcmdata工程内dcxfer.cc文件都有明确的标识,例如jpeg_lossless_transfer_syntax: “1.2.840.10008.1.2.4.70”; 表示
{ uid_jpegprocess14sv1transfersyntax, // "1.2.840.10008.1.2.4.70"
"jpeg lossless, non-hierarchical, 1st order prediction",
exs_jpegprocess14sv1,
ebo_littleendian,
evt_explicit,
eje_encapsulated,
14l ,14l,
offalse,
offalse,
esc_none },
上边就表示了jpeg_lossless_transfer_syntax这个传输语法,是小端和显式的。
组号 | 元素号 | vr+预留 | 值长度 | 数据元素值 |
---|---|---|---|---|
2字节 | 2字节 | 2字节+2字节(0x00,0x00) | 4字节 | 由数据长度决定 |
组号 | 元素号 | vr+预留 | 值长度 | 数据元素值 |
---|---|---|---|---|
2字节 | 2字节 | 2字节 | 2字节 | 由数据长度决定 |
组号 | 元素号 | 值长度 | 数据元素值 |
---|---|---|---|
2字节 | 2字节 | 4字节 | 由数据长度决定 |
当sequence的数据元素值被编码为32位无符号整数值的时候,这个长度应该包括由该数据元素传递的零个或多个item产生的总长度。如果项目序列包含零个项目,则此数据元素长度应为00000000h。
以下是一个例子:
因为这个文件是显式小端(边)编码方式,标注1表示组号和元素号,标注2中显示,前两个字节是sq,接下来2个字节是预留00 00,标注3中,长度是0x18,也就是24个字节长度,这就表示接下来的24个字节都是此sequence元素。
接下来我们再详细看下sequence内部item的定义的结构;内部的item以fffe,e000开始,然后是4个字节的长度,然后是一个标准的dataset集合。
上图中,标注1就是sequence中的item的开始。
以下是一个西门子ct产生的dicom文件片段,我个人感觉这个文件是错误的。
大家可以看到标注1的位置,表示这个sequence是没有设定长度的,所以,它的结尾是以fffe,e0dd结束,后边再跟上0000 0000.也就是标注4所指的位置。这里,注意一下,第一个item的长度是四个字节,使用55 00 00 00来表示,换算为十进制就是85个字节,实际上接下来有122个字节,这里我感觉应该是7a 00 00 00。接下来的item都是正常,这里注意,内部也同样包含了一个sq,内部的sq的长度也是用ff ff ff ff表示的,这里的第一个item的长度文件内记为10 00 00 00,也就是16个字节,通过观察,确实是16个字节的长度,这样也可以进一步证明,标识2的位置55 00 00 00是错误的。或者,我理解错了,大家一起探讨。
下面给的一个例子是隐式,小端的例子。可见grouptag(7fe0)和elementtag(0010),在实际二进制排列中是e07f 1000的二进制;0x00080000=524288个字节=2byte512512
可见grouptag(7fe0)和elementtag(0010),vr:ow 缺省两个字节 ,vl: 0x00 08 00 00=524288个字节=2byte512512
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论