1 | # This modules are implemented from the UML shown bellow
|
---|
2 | # http://www.openehr.org/uml/release-1.0.1/Browsable/_9_0_76d0249_1109599337877_94556_1510Report.html
|
---|
3 | # Ticket refs #50
|
---|
4 | module OpenEHR
|
---|
5 | module RM
|
---|
6 | module Data_Types
|
---|
7 | module Quantity
|
---|
8 |
|
---|
9 | autoload :Date_Time, "rm/data_types/quantity/date_time.rb"
|
---|
10 |
|
---|
11 | class DV_Ordered < OpenEHR::RM::Data_Types::Basic::Data_Value
|
---|
12 | include Comparable
|
---|
13 | attr_reader :other_refference_ranges, :normal_range, :normal_status
|
---|
14 |
|
---|
15 | def initialize(normal_range=nil, normal_status = nil,
|
---|
16 | other_reference_ranges=nil)
|
---|
17 | self.normal_range = normal_range
|
---|
18 | self.normal_status = normal_status
|
---|
19 | self.other_reference_ranges = other_reference_ranges
|
---|
20 | end
|
---|
21 |
|
---|
22 | def is_normal?
|
---|
23 | if @normal_range.nil? and @normal_status.nil?
|
---|
24 | return false
|
---|
25 | elsif !@normal_range.nil?
|
---|
26 | return @normal_range.has(@value)
|
---|
27 | elsif !@normal_status.nil?
|
---|
28 | return @normal_status.code_string == 'N'
|
---|
29 | end
|
---|
30 | end
|
---|
31 |
|
---|
32 | def is_simple?
|
---|
33 | normal_status.nil? and other_refference_ranges.nil?
|
---|
34 | end
|
---|
35 |
|
---|
36 | def <=>(other)
|
---|
37 | raise NotImplementedError, 'This method should be implemented'
|
---|
38 | end
|
---|
39 |
|
---|
40 | def normal_range=(normal_range)
|
---|
41 | @normal_range = normal_range
|
---|
42 | end
|
---|
43 |
|
---|
44 | def other_reference_ranges=(other_reference_ranges)
|
---|
45 | unless other_reference_ranges.nil? or !other_reference_ranges.is_empty?
|
---|
46 | raise ArgumentError, "Other reference ranges validity error"
|
---|
47 | end
|
---|
48 |
|
---|
49 | @other_reference_ranges = other_reference_ranges
|
---|
50 | end
|
---|
51 |
|
---|
52 | def normal_status=(normal_status)
|
---|
53 | @normal_status = normal_status
|
---|
54 | end
|
---|
55 |
|
---|
56 | def is_strictry_comparable_to?(other)
|
---|
57 | raise NotImplementedError, 'this method should be implemented'
|
---|
58 | end
|
---|
59 | end
|
---|
60 |
|
---|
61 | class DV_Quantified < DV_Ordered
|
---|
62 |
|
---|
63 | def initialize
|
---|
64 |
|
---|
65 | end
|
---|
66 |
|
---|
67 | def magnitude
|
---|
68 |
|
---|
69 | end
|
---|
70 |
|
---|
71 | def <=>(others)
|
---|
72 |
|
---|
73 | end
|
---|
74 |
|
---|
75 | def valid_magnitude_status(s)
|
---|
76 | end
|
---|
77 | end
|
---|
78 |
|
---|
79 | class DV_Ordinal < DV_Ordered
|
---|
80 | attr_reader :symbol, :value
|
---|
81 |
|
---|
82 | def is_strictly_comparable_to?
|
---|
83 | end
|
---|
84 |
|
---|
85 | def limits
|
---|
86 | end
|
---|
87 | end
|
---|
88 |
|
---|
89 | class DV_Absolute_Quantity < DV_Quantified
|
---|
90 | attr_reader :accuracy
|
---|
91 |
|
---|
92 | def add(a_diff)
|
---|
93 | raise NotImplementError, 'add must be implemented'
|
---|
94 | end
|
---|
95 |
|
---|
96 | def diff(other)
|
---|
97 | raise NotImplementError, 'diff must be implemented'
|
---|
98 | end
|
---|
99 |
|
---|
100 | def subtract(a_diff)
|
---|
101 | raise NotImplementError, 'subtract must be implemented'
|
---|
102 | end
|
---|
103 | end
|
---|
104 |
|
---|
105 | class DV_Amount < DV_Quantified
|
---|
106 | attr_reader :accuracy, :accuracy_is_percent
|
---|
107 | def infix(dv_amount, op)
|
---|
108 | raise NotImplementError, 'infix must be implemented'
|
---|
109 | end
|
---|
110 | def accuracy=(accuracy)
|
---|
111 | raise ArgumentError, 'accuracy invalid'
|
---|
112 | end
|
---|
113 | end
|
---|
114 |
|
---|
115 | class Reference_Range
|
---|
116 |
|
---|
117 | end
|
---|
118 | end # of Quantity
|
---|
119 | end # of Data_Types
|
---|
120 | end # of RM
|
---|
121 | end # of OpenEHR
|
---|