metamri 0.2.24 → 0.2.25
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -13
- data/VERSION +1 -1
- data/lib/metamri/core_additions.rb +9 -1
- data/lib/metamri/raw_image_dataset_thumbnail.rb +1 -1
- data/lib/metamri/raw_image_file.rb +28 -23
- data/lib/metamri/version.rb +1 -1
- data/lib/metamri.rb +1 -1
- data/metamri.gemspec +6 -6
- metadata +25 -39
checksums.yaml
CHANGED
@@ -1,15 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
|
5
|
-
data.tar.gz: !binary |-
|
6
|
-
NDgyNWE5ZjJkMDkxYzRkM2VmNWJiMjdiZWZiZWI5MWEzZWM1NWY3ZQ==
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: 92932063e1a8a63e45c8b74c92adfbd4def00b09
|
4
|
+
data.tar.gz: 467f2328d0aee4538b0cd03c68e98b8a8599c7b9
|
7
5
|
SHA512:
|
8
|
-
metadata.gz:
|
9
|
-
|
10
|
-
YzA2YmZlMDA4N2UyMjU2N2UxZTJjZDVhMWZkMzdmMzRjYjRlM2M2NzNkZGM1
|
11
|
-
YWFhM2U5MjQ5YzMwOWNiM2JhMTZjYjFkZjRiZDBlNDQzZWJiYzU=
|
12
|
-
data.tar.gz: !binary |-
|
13
|
-
M2Q1NjY2OGFmZGQzZTFiODI3MWU5MmQwNTM4OWZhOWE3OGQ2MzI2OWE0Yjhh
|
14
|
-
NWRmZWMwZWMyMWJiZDRiZDA0ZjQyOGE1NTRhODgxODIzN2UzMmI0YWM5YzRj
|
15
|
-
MDhkMDYwZmQzNDhkZDQzMjRhOTUxOGVkYWQzNjRlOWQyNDA3ZDA=
|
6
|
+
metadata.gz: 9de4f0f131ad11edd2c8a9e99c22efeb8c0e243e14fb8a23ec3c373e7fa537cceabc3dc837310dd35704c7d77a674b8f136fc455adf490e4227c2d1ced991419
|
7
|
+
data.tar.gz: bf1ade09fe6571e22d4c6f71efb3305e28bb01b528e87e5c9212bf6e8aab3fd8f2d5d4289c3d45323c941a2f77fb394b73b7e42a0fffa7329c24e3651b465542
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.2.
|
1
|
+
0.2.25
|
@@ -44,7 +44,15 @@ class Pathname
|
|
44
44
|
next unless leaf.to_s =~ /^P.{5}\.7(\.bz2)/
|
45
45
|
branch = self + leaf
|
46
46
|
next if branch.symlink?
|
47
|
-
|
47
|
+
v_pfile_small_but_summary_flag ="N"
|
48
|
+
if branch.size < min_file_size
|
49
|
+
leaf_summary_s = (leaf.to_s).gsub(/\.bz2/,"")+".summary"
|
50
|
+
branch_summary_s = self.to_s+"/"+leaf_summary_s
|
51
|
+
if File.exist?(branch_summary_s)
|
52
|
+
v_pfile_small_but_summary_flag ="Y"
|
53
|
+
end
|
54
|
+
end
|
55
|
+
if branch.size >= min_file_size or v_pfile_small_but_summary_flag == "Y"
|
48
56
|
# check for P*.7.summary
|
49
57
|
# if there, skip local_copy of P*.7.bz2
|
50
58
|
leaf_summary_s = (leaf.to_s).gsub(/\.bz2/,"")+".summary"
|
@@ -125,7 +125,7 @@ class RawImageDatasetThumbnail
|
|
125
125
|
if dicom_files.empty? # If still empty...
|
126
126
|
raise StandardError, "Could not find dicom files using #{dataset.glob} in #{dataset.directory}"
|
127
127
|
end
|
128
|
-
dicom_file = Pathname(dicom_files[(dicom_files.size/
|
128
|
+
dicom_file = Pathname(dicom_files[(dicom_files.size/3)+1]) # 2 => 3 to keep asl in first half of set --> delay time
|
129
129
|
dicom_file.local_copy do |lc|
|
130
130
|
#dcm = DICOM::DObject.new(lc.to_s) # changing from dicom 0.8.0 to 0.9.5
|
131
131
|
dcm = DICOM::DObject.read(lc.to_s)
|
@@ -196,14 +196,15 @@ class RawImageFile
|
|
196
196
|
# compatible database (sqlite3). This is intended for inserting into the rails
|
197
197
|
# backend database.
|
198
198
|
def db_insert(image_dataset_id)
|
199
|
-
"INSERT INTO raw_image_files
|
200
|
-
(filename, header_reader, file_type, timestamp, source, rmr_number, series_description,
|
201
|
-
gender, num_slices, slice_thickness, slice_spacing, reconstruction_diameter,
|
202
|
-
acquisition_matrix_x, acquisition_matrix_y, rep_time, bold_reps, created_at, updated_at, image_dataset_id)
|
203
|
-
VALUES ('#{@filename}', '#{@hdr_reader}', '#{@file_type}', '#{@timestamp.to_s}', '#{@source}', '#{@rmr_number}',
|
204
|
-
'#{@series_description}', '#{@gender}', #{@num_slices}, #{@slice_thickness}, #{@slice_spacing},
|
205
|
-
|
206
|
-
|
199
|
+
####"INSERT INTO raw_image_files
|
200
|
+
####(filename, header_reader, file_type, timestamp, source, rmr_number, series_description,
|
201
|
+
####gender, num_slices, slice_thickness, slice_spacing, reconstruction_diameter,
|
202
|
+
####acquisition_matrix_x, acquisition_matrix_y, rep_time, bold_reps, created_at, updated_at, image_dataset_id)
|
203
|
+
####VALUES ('#{@filename}', '#{@hdr_reader}', '#{@file_type}', '#{@timestamp.to_s}', '#{@source}', '#{@rmr_number}',
|
204
|
+
####'#{@series_description}', '#{@gender}', #{@num_slices}, #{@slice_thickness}, #{@slice_spacing},
|
205
|
+
#### #{@reconstruction_diameter}, #{@acquisition_matrix_x}, #{@acquisition_matrix_y}, #{@rep_time},
|
206
|
+
#### #{@bold_reps}, '#{DateTime.now}', '#{DateTime.now}', #{image_dataset_id})"
|
207
|
+
puts "Old no raw_image_files table"
|
207
208
|
end
|
208
209
|
|
209
210
|
# Returns an SQL statement to select this image file row from the raw_image_files table
|
@@ -222,31 +223,35 @@ class RawImageFile
|
|
222
223
|
# Uses the db_insert method to actually perform the database insert using the
|
223
224
|
# specified database file.
|
224
225
|
def db_insert!( db_file )
|
225
|
-
db = SQLite3::Database.new( db_file )
|
226
|
-
db.transaction do |database|
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
end
|
232
|
-
db.close
|
226
|
+
####db = SQLite3::Database.new( db_file )
|
227
|
+
####db.transaction do |database|
|
228
|
+
#### if not database.execute( db_fetch ).empty?
|
229
|
+
#### raise(IndexError, "Entry exists for #{filename}, #{@rmr_number}, #{@timestamp.to_s}... Skipping.")
|
230
|
+
#### end
|
231
|
+
#### database.execute( db_insert )
|
232
|
+
####end
|
233
|
+
####db.close
|
234
|
+
puts "SQLite3"
|
233
235
|
end
|
234
236
|
|
235
237
|
# Removes this instance from the raw_image_files table of the specified database.
|
236
238
|
def db_remove!( db_file )
|
237
|
-
db = SQLite3::Database.new( db_file )
|
238
|
-
db.execute( db_remove )
|
239
|
-
db.close
|
239
|
+
####db = SQLite3::Database.new( db_file )
|
240
|
+
####db.execute( db_remove )
|
241
|
+
####db.close
|
242
|
+
puts "SQLite3"
|
240
243
|
end
|
241
244
|
|
242
245
|
# Finds the row in the raw_image_files table of the given db file that matches this object.
|
243
246
|
# ORM is based on combination of rmr_number, timestamp, and filename. The row is returned
|
244
247
|
# as an array of values (see 'sqlite3' gem docs).
|
245
248
|
def db_fetch!( db_file )
|
246
|
-
db = SQLite3::Database.new( db_file )
|
247
|
-
db_row = db.execute( db_fetch )
|
248
|
-
db.close
|
249
|
-
return db_row
|
249
|
+
####db = SQLite3::Database.new( db_file )
|
250
|
+
####db_row = db.execute( db_fetch )
|
251
|
+
####db.close
|
252
|
+
####return db_row
|
253
|
+
puts "SQLite"
|
254
|
+
return nil
|
250
255
|
end
|
251
256
|
|
252
257
|
# The series ID (dicom_series_uid [dicom] or series_uid [pfile/ifile])
|
data/lib/metamri/version.rb
CHANGED
data/lib/metamri.rb
CHANGED
data/metamri.gemspec
CHANGED
@@ -17,14 +17,14 @@ Gem::Specification.new do |s|
|
|
17
17
|
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
18
18
|
s.require_paths = ["lib"]
|
19
19
|
|
20
|
-
s.add_runtime_dependency('dicom'
|
20
|
+
s.add_runtime_dependency('dicom') ####, "~> 0.9.5") # fixed issue with multi row dicom values
|
21
21
|
#s.add_runtime_dependency('dicom', "~> 0.8.0")
|
22
|
-
s.add_runtime_dependency('activeresource'
|
22
|
+
s.add_runtime_dependency('activeresource') #####, "~> 3.0")
|
23
23
|
# s.add_runtime_dependency('rmagick')
|
24
|
-
s.add_runtime_dependency('hirb'
|
25
|
-
s.add_runtime_dependency('sqlite3'
|
26
|
-
s.add_development_dependency('rspec'
|
27
|
-
s.add_development_dependency('escoffier', ">= 0")
|
24
|
+
s.add_runtime_dependency('hirb') #####, "~> 0.4")
|
25
|
+
s.add_runtime_dependency('sqlite3') #####, "~>1.3.4")
|
26
|
+
s.add_development_dependency('rspec') ####, "~> 2.5")
|
27
|
+
####s.add_development_dependency('escoffier', ">= 0")
|
28
28
|
|
29
29
|
end
|
30
30
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: metamri
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.25
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Kristopher J. Kosmatka
|
@@ -9,90 +9,76 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date:
|
12
|
+
date: 2017-04-06 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: dicom
|
16
16
|
requirement: !ruby/object:Gem::Requirement
|
17
17
|
requirements:
|
18
|
-
- -
|
18
|
+
- - ">="
|
19
19
|
- !ruby/object:Gem::Version
|
20
|
-
version: 0
|
20
|
+
version: '0'
|
21
21
|
type: :runtime
|
22
22
|
prerelease: false
|
23
23
|
version_requirements: !ruby/object:Gem::Requirement
|
24
24
|
requirements:
|
25
|
-
- -
|
25
|
+
- - ">="
|
26
26
|
- !ruby/object:Gem::Version
|
27
|
-
version: 0
|
27
|
+
version: '0'
|
28
28
|
- !ruby/object:Gem::Dependency
|
29
29
|
name: activeresource
|
30
30
|
requirement: !ruby/object:Gem::Requirement
|
31
31
|
requirements:
|
32
|
-
- -
|
32
|
+
- - ">="
|
33
33
|
- !ruby/object:Gem::Version
|
34
|
-
version: '
|
34
|
+
version: '0'
|
35
35
|
type: :runtime
|
36
36
|
prerelease: false
|
37
37
|
version_requirements: !ruby/object:Gem::Requirement
|
38
38
|
requirements:
|
39
|
-
- -
|
39
|
+
- - ">="
|
40
40
|
- !ruby/object:Gem::Version
|
41
|
-
version: '
|
41
|
+
version: '0'
|
42
42
|
- !ruby/object:Gem::Dependency
|
43
43
|
name: hirb
|
44
44
|
requirement: !ruby/object:Gem::Requirement
|
45
45
|
requirements:
|
46
|
-
- -
|
46
|
+
- - ">="
|
47
47
|
- !ruby/object:Gem::Version
|
48
|
-
version: '0
|
48
|
+
version: '0'
|
49
49
|
type: :runtime
|
50
50
|
prerelease: false
|
51
51
|
version_requirements: !ruby/object:Gem::Requirement
|
52
52
|
requirements:
|
53
|
-
- -
|
53
|
+
- - ">="
|
54
54
|
- !ruby/object:Gem::Version
|
55
|
-
version: '0
|
55
|
+
version: '0'
|
56
56
|
- !ruby/object:Gem::Dependency
|
57
57
|
name: sqlite3
|
58
58
|
requirement: !ruby/object:Gem::Requirement
|
59
59
|
requirements:
|
60
|
-
- -
|
60
|
+
- - ">="
|
61
61
|
- !ruby/object:Gem::Version
|
62
|
-
version:
|
62
|
+
version: '0'
|
63
63
|
type: :runtime
|
64
64
|
prerelease: false
|
65
65
|
version_requirements: !ruby/object:Gem::Requirement
|
66
66
|
requirements:
|
67
|
-
- -
|
67
|
+
- - ">="
|
68
68
|
- !ruby/object:Gem::Version
|
69
|
-
version:
|
69
|
+
version: '0'
|
70
70
|
- !ruby/object:Gem::Dependency
|
71
71
|
name: rspec
|
72
72
|
requirement: !ruby/object:Gem::Requirement
|
73
73
|
requirements:
|
74
|
-
- -
|
75
|
-
- !ruby/object:Gem::Version
|
76
|
-
version: '2.5'
|
77
|
-
type: :development
|
78
|
-
prerelease: false
|
79
|
-
version_requirements: !ruby/object:Gem::Requirement
|
80
|
-
requirements:
|
81
|
-
- - ~>
|
82
|
-
- !ruby/object:Gem::Version
|
83
|
-
version: '2.5'
|
84
|
-
- !ruby/object:Gem::Dependency
|
85
|
-
name: escoffier
|
86
|
-
requirement: !ruby/object:Gem::Requirement
|
87
|
-
requirements:
|
88
|
-
- - ! '>='
|
74
|
+
- - ">="
|
89
75
|
- !ruby/object:Gem::Version
|
90
76
|
version: '0'
|
91
77
|
type: :development
|
92
78
|
prerelease: false
|
93
79
|
version_requirements: !ruby/object:Gem::Requirement
|
94
80
|
requirements:
|
95
|
-
- -
|
81
|
+
- - ">="
|
96
82
|
- !ruby/object:Gem::Version
|
97
83
|
version: '0'
|
98
84
|
description: Extraction of MRI metadata.
|
@@ -106,8 +92,8 @@ executables:
|
|
106
92
|
extensions: []
|
107
93
|
extra_rdoc_files: []
|
108
94
|
files:
|
109
|
-
- .gitignore
|
110
|
-
- .rspec
|
95
|
+
- ".gitignore"
|
96
|
+
- ".rspec"
|
111
97
|
- Gemfile
|
112
98
|
- Manifest
|
113
99
|
- README.rdoc
|
@@ -158,17 +144,17 @@ require_paths:
|
|
158
144
|
- lib
|
159
145
|
required_ruby_version: !ruby/object:Gem::Requirement
|
160
146
|
requirements:
|
161
|
-
- -
|
147
|
+
- - ">="
|
162
148
|
- !ruby/object:Gem::Version
|
163
149
|
version: '0'
|
164
150
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
165
151
|
requirements:
|
166
|
-
- -
|
152
|
+
- - ">="
|
167
153
|
- !ruby/object:Gem::Version
|
168
154
|
version: '0'
|
169
155
|
requirements: []
|
170
156
|
rubyforge_project:
|
171
|
-
rubygems_version: 2.1
|
157
|
+
rubygems_version: 2.4.5.1
|
172
158
|
signing_key:
|
173
159
|
specification_version: 4
|
174
160
|
summary: MRI metadata
|