【转】03.Dicom 学习笔记-DICOM C-Get 消息服务

转自:https://www.jianshu.com/p/c7f5b9fa597c

引言

  前篇介绍了 DICOM C-Find 消息服务,本文结合开源 DICOM 库 fo-dicom 详细介绍一下 C-Get 服务。

 

C-Get 消息服务

  C-Get 服务主要用于获取影像,用于一个 DIMSE-service-user 在同等的DIMSE-service-user 上查询复合 SOP 实例的属性满足查询条件给出的一组属性的复合 SOP 实例,并取回这些符合条件的复合 SOP 实例,同时在这个过程中将触发一个或多个 C-STORE 子操作过程,所有的操作(包含 C-STORE 子操作)均在同一个 association 连接中。
  有关C-Get 服务流程图,我通过不同的 C-Get SCP 的实现,出现了两种流程图,参考如下:

  • 每个 C-Store 子操作完成后都会有一个 C-Get 响应

 

C-Get workflow 1

-C-Get 响应只会在 C-Store 子操作全部完成后发送

 

C-Get workflow 2

 

C-Get SCU

  通过结合 DICOM 开源库 fo-dicom 来实现 C-Get SCU,部分代码如下:
需要引用命名空间【Dicom.Network】和【System.Threading】

 

using Dicom.Network;
using System.Threading;

 

var client = new DicomClient();// 添加能够接收的抽象语法 abstract syntax,通过查看 DICOM 文件的 SOPClassUID 可获得,否则不会触发 C-Store 子操作
var pc = DicomPresentationContext.GetScpRolePresentationContext(DicomUID.CTImageStorage);
client.AdditionalPresentationContexts.Add(pc);var counter = 0;
var locker = new object();
client.OnCStoreRequest = (DicomCStoreRequest request) =>
{lock (locker){++counter;Console.WriteLine(DateTime.Now.ToString() + " recived, count is " + counter);}// 可以通过 request.Dataset 获取到 DICOM 文件return new DicomCStoreResponse(request, DicomStatus.Success);
};var get = new DicomCGetRequest({StudyInstanceUID});var handle = new ManualResetEventSlim();
get.OnResponseReceived = (DicomCGetRequest requ, DicomCGetResponse response) =>
{if (response.Remaining == 0){handle.Set();}
};
client.AddRequest(get);
client.Send({C-Get SCP IP}, {C-Get SCP Port}, false, {C-Get SCU AE Title}, {C-Get SCP AE Title});
handle.Wait();
  • StudyInstanceUID:检查唯一标识;
  • C-Get SCP IP:C-Get 服务端的 IP 地址或机器名;
  • C-Get SCP Port:C-Get 服务端的端口;
  • C-Get SCU AE Title:C-Get 客户端应用实体的名称;
  • C-Get SCP AE Title:C-Get 服务端应用实体的名称;

C-Get SCP


  在本文开头部分给出了两张流程图,这是通过不同 C-Get SCP 的实现进行抓包得到的,针对这块流程中不同的地方在 DICOM 标准中到底是如何定义的,可以在 DICOM 标准的第4部分【C.1.4 Service Definition】 中找到,具体的描述如下:

A C-GET service conveys the following semantics:

The SCU supplies Unique Key values to identify an entity at the level of the retrieval. The SCP generates C-STORE sub-oper- ations for the corresponding storage SOP Instances identified by the Unique Key values. These C-STORE sub-operations occur on the same Association as the C-GET service and the SCU/SCP roles will be reversed for the C-STORE.

The SCP may optionally generate responses to the C-GET with status equal to Pending during the processing of the C-STORE sub-operations. These C-GET responses indicate the number of Remaining C-STORE sub-operations and the number of C- STORE sub-operations returning the status of Success, Warning, and Failed.

When the number of Remaining C-STORE sub-operations reaches zero, the SCP generates a final response with a status equal to Success, Warning, Failed, or Refused. This response may indicate the number of C-STORE sub-operations returning the status of Success, Warning, and Failed. If the status of a C-STORE sub-operation was Failed a UID List will be returned.

The SCU may cancel the C-GET service by issuing a C-GET-CANCEL request at any time during the processing of the C- GET. The SCP terminates all incomplete C-STORE sub-operations and returns a status of Canceled.

这里已经说明了是可选的,更详细的 C-Get 过程在 DICOM 标准第7部分【9.1.3.2】有描述,不过针对这块没有描述,所以才出现如文章开头两种流程图。C-Get SCP 可以通过派生 DicomService 服务类来实现 Dicom 服务的基本框架,然后实现 IDicomServiceProvider 和 IDicomCGetProvider 接口来实现,部分代码可以参考这里,核心部分是实现 OnCGetRequest 方法。

 

