- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 this回答说:
in DICOM you have to provide all unique keys (Patient ID, Study Instance UID, Series Instance UID and SOP Instance UID) down to the level that you are querying
我正在寻找 DICOM 标准的引用资料?
特别是,我需要“证明”系列级别查询需要 StudyInstanceUID。
最佳答案
查看您对 other 的评论@kritzel_sw 的回答,我试图进一步解释这一点并添加更多“证据”。
特定级别的标识符列表:
- 患者级别:患者 ID
- 学习级别:学习实例UID
- 系列级别:系列实例 UID
- 图像级别:SOP 实例 UID
以下内容复制自here :查询级别 - 患者根:
以下内容复制自here (C.3.2 研究根查询/检索信息模型):
The Study Root Query/Retrieve Information Model is identical to the Patient Root Query/Retrieve Information Model except the top level is the study level. Attributes of patients are considered to be Attributes of studies.
任何模型都支持两种类型的查询 - 分层查询和关系查询。其他答案和这个答案中引用的内容是关于默认实现的分层查询。关系查询支持是扩展协商的一部分,是可选的。
以下内容复制自here (C.5关联协商)
SOP Classes of the Query/Retrieve Service Class, which include query services based on the C-FIND operation, may use SOP Class Extended Negotiation Sub-Item to negotiate options such as Relational-queries and Enhanced Multi-Frame Image Conversion.
和here (C.4.1.2.2 SCU 的扩展行为)
Extended SCU behavior shall be negotiated at Association establishment time. If an option within the extended behavior is not agreed upon in the negotiation, then only baseline SCU behavior shall be performed with respect to that option. Extended SCU behavior includes all baseline behavior with the following option:
- Relational-queries
- Enhanced Multi-Frame Image Conversion
在患者根层次模型中,应首先在患者级别查询以获取研究列表(响应中包含研究实例 UID)。然后,进一步在 STUDY 级别查询以获取系列列表(响应中包含系列实例 UID)等等......
在Study Root模型中,STUDY是最高级别。因此,PATIENT级别的查询不适用。
以下引用来自规范 - DICOM第 4 部分(服务类规范),C.4.1.2.1 章 SCU 的基线行为:
The Identifier contained in a C-FIND request shall contain a single value in the Unique Key Attribute for each level above the Query/Retrieve level. No Required or Optional Keys shall be specified that are associated with levels above the Query/Retrieve level.
这意味着,在查询下一级时,SCU必须指定其前一级的标识符。在患者根研究级别查询中,您必须指定患者 ID。在 Study Root STUDY Level 查询中,没有above级别。因此,SCU 可以在不指定患者 ID 的情况下进行过滤。
The Unique Key Attribute associated with the Query/Retrieve level shall be contained in the C-FIND request and may specify Single Value Matching, Universal Value Matching, or List of UID Matching.
在上述查询的响应中,SCU 已收到该级别的标识符。这些应该包含在查询中。在 SERIES 级别查询时,指定在早期响应中收到的研究实例 UID。
In addition, Required and Optional Keys associated with the Query/Retrieve level may be contained in the Identifier.
查询中还可能包含其他参数。
关于可选参数:
The SCU may not assume the SCP supports any Optional Keys. Hence, Optional Keys serve only to reduce network related overhead when they are supported by the SCP.
The SCU must be prepared to filter C-FIND responses when the SCP fails to support an Optional Key specified in the C-FIND request.
SCP 必须支持在相应级别上对标识符进行过滤 - 这是强制性的。 SCP 还可以另外支持对其他可选参数的过滤;但 SCU 不应该依赖它。
现在,回答您的评论:
Does that mean that I cannot even issue a STUDY level query without patient ID ? what if I only have a study ID / accession number
在这种情况下,使用 Patient Root 查询时,与严格执行规范的 SCP 的通信将会失败。有了Study Root,STUDY就是顶级。如果 SCP 支持,您的过滤器应该可以工作。
实际上,大多数 SCP 都是自由派。登记号和患者 ID 是研究级别广泛使用的过滤器。
关于dicom - C-Find 查询 - 系列级查询是否需要 StudyInstanceUID?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55486283/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!