sylfy 0.0.2 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +2 -0
- data/Rakefile +13 -0
- data/lib/sylfy.rb +12 -25
- data/lib/sylfy/add.rb +10 -0
- data/lib/sylfy/add/bio_kegg_kgml.rb +108 -0
- data/lib/sylfy/datamodel.rb +141 -0
- data/lib/sylfy/feature.rb +128 -0
- data/lib/sylfy/mathf.rb +40 -0
- data/lib/sylfy/pattern.rb +14 -0
- data/lib/sylfy/service.rb +34 -0
- data/lib/sylfy/service/biocycrest.rb +41 -0
- data/lib/sylfy/service/cactusncirest.rb +64 -0
- data/lib/sylfy/service/cbioportal.rb +156 -0
- data/lib/sylfy/service/chembl.rb +106 -0
- data/lib/sylfy/service/ebisoap.rb +55 -0
- data/lib/sylfy/service/ensemblrest.rb +64 -0
- data/lib/sylfy/service/ensemblrest/archive.rb +35 -0
- data/lib/sylfy/service/ensemblrest/comparative.rb +146 -0
- data/lib/sylfy/service/ensemblrest/xrefs.rb +73 -0
- data/lib/sylfy/service/hgncrest.rb +52 -0
- data/lib/sylfy/service/keggrest.rb +6 -19
- data/lib/sylfy/service/keggrest/conv.rb +64 -40
- data/lib/sylfy/service/keggrest/find.rb +27 -48
- data/lib/sylfy/service/keggrest/get.rb +82 -0
- data/lib/sylfy/service/keggrest/link.rb +17 -37
- data/lib/sylfy/service/keggrest/list.rb +18 -50
- data/lib/sylfy/service/lipidmaprest.rb +228 -0
- data/lib/sylfy/service/pubchem.rb +71 -0
- data/lib/sylfy/service/pubchemrest.rb +249 -0
- data/lib/sylfy/service/rest.rb +26 -0
- data/lib/sylfy/service/soapwsdl.rb +78 -0
- data/lib/sylfy/service/unichemrest.rb +106 -0
- data/lib/sylfy/utils.rb +18 -0
- data/lib/sylfy/utils/keyhash.rb +1149 -0
- data/lib/sylfy/utils/reactionkey.rb +197 -0
- data/lib/sylfy/version.rb +1 -1
- data/sylfy.gemspec +11 -15
- data/test/test_kegg_rest.rb +58 -0
- data/test/test_reactionkey.rb +37 -0
- metadata +87 -15
- data/lib/sylfy/math.rb +0 -24
- data/lib/sylfy/service/keggrest/restKegg_get.rb +0 -130
@@ -0,0 +1,197 @@
|
|
1
|
+
#
|
2
|
+
# UniSysDB library in Ruby
|
3
|
+
# Copyright (C) 2012
|
4
|
+
#
|
5
|
+
# @author Natapol Pornputtapong <natapol@chalmers.se>
|
6
|
+
#
|
7
|
+
|
8
|
+
require 'sylfy/utils/keyhash'
|
9
|
+
|
10
|
+
class Array
|
11
|
+
def include_all?(array = [])
|
12
|
+
result = true
|
13
|
+
self_array = {}
|
14
|
+
self.each {|e| self_array[e.split(/;/)[0]] = e.split(/;/)[1] ? e.split(/;/)[1].to_f : 1.0}
|
15
|
+
|
16
|
+
array.each do |item|
|
17
|
+
if !self_array.has_key?(item.split(/;/)[0])
|
18
|
+
result = false
|
19
|
+
else
|
20
|
+
result = false if self_array[item] != item.split(/;/)[1].to_f
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
return result
|
25
|
+
end
|
26
|
+
|
27
|
+
def _key_version?
|
28
|
+
array = self.flatten.uniq
|
29
|
+
return array.length == 1 ? array[0] : "X"
|
30
|
+
end
|
31
|
+
|
32
|
+
def _key_cal_charge
|
33
|
+
charge = [0, 0]
|
34
|
+
self[0].each {|e| charge[0] += e.ord - 78}
|
35
|
+
self[1].each {|e| charge[1] += e.ord - 78}
|
36
|
+
return charge[0] == charge[1] ? "B" : "X"
|
37
|
+
end
|
38
|
+
|
39
|
+
def _key_cal_coef
|
40
|
+
sum = 0
|
41
|
+
self.flatten.each {|e| sum += e}
|
42
|
+
return sum.floor >= 26 ? "Z" : (sum.floor + 64).chr
|
43
|
+
end
|
44
|
+
|
45
|
+
def _key_include?(str)
|
46
|
+
result = false
|
47
|
+
self.each {|e| result = true if e.split(/;/)[0] == str.split(/;/)[0]}
|
48
|
+
return result
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
module Sylfy
|
53
|
+
|
54
|
+
module Utils
|
55
|
+
|
56
|
+
#COFACTORS = [
|
57
|
+
# ["FAD-FADH2", ["VWWQXMAJTJZDQX-UYBVJOGSSA-N"], ["YPZRHBJKEMOYQH-UYBVJOGSSA-N"], "B"],
|
58
|
+
# ["FMN-FMNH2", ["FVTCRASFADXXNN-SCRDCRAPSA-N"], ["YTNIXZGTHTVJBW-SCRDCRAPSA-N"], "C"],
|
59
|
+
# ["NAD-NADH", ["BAWFJGJZGIEFAR-NNYOXOHSSA-O"], ["BOPGDPNILDQYTO-NNYOXOHSSA-N"], "D"],
|
60
|
+
# ["NADP-NADPH", ["XJLXINKUBYWONI-NNYOXOHSSA-O"], ["ACFIXJIJDZMPPO-NNYOXOHSSA-N"], "E"]
|
61
|
+
#]
|
62
|
+
|
63
|
+
COFACTORS = []
|
64
|
+
|
65
|
+
PORTERS = []
|
66
|
+
|
67
|
+
|
68
|
+
def self.reactionkey(leftin, rightin, direction = nil)
|
69
|
+
|
70
|
+
#key[:first].push(item[0][0..13])
|
71
|
+
#key[:second].push(item[0][15..22])
|
72
|
+
#key[:flag].push(item[0][23])
|
73
|
+
#key[:ver].push(item[0][24])
|
74
|
+
#key[:indicator].push(item[0][26])
|
75
|
+
#
|
76
|
+
#AAAAAAAAAAAAAA-BBBBBBBBFV-P
|
77
|
+
#AAAAAAAAAAAAAA is the first hash block.
|
78
|
+
#It is a 14-character hash encoding the basic (Mobile-H) InChI layer, that is, molecular skeleton (connectivity).
|
79
|
+
#BBBBBBBB is the second hash block.
|
80
|
+
#It is an 8-character hash of the remaining layers (except for the "/p" segment, which accounts for added or removed protons and is not hashed at all; instead, the number of protons is indicated at the end of the InChIKey). In all cases, this block encodes stereochemistry and isotopic substitution information, associated with molecular connectivity expressed by the first block. In case of Non-standard InChI, it also encodes information on the exact position of tautomeric hydrogens (if any), as well as on the related stereo/isotopic data.
|
81
|
+
#F is a flag which indicates the kind of InChIKey.
|
82
|
+
#It is 'S' for Standard InChIKey (produced out of Standard InChI) and 'N' for Non-standard.
|
83
|
+
#V is an InChI version character.
|
84
|
+
#It is 'A' for version 1 ( 'B' is reserved for version 2, etc. ).
|
85
|
+
#P is a [de]protonation indicator.
|
86
|
+
#
|
87
|
+
#
|
88
|
+
# input InChIKey;coef
|
89
|
+
|
90
|
+
version = "A"
|
91
|
+
|
92
|
+
reverse_sign = {'<=' => '=>', '=>' => '<=', '<=>' => '<=>', '<?>' => '<?>'}
|
93
|
+
sign_symbol = {'<=' => 'B', '=>' => 'F', '<=>' => 'R', '<?>' => 'U'}
|
94
|
+
|
95
|
+
both = []
|
96
|
+
|
97
|
+
if direction && sign_symbol.keys.include?(direction) && leftin && rightin && !leftin.empty? && !rightin.empty? && leftin != rightin
|
98
|
+
|
99
|
+
left = leftin.dup
|
100
|
+
right = rightin.dup
|
101
|
+
|
102
|
+
cofactor_symbol = "A"
|
103
|
+
|
104
|
+
COFACTORS.each do |cofactor|
|
105
|
+
if left.include_all?(cofactor[1]) && right.include_all?(cofactor[2])
|
106
|
+
left.delete_if {|x| cofactor[1].include?(x.split(/;/)[0]) }
|
107
|
+
right.delete_if {|x| cofactor[2].include?(x.split(/;/)[0]) }
|
108
|
+
cofactor_symbol = cofactor[3]
|
109
|
+
elsif left.include_all?(cofactor[2]) && right.include_all?(cofactor[1])
|
110
|
+
left.delete_if {|x| cofactor[2].include?(x.split(/;/)[0]) }
|
111
|
+
right.delete_if {|x| cofactor[1].include?(x.split(/;/)[0]) }
|
112
|
+
cofactor_symbol = cofactor[3]
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
if (left.sort <=> right.sort) < 0
|
117
|
+
dsign = sign_symbol[direction]
|
118
|
+
both = [left.sort, right.sort]
|
119
|
+
else
|
120
|
+
dsign = sign_symbol[reverse_sign[direction]]
|
121
|
+
both = [right.sort, left.sort]
|
122
|
+
end
|
123
|
+
|
124
|
+
elsif leftin != rightin && ((leftin && !leftin.empty?) || (rightin && rightin.empty?))
|
125
|
+
left = leftin ? leftin.dup : []
|
126
|
+
right = rightin ? rightin.dup : []
|
127
|
+
|
128
|
+
cofactor_symbol = "Z"
|
129
|
+
|
130
|
+
PORTERS.each do |cofactor|
|
131
|
+
if left.include_all?(cofactor[1]) && right.include_all?(cofactor[2])
|
132
|
+
left.delete_if {|x| cofactor[1]._key_include?(x) }
|
133
|
+
right.delete_if {|x| cofactor[2]._key_include?(x) }
|
134
|
+
cofactor_symbol = cofactor[3]
|
135
|
+
elsif left.include_all?(cofactor[2]) && right.include_all?(cofactor[1])
|
136
|
+
left.delete_if {|x| cofactor[2]._key_include?(x) }
|
137
|
+
right.delete_if {|x| cofactor[1]._key_include?(x) }
|
138
|
+
cofactor_symbol = cofactor[3]
|
139
|
+
end
|
140
|
+
end
|
141
|
+
|
142
|
+
if (left.sort <=> right.sort) < 0
|
143
|
+
dsign = "A"
|
144
|
+
both = [left.sort, right.sort]
|
145
|
+
else
|
146
|
+
dsign = "Z"
|
147
|
+
both = [right.sort, left.sort]
|
148
|
+
end
|
149
|
+
else
|
150
|
+
return nil
|
151
|
+
end
|
152
|
+
|
153
|
+
|
154
|
+
code = {:first => [], :second => [], :flag => [], :ver => [], :charge => [], :coef => []}
|
155
|
+
both.each do |side|
|
156
|
+
part = {:first => [], :second => [], :flag => [], :ver => [], :charge => [], :coef => []}
|
157
|
+
side.each do |item|
|
158
|
+
part[:first].push(item[0..13])
|
159
|
+
part[:second].push(item[15..22])
|
160
|
+
part[:flag].push(item[23])
|
161
|
+
part[:ver].push(item[24])
|
162
|
+
part[:charge].push(item[26])
|
163
|
+
part[:coef].push(item.split(/;/)[1] ? item.split(/;/)[1].to_f : 1.0)
|
164
|
+
end
|
165
|
+
|
166
|
+
part.each_pair do |k, v|
|
167
|
+
code[k].push([:first, :second].include?(k) ? v.join('+') : v)
|
168
|
+
end
|
169
|
+
end
|
170
|
+
|
171
|
+
# construct code string
|
172
|
+
codeString = {}
|
173
|
+
codeString[:A] = Sylfy::Utils::Keyhash.key(code[:first].join('/'))
|
174
|
+
codeString[:B] = Sylfy::Utils::Keyhash.key(code[:second].join('/'), false)
|
175
|
+
codeString[:v] = code[:ver]._key_version?
|
176
|
+
codeString[:F] = codeString[:version] != "X" ? code[:flag]._key_version? : "X"
|
177
|
+
codeString[:H] = code[:charge]._key_cal_charge
|
178
|
+
codeString[:E] = code[:coef]._key_cal_coef
|
179
|
+
codeString[:CC] = "#{["A", "Z"].include?(dsign) ? "Z" : "A"}#{cofactor_symbol}"
|
180
|
+
|
181
|
+
# construct key AAAAAAAAAAAAAA-BBBBBBBBFvV-HE-CC-D
|
182
|
+
# A calculate from list of First part of InChIKey
|
183
|
+
# B calculate from list of Second part of InChIKey
|
184
|
+
# F Flag S for standard X for not
|
185
|
+
# E sum of co-efficient
|
186
|
+
# H charge B for balance and X for not
|
187
|
+
# C indicate cofactor code
|
188
|
+
# v indicate version of InChIKey
|
189
|
+
# V indicate version of this key function
|
190
|
+
# D indicate direction
|
191
|
+
# return "#{codeString[:A]}-#{codeString[:B]}#{codeString[:F]}#{codeString[:v]}#{version}-#{codeString[:H]}#{codeString[:E]}-#{codeString[:CC]}-#{dsign}"
|
192
|
+
return "#{codeString[:A]}-#{codeString[:B]}#{codeString[:F]}#{codeString[:v]}#{version}-#{codeString[:H]}#{codeString[:E]}-#{dsign}"
|
193
|
+
end
|
194
|
+
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
data/lib/sylfy/version.rb
CHANGED
data/sylfy.gemspec
CHANGED
@@ -5,7 +5,7 @@ require "sylfy/version"
|
|
5
5
|
Gem::Specification.new do |s|
|
6
6
|
s.name = 'sylfy'
|
7
7
|
s.version = Sylfy::VERSION
|
8
|
-
s.date = '
|
8
|
+
s.date = '2014-07-03'
|
9
9
|
s.platform = Gem::Platform::RUBY
|
10
10
|
|
11
11
|
s.summary = "Provides some useful functions for systems biology field."
|
@@ -16,24 +16,20 @@ Gem::Specification.new do |s|
|
|
16
16
|
s.homepage = 'http://rubygems.org/gems/sylfy'
|
17
17
|
s.license = 'GPL'
|
18
18
|
|
19
|
-
# s.rubyforge_project = "
|
19
|
+
# s.rubyforge_project = ""
|
20
20
|
|
21
21
|
s.files = `git ls-files`.split("\n")
|
22
22
|
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
|
23
23
|
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
24
24
|
s.require_paths = ["lib"]
|
25
25
|
|
26
|
-
s.add_dependency "gsl", "
|
27
|
-
s.add_dependency "bio", "
|
26
|
+
s.add_dependency "rb-gsl", "~> 1.16"
|
27
|
+
s.add_dependency "bio", "~> 1.4"
|
28
|
+
s.add_dependency "savon", "~> 2.0"
|
29
|
+
s.add_dependency "statsample", "~> 1.0"
|
30
|
+
s.add_dependency "rubabel", "~> 0.4"
|
28
31
|
|
29
|
-
# s.add_development_dependency "rspec", "
|
30
|
-
# s.
|
31
|
-
|
32
|
-
|
33
|
-
# s.add_dependency "httpclient", ">= 2.3.3"
|
34
|
-
# s.add_dependency "rake", ">= 0.8.7"
|
35
|
-
# s.add_dependency "json", ">= 1.7.7"
|
36
|
-
# s.add_dependency "os", ">= 0.9.6"
|
37
|
-
# s.add_dependency "rubyzip", ">= 0.9.7"
|
38
|
-
# s.add_dependency "multi_json", ">= 1.3.2"
|
39
|
-
end
|
32
|
+
# s.add_development_dependency "rspec", "~> 2.11"
|
33
|
+
# s.add_dependency "httpclient", "~> 2.3.3"
|
34
|
+
|
35
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
require "./lib/sylfy.rb"
|
2
|
+
require "test/unit"
|
3
|
+
|
4
|
+
|
5
|
+
class TestKEGGREST < Test::Unit::TestCase
|
6
|
+
|
7
|
+
def test_list
|
8
|
+
assert_nothing_thrown("pathway") {Sylfy::Service::KEGGREST::list("pathway")}
|
9
|
+
assert_nothing_thrown("pathway/hsa") {Sylfy::Service::KEGGREST::list("pathway/hsa")}
|
10
|
+
assert_nothing_thrown("organism") {Sylfy::Service::KEGGREST::list("organism")}
|
11
|
+
assert_nothing_thrown("hsa") {Sylfy::Service::KEGGREST::list("hsa")}
|
12
|
+
assert_nothing_thrown("T01001") {Sylfy::Service::KEGGREST::list("T01001")}
|
13
|
+
assert_nothing_thrown("hsa:10458+ece:Z5100") {Sylfy::Service::KEGGREST::list("hsa:10458+ece:Z5100")}
|
14
|
+
assert_nothing_thrown("cpd:C01290+gl:G00092") {Sylfy::Service::KEGGREST::list("cpd:C01290+gl:G00092")}
|
15
|
+
assert_nothing_thrown("C01290+G00092") {Sylfy::Service::KEGGREST::list("C01290+G00092")}
|
16
|
+
end
|
17
|
+
|
18
|
+
def test_find
|
19
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("genes", "shiga+toxin")}
|
20
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("genes", '"shiga toxin"')}
|
21
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("compound", "C7H10O5", "formula")}
|
22
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("compound", "O5C7", "formula")}
|
23
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("compound", "174.05", "exact_mass")}
|
24
|
+
assert_nothing_thrown("") {Sylfy::Service::KEGGREST::find("compound", "300-310", "mol_weight")}
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_get
|
28
|
+
assert_nothing_thrown("cpd:C01290+gl:G00092 ") {Sylfy::Service::KEGGREST::get("cpd:C01290+gl:G00092")}
|
29
|
+
assert_nothing_thrown("C01290+G00092") {Sylfy::Service::KEGGREST::get("C01290+G00092")}
|
30
|
+
assert_nothing_thrown("hsa:10458+ece:Z5100") {Sylfy::Service::KEGGREST::get("hsa:10458+ece:Z5100")}
|
31
|
+
assert_nothing_thrown("hsa:10458+ece:Z5100/aaseq") {Sylfy::Service::KEGGREST::get("hsa:10458+ece:Z5100", "aaseq")}
|
32
|
+
assert_nothing_thrown("hsa05130/kgml") {Sylfy::Service::KEGGREST::get("hsa05130", "kgml")}
|
33
|
+
end
|
34
|
+
|
35
|
+
def test_conv
|
36
|
+
assert_nothing_thrown("eco/ncbi-geneid") {Sylfy::Service::KEGGREST::conv("eco", "ncbi-geneid")}
|
37
|
+
assert_nothing_thrown("ncbi-geneid/eco") {Sylfy::Service::KEGGREST::conv("ncbi-geneid", "eco")}
|
38
|
+
assert_nothing_thrown("ncbi-gi/hsa:10458+ece:Z5100") {Sylfy::Service::KEGGREST::conv("ncbi-gi", "hsa:10458+ece:Z5100")}
|
39
|
+
assert_nothing_thrown("genes/ncbi-gi:3113320") {Sylfy::Service::KEGGREST::conv("genes", "ncbi-gi:3113320")}
|
40
|
+
end
|
41
|
+
|
42
|
+
def test_link
|
43
|
+
assert_nothing_thrown("pathway/hsa") {Sylfy::Service::KEGGREST::link("pathway", "hsa")}
|
44
|
+
assert_nothing_thrown("hsa/pathway") {Sylfy::Service::KEGGREST::link("hsa", "pathway")}
|
45
|
+
assert_nothing_thrown("pathway/hsa:10458+ece:Z5100") {Sylfy::Service::KEGGREST::link("pathway", "hsa:10458+ece:Z5100")}
|
46
|
+
assert_nothing_thrown("genes/K00500") {Sylfy::Service::KEGGREST::link("genes", "K00500")}
|
47
|
+
assert_nothing_thrown("genes/hsa00010") {Sylfy::Service::KEGGREST::link("genes", "hsa00010")}
|
48
|
+
assert_nothing_thrown("hsa/hsa00010") {Sylfy::Service::KEGGREST::link("hsa", "hsa00010")}
|
49
|
+
assert_nothing_thrown("ko/map00010") {Sylfy::Service::KEGGREST::link("ko", "map00010")}
|
50
|
+
assert_nothing_thrown("ko/ko00010") {Sylfy::Service::KEGGREST::link("ko", "ko00010")}
|
51
|
+
assert_nothing_thrown("rn/map00010") {Sylfy::Service::KEGGREST::link("rn", "map00010")}
|
52
|
+
assert_nothing_thrown("rn/rn00010") {Sylfy::Service::KEGGREST::link("rn", "rn00010")}
|
53
|
+
assert_nothing_thrown("ec/map00010") {Sylfy::Service::KEGGREST::link("ec", "map00010")}
|
54
|
+
assert_nothing_thrown("ec/ec00010") {Sylfy::Service::KEGGREST::link("ec", "ec00010")}
|
55
|
+
assert_nothing_thrown("cpd/map00010") {Sylfy::Service::KEGGREST::link("cpd", "map00010")}
|
56
|
+
end
|
57
|
+
|
58
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
require "./lib/sylfy.rb"
|
2
|
+
require "test/unit"
|
3
|
+
|
4
|
+
class TestReactionKey < Test::Unit::TestCase
|
5
|
+
def test_reactionkey
|
6
|
+
a = ['MEFKEPWMEQBLKI-AIRLBKTGSA-O', 'QAIPRVGONGVQAS-DUXPYHPUSA-M;2.0']
|
7
|
+
b = ['ZJUKTBDSGOFHSH-WFMPWKQPSA-N', 'KSEBMYQBYZTDHS-HWKANZROSA-M', 'GPRLSGONYQIRFK-UHFFFAOYSA-N']
|
8
|
+
|
9
|
+
c = ['MEFKEPWMEQBLKI-AIRLBKTGSA-O', 'QAIPRVGONGVQAS-DUXPYHPUSA-M;2.0', "VWWQXMAJTJZDQX-UYBVJOGSSA-N"]
|
10
|
+
d = ['ZJUKTBDSGOFHSH-WFMPWKQPSA-N', 'KSEBMYQBYZTDHS-HWKANZROSA-M', 'GPRLSGONYQIRFK-UHFFFAOYSA-N', "YPZRHBJKEMOYQH-UYBVJOGSSA-N"]
|
11
|
+
|
12
|
+
assert_equal(Sylfy::Utils::reactionkey(b, a, "<="), Sylfy::Utils::reactionkey(a, b, "=>"))
|
13
|
+
assert_equal(Sylfy::Utils::reactionkey(b, a, "<=>"), Sylfy::Utils::reactionkey(a, b, "<=>"))
|
14
|
+
assert_equal(Sylfy::Utils::reactionkey(b, a, "<?>"), Sylfy::Utils::reactionkey(a, b, "<?>"))
|
15
|
+
|
16
|
+
assert_equal("#{Sylfy::Utils::reactionkey(a, b, "<=")[0..-2]}B", Sylfy::Utils::reactionkey(a, b, "=>"))
|
17
|
+
assert_equal("#{Sylfy::Utils::reactionkey(a, b, "<=")[0..-2]}F", Sylfy::Utils::reactionkey(a, b, "<="))
|
18
|
+
assert_equal("#{Sylfy::Utils::reactionkey(a, b, "<=")[0..-2]}R", Sylfy::Utils::reactionkey(a, b, "<=>"))
|
19
|
+
assert_equal("#{Sylfy::Utils::reactionkey(a, b, "<=")[0..-2]}U", Sylfy::Utils::reactionkey(a, b, "<?>"))
|
20
|
+
|
21
|
+
assert_equal(Sylfy::Utils::reactionkey(d, c, "<="), Sylfy::Utils::reactionkey(c, d, "=>"))
|
22
|
+
assert_equal(Sylfy::Utils::reactionkey(d, c, "<=>"), Sylfy::Utils::reactionkey(c, d, "<=>"))
|
23
|
+
assert_equal(Sylfy::Utils::reactionkey(d, c, "<?>"), Sylfy::Utils::reactionkey(c, d, "<?>"))
|
24
|
+
assert_equal("#{Sylfy::Utils::reactionkey(c, d, "<=")[0..-2]}B", Sylfy::Utils::reactionkey(c, d, "=>"))
|
25
|
+
assert_equal("#{Sylfy::Utils::reactionkey(c, d, "<=")[0..-2]}F", Sylfy::Utils::reactionkey(c, d, "<="))
|
26
|
+
assert_equal("#{Sylfy::Utils::reactionkey(c, d, "<=")[0..-2]}R", Sylfy::Utils::reactionkey(c, d, "<=>"))
|
27
|
+
assert_equal("#{Sylfy::Utils::reactionkey(c, d, "<=")[0..-2]}U", Sylfy::Utils::reactionkey(c, d, "<?>"))
|
28
|
+
|
29
|
+
assert_not_equal(Sylfy::Utils::reactionkey(a, d, "<?>"), Sylfy::Utils::reactionkey(c, d, "<?>"))
|
30
|
+
assert_not_equal(Sylfy::Utils::reactionkey(c, b, "<?>"), Sylfy::Utils::reactionkey(c, d, "<?>"))
|
31
|
+
|
32
|
+
assert_equal(Sylfy::Utils::reactionkey(b.shuffle, a.shuffle, "=>"), Sylfy::Utils::reactionkey(b, a, "=>"))
|
33
|
+
|
34
|
+
#assert_equal("RBBGYPGMOGQICO-ANDFYIIK-PRHFFSIG-AB-A-B", Sylfy::Utils::reactionkey(c, d, "=>"))
|
35
|
+
#assert_equal("RBBGYPGMOGQICO-ANDFYIIK-PRHFFSIG-AA-A-B", Sylfy::Utils::reactionkey(a, b, "=>"))
|
36
|
+
end
|
37
|
+
end
|
metadata
CHANGED
@@ -1,43 +1,85 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sylfy
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
4
|
+
version: 0.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Natapol Pornputtapong
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2014-07-03 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
|
-
name: gsl
|
14
|
+
name: rb-gsl
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- -
|
17
|
+
- - ~>
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: 1.
|
19
|
+
version: '1.16'
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- -
|
24
|
+
- - ~>
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: 1.
|
26
|
+
version: '1.16'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: bio
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- -
|
31
|
+
- - ~>
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: 1.4
|
33
|
+
version: '1.4'
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- -
|
38
|
+
- - ~>
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: 1.4
|
40
|
+
version: '1.4'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: savon
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ~>
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '2.0'
|
48
|
+
type: :runtime
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ~>
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '2.0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: statsample
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ~>
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '1.0'
|
62
|
+
type: :runtime
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ~>
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '1.0'
|
69
|
+
- !ruby/object:Gem::Dependency
|
70
|
+
name: rubabel
|
71
|
+
requirement: !ruby/object:Gem::Requirement
|
72
|
+
requirements:
|
73
|
+
- - ~>
|
74
|
+
- !ruby/object:Gem::Version
|
75
|
+
version: '0.4'
|
76
|
+
type: :runtime
|
77
|
+
prerelease: false
|
78
|
+
version_requirements: !ruby/object:Gem::Requirement
|
79
|
+
requirements:
|
80
|
+
- - ~>
|
81
|
+
- !ruby/object:Gem::Version
|
82
|
+
version: '0.4'
|
41
83
|
description: Systems Biology Library for Ruby
|
42
84
|
email: natapol.por@gmail.com
|
43
85
|
executables: []
|
@@ -45,16 +87,44 @@ extensions: []
|
|
45
87
|
extra_rdoc_files: []
|
46
88
|
files:
|
47
89
|
- README.md
|
90
|
+
- Rakefile
|
48
91
|
- lib/sylfy.rb
|
49
|
-
- lib/sylfy/
|
92
|
+
- lib/sylfy/add.rb
|
93
|
+
- lib/sylfy/add/bio_kegg_kgml.rb
|
94
|
+
- lib/sylfy/datamodel.rb
|
95
|
+
- lib/sylfy/feature.rb
|
96
|
+
- lib/sylfy/mathf.rb
|
97
|
+
- lib/sylfy/pattern.rb
|
98
|
+
- lib/sylfy/service.rb
|
99
|
+
- lib/sylfy/service/biocycrest.rb
|
100
|
+
- lib/sylfy/service/cactusncirest.rb
|
101
|
+
- lib/sylfy/service/cbioportal.rb
|
102
|
+
- lib/sylfy/service/chembl.rb
|
103
|
+
- lib/sylfy/service/ebisoap.rb
|
104
|
+
- lib/sylfy/service/ensemblrest.rb
|
105
|
+
- lib/sylfy/service/ensemblrest/archive.rb
|
106
|
+
- lib/sylfy/service/ensemblrest/comparative.rb
|
107
|
+
- lib/sylfy/service/ensemblrest/xrefs.rb
|
108
|
+
- lib/sylfy/service/hgncrest.rb
|
50
109
|
- lib/sylfy/service/keggrest.rb
|
51
110
|
- lib/sylfy/service/keggrest/conv.rb
|
52
111
|
- lib/sylfy/service/keggrest/find.rb
|
112
|
+
- lib/sylfy/service/keggrest/get.rb
|
53
113
|
- lib/sylfy/service/keggrest/link.rb
|
54
114
|
- lib/sylfy/service/keggrest/list.rb
|
55
|
-
- lib/sylfy/service/
|
115
|
+
- lib/sylfy/service/lipidmaprest.rb
|
116
|
+
- lib/sylfy/service/pubchem.rb
|
117
|
+
- lib/sylfy/service/pubchemrest.rb
|
118
|
+
- lib/sylfy/service/rest.rb
|
119
|
+
- lib/sylfy/service/soapwsdl.rb
|
120
|
+
- lib/sylfy/service/unichemrest.rb
|
121
|
+
- lib/sylfy/utils.rb
|
122
|
+
- lib/sylfy/utils/keyhash.rb
|
123
|
+
- lib/sylfy/utils/reactionkey.rb
|
56
124
|
- lib/sylfy/version.rb
|
57
125
|
- sylfy.gemspec
|
126
|
+
- test/test_kegg_rest.rb
|
127
|
+
- test/test_reactionkey.rb
|
58
128
|
homepage: http://rubygems.org/gems/sylfy
|
59
129
|
licenses:
|
60
130
|
- GPL
|
@@ -75,8 +145,10 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
75
145
|
version: '0'
|
76
146
|
requirements: []
|
77
147
|
rubyforge_project:
|
78
|
-
rubygems_version: 2.0.
|
148
|
+
rubygems_version: 2.0.14.1
|
79
149
|
signing_key:
|
80
150
|
specification_version: 4
|
81
151
|
summary: Provides some useful functions for systems biology field.
|
82
|
-
test_files:
|
152
|
+
test_files:
|
153
|
+
- test/test_kegg_rest.rb
|
154
|
+
- test/test_reactionkey.rb
|