C-Get 过程分析

  我这里选择本文开头第一种流程图的抓包数据进行分析,由于包的数据量比较大,我这里过滤掉不能被解码成 DICOM 协议的包,只分析能被解码成 DICOM 协议的包,先看前面部分:

 

C-Get pcap

红色框内的两行是两个 AE 建立 association 的过程:

  1. C-Get SCU(10.3.13.202)向 C-Get SCP(10.3.2.209) 发送 A-ASSOCIATE 请求;
  2. C-Get SCP(10.3.2.209)响应 C-Get SCU(10.3.13.202)的 A-ASSOCIATE 请求,然后两个 AE 就建立了一个 association;

接着蓝色框第一行就是 C-Get SCU(10.3.13.202)向 C-Get SCP(10.3.2.209) 发送 C-Get 请求了;
蓝色框第二行是 C-Get SCP(10.3.2.209)经过查找,找到满足条件的复合 SOP 实例对象,返回找到的信息,从下图红色框可以看到有3个子操作待执行,这里表示找到了3个满足条件的复合 SOP 实例对象,接下来会触发3个 C-Store 子操作。

 

C-Get Response

接着就是 C-Store 归档数据的操作了

C-Store

一个复合 SOP 实例对象数据归档的最后一个包是一个畸形数据包【Malformed packet】:

Malformed packet

从上图可以看出,前面传输的数据包都将在收到 Frame 609后进行重组,Frame 609就在 Malformed Packet 这个数据包,下面的蓝色框是这个数据包将前面所有收到的数据包重组之后,解析 SOP 对象得到的 TAG 值;
然后 C-Get SCU(10.3.13.202)向 C-Get SCP(10.3.2.209) 发送 C-Store 响应,并告知状态为 Success;

C-Store Response

接着 C-Get SCP(10.3.2.209)向 C-Get SCU(10.3.13.202)发送 C-Get 请求的响应,内容包括当前的状态、剩下多少个子操作待执行、已完成多少个子操作和失败的子操作个数:

C-Get Response

这个数据包结束后就又是下一个 SOP 实例对象的归档数据包了,和上面一样,这里不再继续分析。
当所有的 C-Store 子操作结束后 C-Get SCP(10.3.2.209)会向 C-Get SCU(10.3.13.202)发送一个 C-Get 请求的响应,这里会返回 C-Get 请求的状态,如果前面的子操作都成功的话,这里会返回状态为 Success:

C-Get Response

最后 C-Get SCU(10.3.13.202)向 C-Get SCP(10.3.2.209) 发送 A-RELEASE 请求断开 association;
C-Get SCP(10.3.2.209)响应 C-Get SCU(10.3.13.202)的 A-RELEASE 请求,然后断开两个 AE 之间的 association;
至此,整个 DICOM 协议相关的包就全部发送完毕。



作者:Statmoon
链接:https://www.jianshu.com/p/c7f5b9fa597c
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436085.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php dao类设计,DAO数据访问对象设计 - GoFrame官网 - 类似PHP-Laravel, Java-SpringBoot的Go企业级开发框架...

关于DAO数据访问对象设计其实是关于GoFrame框架工程化实践中比较重要一块设计。DAO设计结合GoFrame的ORM组件性能和易用性都很强,可以极大提高开发和维护效率。看完本章节内容之后,小伙伴们应该能够理解并体会到使用DAO数据库访问对象设计的优点。一、现…

再谈“我是怎么招聘程序员的”

我以前写过一篇“我是怎么招聘程序员的”的文章(在CSDN那里有很多人进行了回复)。今天,我想再谈谈关于招聘和面试这方面的东西,主要是以下这些原因: 近半年来我在进行了大量的招聘工作,对面试有一些新的体…

【转】04.Dicom 学习笔记-DICOM C-Move 消息服务

引言 前篇介绍了 DICOM C-Get 消息服务,本文结合开源 DICOM 库 fo-dicom 详细介绍一下 C-Move 服务。 C-Move 消息服务 C-Move 服务可以用来获取影像和转存影像,用于一个 DIMSE-service-user 在同等的 DIMSE-service-user 上查询复合 SOP 实例的属性满足…

【转】05.Dicom 学习笔记-DICOM C-Echo 消息服务

引言 经过前面几篇的介绍,DIMSE-C 消息服务这块已经讲解了差不多了,还剩最后一个 C-Echo 消息服务,这个服务相对前面的4个服务来说更简单一些,本文结合开源 DICOM 库 fo-dicom 详细介绍一下 C-Echo 服务。 C-Echo 消息服务 首先来…

哪些设计模式最值得学习

最近又在首页看到几篇设计模式相关的学习随笔。回想起来,这几年在园子里发布的有关设计模式的随笔都有一个共同的特点。那就是Factory和Singleton居多,如果是系列的,也往往是从这两个模式开始的。由于能够坚持把《设计模式》中所有模式都写完…

