bioinform 0.3.0 → 0.3.2
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 +5 -5
- data/Gemfile.lock +2 -2
- data/lib/bioinform/data_models/named_model.rb +2 -2
- 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 +6 -7
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
|
-
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
2
|
+
SHA256:
|
|
3
|
+
metadata.gz: 815bb48e1022dbcf03e50fd8fe9ea2aebde5af49982a6dd724dd8076b6f8feb2
|
|
4
|
+
data.tar.gz: 2763d993767d26629452e4b1249005ac9a1fd2a2e7ea2144bad6fb64c1f4db01
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: f2c27432312380b2595e42560e9edcf37d78790a06f8f4ebd4524e464fc2a2a50856b1c81935d921b8e240d1c914d737acb3baabdbf24f37cb84c77e991c2084
|
|
7
|
+
data.tar.gz: c6d1a75d09883d8cef6c1cec3a1aa2df635b02bcc86b7dea3d633e32f69649e3a0a324e0edde779c0dd30e541a4ea7017d74b30e16491e0b0d1c437c77adfd7f
|
data/Gemfile.lock
CHANGED
|
@@ -16,8 +16,8 @@ module Bioinform
|
|
|
16
16
|
|
|
17
17
|
private :motif_klasses, :motif?
|
|
18
18
|
|
|
19
|
-
def method_missing(meth, *args, &block)
|
|
20
|
-
result = model.public_send(meth, *args, &block)
|
|
19
|
+
def method_missing(meth, *args, **kwargs, &block)
|
|
20
|
+
result = model.public_send(meth, *args, **kwargs, &block)
|
|
21
21
|
if motif?(result) && ! result.is_a?(self.class)
|
|
22
22
|
self.class.new(result, name)
|
|
23
23
|
else
|
|
@@ -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.2
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Ilya Vorontsov
|
|
8
|
-
autorequire:
|
|
8
|
+
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date:
|
|
11
|
+
date: 2026-01-02 00:00:00.000000000 Z
|
|
12
12
|
dependencies: []
|
|
13
13
|
description: A bunch of useful classes for bioinformatics
|
|
14
14
|
email:
|
|
@@ -106,7 +106,7 @@ files:
|
|
|
106
106
|
homepage: ''
|
|
107
107
|
licenses: []
|
|
108
108
|
metadata: {}
|
|
109
|
-
post_install_message:
|
|
109
|
+
post_install_message:
|
|
110
110
|
rdoc_options: []
|
|
111
111
|
require_paths:
|
|
112
112
|
- lib
|
|
@@ -121,9 +121,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
121
121
|
- !ruby/object:Gem::Version
|
|
122
122
|
version: '0'
|
|
123
123
|
requirements: []
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
signing_key:
|
|
124
|
+
rubygems_version: 3.2.33
|
|
125
|
+
signing_key:
|
|
127
126
|
specification_version: 4
|
|
128
127
|
summary: Classes for work with different input formats of positional matrices and
|
|
129
128
|
IUPAC-words and making simple transform and statistics with them. Also module includes
|