Module: RTP
- Includes:
- Logging
- Defined in:
- lib/rtp-connect/plan.rb,
lib/rtp-connect/field.rb,
lib/rtp-connect/record.rb,
lib/rtp-connect/logging.rb,
lib/rtp-connect/methods.rb,
lib/rtp-connect/version.rb,
lib/rtp-connect/constants.rb,
lib/rtp-connect/variables.rb,
lib/rtp-connect/site_setup.rb,
lib/rtp-connect/plan_to_dcm.rb,
lib/rtp-connect/prescription.rb,
lib/rtp-connect/control_point.rb,
lib/rtp-connect/dose_tracking.rb,
lib/rtp-connect/extended_plan.rb,
lib/rtp-connect/extended_field.rb,
lib/rtp-connect/simulation_field.rb
Overview
Copyright 2011-2020 Christoffer Lervag
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Defined Under Namespace
Modules: Logging Classes: ControlPoint, DoseTracking, ExtendedField, ExtendedPlan, Field, Plan, Prescription, Record, SimulationField, SiteSetup
Constant Summary collapse
- VERSION =
The RTPConnect library version string.
'1.11'
- CRC_SEED =
The seed value used in the RTPConnect implementation of the CCITT algorithm.
0x0521
- CRC_TABLE =
The table & values used in the RTPConnect implementation of the CCITT algorithm.
[ 0x0000, 0xC0C1, 0xC181, 0x0140, 0xC301, 0x03C0, 0x0280, 0xC241, 0xC601, 0x06C0, 0x0780, 0xC741, 0x0500, 0xC5C1, 0xC481, 0x0440, 0xCC01, 0x0CC0, 0x0D80, 0xCD41, 0x0F00, 0xCFC1, 0xCE81, 0x0E40, 0x0A00, 0xCAC1, 0xCB81, 0x0B40, 0xC901, 0x09C0, 0x0880, 0xC841, 0xD801, 0x18C0, 0x1980, 0xD941, 0x1B00, 0xDBC1, 0xDA81, 0x1A40, 0x1E00, 0xDEC1, 0xDF81, 0x1F40, 0xDD01, 0x1DC0, 0x1C80, 0xDC41, 0x1400, 0xD4C1, 0xD581, 0x1540, 0xD701, 0x17C0, 0x1680, 0xD641, 0xD201, 0x12C0, 0x1380, 0xD341, 0x1100, 0xD1C1, 0xD081, 0x1040, 0xF001, 0x30C0, 0x3180, 0xF141, 0x3300, 0xF3C1, 0xF281, 0x3240, 0x3600, 0xF6C1, 0xF781, 0x3740, 0xF501, 0x35C0, 0x3480, 0xF441, 0x3C00, 0xFCC1, 0xFD81, 0x3D40, 0xFF01, 0x3FC0, 0x3E80, 0xFE41, 0xFA01, 0x3AC0, 0x3B80, 0xFB41, 0x3900, 0xF9C1, 0xF881, 0x3840, 0x2800, 0xE8C1, 0xE981, 0x2940, 0xEB01, 0x2BC0, 0x2A80, 0xEA41, 0xEE01, 0x2EC0, 0x2F80, 0xEF41, 0x2D00, 0xEDC1, 0xEC81, 0x2C40, 0xE401, 0x24C0, 0x2580, 0xE541, 0x2700, 0xE7C1, 0xE681, 0x2640, 0x2200, 0xE2C1, 0xE381, 0x2340, 0xE101, 0x21C0, 0x2080, 0xE041, 0xA001, 0x60C0, 0x6180, 0xA141, 0x6300, 0xA3C1, 0xA281, 0x6240, 0x6600, 0xA6C1, 0xA781, 0x6740, 0xA501, 0x65C0, 0x6480, 0xA441, 0x6C00, 0xACC1, 0xAD81, 0x6D40, 0xAF01, 0x6FC0, 0x6E80, 0xAE41, 0xAA01, 0x6AC0, 0x6B80, 0xAB41, 0x6900, 0xA9C1, 0xA881, 0x6840, 0x7800, 0xB8C1, 0xB981, 0x7940, 0xBB01, 0x7BC0, 0x7A80, 0xBA41, 0xBE01, 0x7EC0, 0x7F80, 0xBF41, 0x7D00, 0xBDC1, 0xBC81, 0x7C40, 0xB401, 0x74C0, 0x7580, 0xB541, 0x7700, 0xB7C1, 0xB681, 0x7640, 0x7200, 0xB2C1, 0xB381, 0x7340, 0xB101, 0x71C0, 0x7080, 0xB041, 0x5000, 0x90C1, 0x9181, 0x5140, 0x9301, 0x53C0, 0x5280, 0x9241, 0x9601, 0x56C0, 0x5780, 0x9741, 0x5500, 0x95C1, 0x9481, 0x5440, 0x9C01, 0x5CC0, 0x5D80, 0x9D41, 0x5F00, 0x9FC1, 0x9E81, 0x5E40, 0x5A00, 0x9AC1, 0x9B81, 0x5B40, 0x9901, 0x59C0, 0x5880, 0x9841, 0x8801, 0x48C0, 0x4980, 0x8941, 0x4B00, 0x8BC1, 0x8A81, 0x4A40, 0x4E00, 0x8EC1, 0x8F81, 0x4F40, 0x8D01, 0x4DC0, 0x4C80, 0x8C41, 0x4400, 0x84C1, 0x8581, 0x4540, 0x8701, 0x47C0, 0x4680, 0x8641, 0x8201, 0x42C0, 0x4380, 0x8341, 0x4100, 0x81C1, 0x8081, 0x4040 ]
- PARSE_METHOD =
Pairs of RTPConnect keywords and parse method names.
{ "PLAN_DEF" => :plan_definition, "EXTENDED_PLAN_DEF" => :extended_plan_def, "RX_DEF" => :prescription_site, "SITE_SETUP_DEF" => :site_setup, "SIM_DEF" => :simulation_field, "FIELD_DEF" => :treatment_field, "EXTENDED_FIELD_DEF" => :extended_treatment_field, "PDF_FIELD_DEF" => :document_based_treatment_field, "MLC_DEF" => :multileaf_collimator, "CONTROL_PT_DEF" => :control_point, "MLC_SHAPE_DEF" => :mlc_shape, "DOSE_DEF" => :dose_tracking, "DOSE_ACTION" => :dose_action, }
Class Method Summary collapse
-
.leaf_boundaries(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for a given type of MLC, specified by its number of leaves at one side.
-
.leaf_boundaries_even(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for ordinary even numbered multi leaf collimators.
-
.leaf_boundaries_odd(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for ordinary odd numbered multi leaf collimators.
-
.leaf_boundaries_varian_60 ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for the Varian 120 leaf MLC (60 leaves on each bank).
-
.verify(line, options = {}) ⇒ Boolean
Computes the CRC checksum of the given line and verifies that this value corresponds with the checksum given at the end of the line.
Methods included from Logging
Class Method Details
.leaf_boundaries(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for a given type of MLC, specified by its number of leaves at one side.
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# File 'lib/rtp-connect/methods.rb', line 16 def leaf_boundaries(nr_leaves) case nr_leaves when 29 leaf_boundaries_odd(29) when 40 leaf_boundaries_even(40) when 41 leaf_boundaries_odd(41) when 60 leaf_boundaries_varian_60 when 80 leaf_boundaries_even(80) else raise ArgumentError, "Unsupported number of leaves: #{nr_leaves}" end end |
.leaf_boundaries_even(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for ordinary even numbered multi leaf collimators.
39 40 41 |
# File 'lib/rtp-connect/methods.rb', line 39 def leaf_boundaries_even(nr_leaves) Array.new(nr_leaves+1) {|i| (i * 400 / nr_leaves.to_f - 200).to_i} end |
.leaf_boundaries_odd(nr_leaves) ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for ordinary odd numbered multi leaf collimators.
49 50 51 |
# File 'lib/rtp-connect/methods.rb', line 49 def leaf_boundaries_odd(nr_leaves) Array.new(nr_leaves-1) {|i| (10 * (i - (0.5 * nr_leaves - 1))).to_i}.unshift(-200).push(200) end |
.leaf_boundaries_varian_60 ⇒ Array<Fixnum>
Gives an array of MLC leaf position boundaries for the Varian 120 leaf MLC (60 leaves on each bank).
57 58 59 60 61 |
# File 'lib/rtp-connect/methods.rb', line 57 def leaf_boundaries_varian_60 Array.new(10) {|i| (i * 10 - 200).to_i} .concat(Array.new(41) {|i| (i * 5 - 100).to_i}) .concat(Array.new(10) {|i| (i * 10 + 110).to_i}) end |
.verify(line, options = {}) ⇒ Boolean
Computes the CRC checksum of the given line and verifies that this value corresponds with the checksum given at the end of the line.
72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/rtp-connect/methods.rb', line 72 def verify(line, ={}) last_comma_pos = line.rindex(',') raise ArgumentError, "Invalid line encountered; No comma present in the string: #{line}" unless last_comma_pos string_to_check = line[0..last_comma_pos] string_remaining = line[(last_comma_pos+1)..-1] raise ArgumentError, "Invalid line encountered; Valid checksum missing at end of string: #{string_remaining}" unless string_remaining.length >= 3 checksum_extracted = string_remaining.value.to_i checksum_computed = string_to_check.checksum raise ArgumentError, "Invalid line encountered: Specified checksum #{checksum_extracted} deviates from the computed checksum #{checksum_computed}." if checksum_extracted != checksum_computed && ![:ignore_crc] return true end |