File: get.cpp

package info (click to toggle)
odil 0.13.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,476 kB
  • sloc: cpp: 55,982; python: 3,947; javascript: 460; xml: 182; makefile: 99; sh: 36
file content (116 lines) | stat: -rw-r--r-- 3,786 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include <iostream>

#include "odil/Association.h"
#include "odil/DataSet.h"
#include "odil/FindSCU.h"
#include "odil/GetSCU.h"
#include "odil/registry.h"

void print_informations(std::shared_ptr<odil::DataSet const> response)
{
    auto const name = response->has("PatientName")?
        response->as_string("PatientName", 0):"(no name)";
    auto const study = response->has("StudyDescription")?
        response->as_string("StudyDescription", 0):"(no study description)";
    auto const series = response->has("SeriesDescription")?
        response->as_string("SeriesDescription", 0):"(no series description)";
    auto const instance = response->has("InstanceNumber")?
        response->as_int("InstanceNumber", 0):(-1);
    std::cout
        << name << ": " << study << " / " << series << ": " << instance << "\n";
}

int main()
{
    odil::Association association;
    association.set_peer_host("184.73.255.26");
    association.set_peer_port(11112);
    association.update_parameters()
        .set_calling_ae_title("myself")
        .set_called_ae_title("AWSPIXELMEDPUB")
        .set_presentation_contexts({
            {
                odil::registry::StudyRootQueryRetrieveInformationModelFind,
                { odil::registry::ImplicitVRLittleEndian }, 
                odil::AssociationParameters::PresentationContext::Role::SCU
            },
            {
                odil::registry::StudyRootQueryRetrieveInformationModelGet,
                { odil::registry::ImplicitVRLittleEndian }, 
                odil::AssociationParameters::PresentationContext::Role::SCU
            },
            {
                odil::registry::MRImageStorage,
                { odil::registry::ImplicitVRLittleEndian }, 
                odil::AssociationParameters::PresentationContext::Role::SCP
            },
            {
                odil::registry::Verification,
                { odil::registry::ImplicitVRLittleEndian }, 
                odil::AssociationParameters::PresentationContext::Role::SCU
            }
        });
    
    association.associate();

    odil::FindSCU find_scu(association);
    find_scu.set_affected_sop_class(
        odil::registry::StudyRootQueryRetrieveInformationModelFind);

    auto query = std::make_shared<odil::DataSet>();
    query->add("QueryRetrieveLevel", { "STUDY" });
    query->add("StudyInstanceUID");

    auto const studies = find_scu.find(query);
    std::shared_ptr<odil::DataSet> series;
    for(auto const & study: studies)
    {
        if(!study->has("StudyInstanceUID"))
        {
            continue;
        }

        query->clear();
        query->add("QueryRetrieveLevel", {"SERIES"});
        query->add("Modality", {"MR"});
        query->add("StudyInstanceUID", study->as_string("StudyInstanceUID"));
        query->add("SeriesInstanceUID");

        auto const study_series = find_scu.find(query);

        if(!study_series.empty())
        {
            series = study_series[0];
            break;
        }
    }

    odil::GetSCU get_scu(association);
    get_scu.set_affected_sop_class(
        odil::registry::StudyRootQueryRetrieveInformationModelGet);
    
    query->clear();
    query->add("QueryRetrieveLevel", { "SERIES" });
    query->add("StudyInstanceUID", (*series)["StudyInstanceUID"]);
    query->add("SeriesInstanceUID", (*series)["SeriesInstanceUID"]);

    std::cout << "--------\n";
    std::cout << "Callback\n";
    std::cout << "--------\n\n";
    
    get_scu.get(query, print_informations);
    
    std::cout << "\n";
    
    std::cout << "------\n";
    std::cout << "vector\n";
    std::cout << "------\n\n";
    
    auto const result = get_scu.get(query);
    for(auto const & dataset: result)
    {
        print_informations(dataset);
    }
    
    association.release();
}