【转】000.DICOM:DICOM标准学习路线图(初稿)!!!!!!!!!!!!

转自:https://zssure.blog.csdn.net/article/details/49231303 题记: DICOM医学图像处理专栏撰写已有两个年头,积累了近百篇文章。 起初 只是用于记录自己科研、工作中遇到的疑难问题,专注于图像处理(主要是医学图像…

对比 SQL Server 2005 和 Oracle

在 Microsoft Windows Server 上运行的 SQL Server 2005,为企业级关系数据库和分析解决方案提供了一个平台,在安全、可用性、与 Visual Studio 的整合度,从小企业到大企业的可扩展性以及低费用方面胜过了Oracle 10g。探索下列信息以发现在 这…

【转】pacs定位线_C#开发PACS医学影像处理系统(十五):Dicom影像交叉定位线算法

转自:https://www.cnblogs.com/Uncle-Joker/p/13686618.html 1.定位线概念:某个方位的影像在另一个方向的影像上的投影相交线,例如横断面(从头到脚的方向)在矢状面(从左手到右手)上的影像投影面交线。 举个例子:右边的是MR(核磁共…

C++设计模式之 简单工厂模式讲解(历史上最简单明白的例子)

工作之余,在看资料过程中发现一个极易理解的简单工厂模式的例子,自己亲自试练一番,感觉对这个设计模式不熟悉的朋友, 一看马上就知道是什么回事了。 简单工厂模式根据提供给它的数据,返回几个可能类中的一个类的实例。通常它返的…

【转】.NET Core 可移植类库PCL Portable Class Library详解

转自:https://www.kaifaxueyuan.com/server/dotnet-core/dotnet-core-portable-class-library.html 在这一章中,我们将讨论什么是PCL (可移植类库),以及为什么我们需要PCL。为了理解这个概念,让我们打开上一章创建的类库项目文件夹…

设计模式C++实现(4)——原型模式、模板方法模式

软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书&#xff0…

【转】医疗业务学习笔记--DICOM协议的基础内容!!!!!!!!!!

转自:医疗业务学习笔记--DICOM协议的基础内容 - 知乎 本文首发于“雨夜随笔”公众号,欢迎关注。 DICOM协议是医疗领域对如何处理、存储、打印和传输医疗图片的一系列标准。DICOM是 Digital Imaging and Communications in Medicine 的缩写,…

linux去掉u盘写保护,最全面win10系统下u盘写保护怎么去掉

U盘写保护就是只能读取U盘中的内容,但是却不能修改或者将其它文件保存在U盘,有时候U盘写保护妨碍我们使用,有些朋友想要将其接除,对此,我给大家整理了win10移除写保护的方法,希望能帮助到你U盘是通过USB接口…

设计模式C++实现(5)——桥接模式

软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书&#xff0…

【转】CT基本概念(必须掌握)!!!!!!!!!!!!!!

转自:http://www.bmecn.com/wenku/knowledge/988.html 1.像素(Pixel)和体素(Voxel) 像素(Pixel)是构成图像的基本单位,即图像可被分解成的最小的独立信息单元。因为图像是二维的&a…

推荐笔记本用户使用的硬盘。。。2.5”战胜台式机硬盘 日立7K320-250GB

2.5”战胜台式机硬盘 日立7K320-250GB 相关评测文章参考:http://www.beareyes.com.cn/2/lib/200808/07/20080807034_8.htm 转载于:https://www.cnblogs.com/bingdongli/archive/2008/10/05/1304169.html

设计模式C++实现(6)——适配器模式

软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书&#xff0…

设计模式C++实现(7)——装饰模式

装饰模式:动态地给一个对象添加一些额外的职责。就增加功能来说,装饰模式相比生成子类更为灵活。有时我们希望给某个对象而不是整个类添加一些功能。比如有一个手机,允许你为手机添加特性,比如增加挂件、屏幕贴膜等。一种灵活的设…

较为周全的Asp.net提交验证方案 (下)

接上篇。 下面要对这个生成的“提交验证”类进行功能扩展,通过.Net的“部分类”或“扩展方法”技术都可以轻松实现,这里采用的是“部分类”技术: 引用生成的ADO.NET Entity Framework数据模型的命名空间,且声明为部分类。 书写静态…

linux 14.04安装方法,Ubuntu 14.04 安装配置GNOME经典界面

Ubuntu 14.04上基本完美支持GNOME经典界面,安装配置步骤如下:1. 安装gnome-session-flashbacksudo apt-get install gnome-session-flashback这个包安装后,注销后,在登录界面就能选择GNOME Flashback (Compiz)这个桌面环境了。2. …