0

私は dcm4che2 ライブラリを使用したプログラミングの初心者であり、Query/Retrieve Level を Patient/Series/Image に設定して、PACS サーバーにクエリを実行する簡単なプログラムを作成しています。
コードは非常に単純で、場合によっては正常に動作します。

  dcmqr.setCalledAET("AET_REMOTE", true);
  dcmqr.setRemoteHost("aa.bb.cc.dd");
  dcmqr.setRemotePort(xxxx);
  dcmqr.getKeys();

  dcmqr.setDateTimeMatching(true);
  dcmqr.setCFind(true);
  dcmqr.setCGet(false);
  dcmqr.configureTransferCapability(true);
  dcmqr.setQueryLevel(DcmQR.QueryRetrieveLevel.IMAGE);

  dcmqr.addMatchingKey(new int[]{Tag.PatientName},sPatientName);
  dcmqr.addMatchingKey(new int[]{Tag.Modality},sModality);  
  dcmqr.addMatchingKey(new int[]{Tag.AccessionNumber},sAccession);
  dcmqr.addMatchingKey(new int[]{Tag.SeriesNumber},sSeriesNumber);
  dcmqr.addReturnKey(new int[]{Tag.SeriesDescription});
  dcmqr.addReturnKey(new int[]{Tag.StudyDescription});
  dcmqr.addReturnKey(new int[]{Tag.PatientBirthDate});
  dcmqr.addReturnKey(new int[]{Tag.PatientSex});

  List<DicomObject> result = null;

  try{
    dcmqr.start();
    dcmqr.open();
    result = dcmqr.query();
    dcmqr.stop();
    dcmqr.close();
  }
  catch(Exception e){
      ...
  }

ただし、場合によっては (およびクエリ/取得レベルを「イメージ」に設定するたびに)、query() メソッドが失敗し (「DIMSE RSP の予期しないメッセージ ID」)、以下に報告されているように A-Abort コマンドがスローされます。

...

[main] INFO org.dcm4che2.net.PDUEncoder - AET_REMOTE(1) << 3:C-FIND-RQ[pcid=1,   prior=0
        cuid=xyz/Study Root Query/Retrieve Information Model - FIND
        ts=xyz/Implicit VR Little Endian]

[AE_TITLE_X] INFO org.dcm4che2.net.PDUDecoder - AET_REMOTE(1) >> 2:C-FIND-RSP[
pcid=1, status=0H cuid=xyz/Study Root Query/Retrieve Information Model - FIND]

[main] INFO org.dcm4che2.tool.dcmqr.DcmQR - Send Query Request #3/15 using .../Study Root Query/Retrieve Information Model - FIND:
(0008,0052) CS #6 [IMAGE] Query/Retrieve Level
(0008,0060) CS #2 [CT] Modality
(0010,0010) PN #12 [xxx^yyyy] PatientÆs Name
(0020,000D) UI #42 [x.y.z.zyx...] Study Instance UID
(0020,000E) UI #56 [y.x.z.zyx...] Series Instance UID

[AE_TITLE_X] WARN org.dcm4che2.net.Association - unexpected message ID in DIMSE RSP:
(0000,0002) UI #28 [x.y.z.zax...] Affected SOP Class UID
(0000,0100) US #2 [32800] Command Field
(0000,0120) US #2 [2] Message ID Being Responded To
(0000,0800) US #2 [257] Command Data Set Type
(0000,0900) US #2 [0] Status

[AE_TITLE_X] INFO org.dcm4che2.net.PDUEncoder - AET_REMOTE(1) << A-ABORT[source=0,       reason=0]
[AE_TITLE_X] INFO org.dcm4che2.net.Association - AET_REMOTE(1): close    Socket[addr=/aa.bb.cc.dd,port=xxx,localport=yyy]

[main] INFO org.dcm4che2.net.PDUEncoder - AET_REMOTE(1) << 4:C-FIND-RQ[pcid=1, prior=0
cuid=.../Study Root Query/Retrieve Information Model - FIND
    ts=.../Implicit VR Little Endian]
[main] WARN org.dcm4che2.net.Association - unable to send P-DATA-TF in state: Sta1

実際、このエラーが何を意味するのか理解できず、解決策を見つけられません。コミュニケーションの問題だと思います..誰か助けてくれませんか?

ありがとう。

4

1 に答える 1