bioinform 0.3.0 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/lib/bioinform/data_models/pcm.rb +6 -1
- data/lib/bioinform/data_models/pm.rb +13 -5
- data/lib/bioinform/data_models/ppm.rb +4 -4
- data/lib/bioinform/data_models/pwm.rb +3 -2
- data/lib/bioinform/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 14f2fb7993dff9e7a405856ff0e44989e1fd4d1a
|
4
|
+
data.tar.gz: 268ceea6bb9741c463e30923c4a26b8a9a8092a3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: aa01a07bcf91915f1e562bd7a16a2d74f74334215ee9cdf7e9cbb0516fcf589e8c28731de319f5c8fb1b412e39a111aabc6b689a791257d35fe008ea1e54b777
|
7
|
+
data.tar.gz: 63c27498b5b1c8ca1954c2b950cf202480516e5b5aa534ca1c02f00e4e7e310d16db4ac4d2934e462c071b29be939b40a292fbd97ad7b57321d44933f7f87523
|
data/Gemfile.lock
CHANGED
@@ -29,7 +29,12 @@ module Bioinform
|
|
29
29
|
VALIDATOR = PM::VALIDATOR * PCM.count_validator(eps: 1.0e-4).make_strict
|
30
30
|
DIFFERENT_COUNTS_VALIDATOR = PM::VALIDATOR * PCM.count_validator(eps: nil).make_strict
|
31
31
|
|
32
|
-
|
32
|
+
|
33
|
+
def self.default_validator
|
34
|
+
PCM::VALIDATOR
|
35
|
+
end
|
36
|
+
|
37
|
+
def initialize(matrix, alphabet: NucleotideAlphabet, validator: default_validator)
|
33
38
|
super
|
34
39
|
# validator already checked count discrepancy. We store median count.
|
35
40
|
@count = matrix.map{|pos| pos.inject(0.0, &:+) }.sort[matrix.length / 2]
|
@@ -20,7 +20,7 @@ module Bioinform
|
|
20
20
|
}
|
21
21
|
|
22
22
|
attr_reader :matrix, :alphabet
|
23
|
-
def initialize(matrix, alphabet: NucleotideAlphabet, validator:
|
23
|
+
def initialize(matrix, alphabet: NucleotideAlphabet, validator: default_validator)
|
24
24
|
validation_results = validator.validate_params(matrix, alphabet)
|
25
25
|
unless validation_results.valid?
|
26
26
|
raise ValidationError.new('Invalid matrix.', validation_errors: validation_results)
|
@@ -29,15 +29,23 @@ module Bioinform
|
|
29
29
|
@alphabet = alphabet
|
30
30
|
end
|
31
31
|
|
32
|
-
def self.
|
32
|
+
def self.default_validator
|
33
|
+
PM::VALIDATOR
|
34
|
+
end
|
35
|
+
|
36
|
+
def default_validator
|
37
|
+
self.class.default_validator
|
38
|
+
end
|
39
|
+
|
40
|
+
def self.from_string(input, alphabet: NucleotideAlphabet, parser: DEFAULT_PARSER, validator: default_validator)
|
33
41
|
info = parser.parse!(input)
|
34
|
-
self.new(info[:matrix], alphabet: alphabet).named( info[:name] )
|
42
|
+
self.new(info[:matrix], alphabet: alphabet, validator: validator).named( info[:name] )
|
35
43
|
end
|
36
44
|
|
37
|
-
def self.from_file(filename, alphabet: NucleotideAlphabet, parser: DEFAULT_PARSER)
|
45
|
+
def self.from_file(filename, alphabet: NucleotideAlphabet, parser: DEFAULT_PARSER, validator: default_validator)
|
38
46
|
info = parser.parse!(File.read(filename))
|
39
47
|
name = (info[:name] && !info[:name].strip.empty?) ? info[:name] : File.basename(filename, File.extname(filename))
|
40
|
-
self.new(info[:matrix], alphabet: alphabet).named( name )
|
48
|
+
self.new(info[:matrix], alphabet: alphabet, validator: validator).named( name )
|
41
49
|
end
|
42
50
|
|
43
51
|
def length
|
@@ -7,6 +7,10 @@ module Bioinform
|
|
7
7
|
end
|
8
8
|
|
9
9
|
class PPM < PM
|
10
|
+
def self.default_validator
|
11
|
+
PPM::VALIDATOR
|
12
|
+
end
|
13
|
+
|
10
14
|
def self.probability_validator(eps: 1.0e-4)
|
11
15
|
Validator.new{|matrix, alphabet|
|
12
16
|
errors = []
|
@@ -26,10 +30,6 @@ module Bioinform
|
|
26
30
|
end
|
27
31
|
|
28
32
|
VALIDATOR = PM::VALIDATOR * PPM.probability_validator(eps: 1.0e-4).make_strict
|
29
|
-
|
30
|
-
def initialize(matrix, alphabet: NucleotideAlphabet, validator: PPM::VALIDATOR)
|
31
|
-
super # default validator redefined
|
32
|
-
end
|
33
33
|
end
|
34
34
|
end
|
35
35
|
end
|
@@ -8,8 +8,9 @@ module Bioinform
|
|
8
8
|
|
9
9
|
class PWM < PM
|
10
10
|
VALIDATOR = PM::VALIDATOR
|
11
|
-
|
12
|
-
|
11
|
+
|
12
|
+
def self.default_validator
|
13
|
+
PWM::VALIDATOR
|
13
14
|
end
|
14
15
|
|
15
16
|
def score(word)
|
data/lib/bioinform/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: bioinform
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ilya Vorontsov
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2016-04-
|
11
|
+
date: 2016-04-22 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: A bunch of useful classes for bioinformatics
|
14
14
|
email:
|