egor 0.0.5 → 0.9.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,36 +1,38 @@
1
- == 0.0.5 2009-1-23
1
+ == 0.9.0 13/2/2009
2
2
 
3
- * 4 major enhancement:
4
- * Egor warns if your sigma value is too big for any amino acid count (minimum ratio of amino acid count to sigma value: 500.0)
5
- * --augosigma option was added to avoid excessive influence of backgournd frequencies
6
- * a bug in p2 probabilty calculation of the partial smoothing procedure was fixed
7
- * a bug in total probability/log odds ratio calculation was fixed
3
+ * Added --heatmap option for heat map generation from substitution tables
4
+ * Added --heatmap-format option for heat map figure format (PNG, GIF, JPG, BMP, and PDF)
5
+ * Added --heatmap-stem option to set a file name of total heat maps figure when --heatmap 1 or 2 is set
6
+ * Added --heatmap-columns option to set the number of tables in a row when --heatmap 1 or 2 is set
7
+ * Added --heatmap-values option to print values in the cells of heat maps
8
+ * Renamed --noround option to --noroundoff
9
+ * 'simple_memoize' RubyGem package is no longer required
8
10
 
9
- * 4 minor enhancement:
10
- * --noround option was added to get original log odds ratios
11
- * --p1smooth option was added to enable p1 probability smoothing when partial smoothing
12
- * default verbosity has been changed from ERROR to WARN
13
- * codes were refactored to be more human readable and DRY
11
+ == 0.0.5 23/1/2009
14
12
 
15
- == 0.0.4 2008-12-15
13
+ * Warns if your sigma value is too big for any amino acid count (minimum ratio of amino acid count to sigma value: 500.0)
14
+ * Added --augosigma option to avoid excessive influence of background frequencies
15
+ * Added --noround option was added to get original log odds ratios
16
+ * Added --p1smooth option was added to enable p1 probability smoothing when partial smoothing
17
+ * Fixed a bug in p2 probability calculation of the partial smoothing procedure
18
+ * Fixed a bug in total probability/log odds ratio calculation
19
+ * Changed default verbosity from ERROR to WARN
20
+ * Refactored codes to be more human readable and DRY
16
21
 
17
- * 2 major enhancement:
18
- * log-odds ratio matrices can be generated with --nosmooth option
19
- * safe handling for zero observations or mutations of amino acids
22
+ == 0.0.4 15/12/2008
20
23
 
21
- == 0.0.3 2008-12-09
24
+ * Fixed a bug to generated log-odds ratio matrices with --nosmooth option
25
+ * Copes with no observations or mutations
22
26
 
23
- * 2 major enhancement:
24
- * An option '--cys (-j) 2' added not to distinguish J from C, so 'disulphide bond' environment feature is not prerequisite
25
- * Masking works for target amino acid, too
27
+ == 0.0.3 09/12/2008
26
28
 
27
- == 0.0.2 2008-11-13
29
+ * Added --cys (-j) 2 not to distinguish J from C, so 'disulphide bond' environment feature is not prerequisite
30
+ * Fixed a bug to make masking works for target amino acid, too
28
31
 
29
- * 2 major enhancement:
30
- * Constrained environment features are properly handled
31
- * Sane log-odds ratio matrices are produced
32
+ == 0.0.2 13/11/2008
32
33
 
33
- == 0.0.1 2008-11-07
34
+ * Supports user provided constrained environment features are properly handled
34
35
 
35
- * 1 major enhancement:
36
- * Initial release
36
+ == 0.0.1 07/11/2008
37
+
38
+ * Initial release
@@ -9,24 +9,28 @@ config/website.yml.sample
9
9
  egor.gemspec
10
10
  lib/egor.rb
11
11
  lib/egor/cli.rb
12
- lib/enumerable_extensions.rb
13
- lib/environment.rb
14
- lib/environment_class_hash.rb
15
- lib/environment_feature.rb
16
- lib/environment_feature_array.rb
12
+ lib/egor/environment.rb
13
+ lib/egor/environment_class_hash.rb
14
+ lib/egor/environment_feature.rb
15
+ lib/egor/environment_feature_array.rb
16
+ lib/egor/heatmap_array.rb
17
17
  lib/math_extensions.rb
18
18
  lib/narray_extensions.rb
19
19
  lib/nmatrix_extensions.rb
20
+ lib/string_extensions.rb
20
21
  script/console
21
22
  script/destroy
22
23
  script/generate
23
24
  script/txt2html
25
+ test/egor/test_cli.rb
26
+ test/egor/test_environment_class_hash.rb
27
+ test/egor/test_environment_feature.rb
24
28
  test/test_egor.rb
25
- test/test_egor_cli.rb
26
- test/test_enumerable_extensions.rb
27
- test/test_environment_feature.rb
28
29
  test/test_helper.rb
30
+ test/test_math_extensions.rb
31
+ test/test_narray_extensions.rb
29
32
  test/test_nmatrix_extensions.rb
33
+ test/test_string_extensions.rb
30
34
  website/index.html
31
35
  website/index.txt
32
36
  website/javascripts/rounded_corners_lite.inc.js
@@ -1,102 +1,254 @@
1
1
  = egor
2
2
 
3
- * http://egor.rubyforge.org
3
+ http://www-cryst.bioc.cam.ac.uk/egor
4
4
 
5
5
 
6
- == DESCRIPTION:
6
+ == Description
7
7
 
8
- egor: Esst GeneratOR, a program for calculating environment-specific substitution tables
8
+ 'egor' is a program for calculating environment-specific substitution tables from user providing environmental class definitions and sequence alignments with the annotations of the environment classes.
9
9
 
10
10
 
11
- == FEATURES/PROBLEMS:
11
+ == Features
12
12
 
13
- * No more segmentation fault
14
- * Fast enough not to leave your place
15
- * Slow enough to check your emails or have some chats with your colleagues next you
16
- * Full smoothing supported
17
- * In theory, infinite number of environment features can be handled
13
+ * Environment-specific substitution table generation based on user providing environmental class definition
14
+ * Entropy-based smoothing procedures to cope with sparse data problem
15
+ * BLOSUM-like weighting procedures using PID threshold
16
+ * Heat Map generation for substitution tables
18
17
 
19
18
 
20
- == INSTALL:
19
+ == Requirements
21
20
 
22
- $ sudo gem install egor
21
+ * ruby 1.8.7 or above (http://www.ruby-lang.org)
22
+ * rubygems 1.2.0 or above (http://rubyforge.org/projects/rubygems)
23
+
24
+ Following RubyGems will be automatically installed if you have rubygems installed on your machine
25
+
26
+ * narray (http://narray.rubyforge.org)
27
+ * facets (http://facets.rubyforge.org)
28
+ * bio (http://bioruby.open-bio.org)
29
+ * RMagick (http://rmagick.rubyforge.org)
30
+
31
+
32
+ == Installation
33
+
34
+ ~user $ sudo gem install egor
23
35
 
24
36
 
25
- == BASIC USAGE:
37
+ == Basic Usage
26
38
 
27
- $ egor -l TEMLIST-file -c classdef.dat
28
- or
29
- $ egor -f TEM-file -c classdef.dat
39
+ It's pretty much the same as Kenji's subst (http://www-cryst.bioc.cam.ac.uk/~kenji/subst/), so in most cases, you can swap 'subst' with 'egor'.
30
40
 
41
+ ~user $ egor -l TEMLIST-file -c classdef.dat
42
+ or
43
+ ~user $ egor -f TEM-file -c classdef.dat
31
44
 
32
- == OPTIONS:
45
+
46
+ == Options
33
47
  --tem-file (-f) FILE: a tem file
34
48
  --tem-list (-l) FILE: a list for tem files
35
49
  --classdef (-c) FILE: a file for the defintion of environments (default: 'classdef.dat')
36
50
  --outfile (-o) FILE: output filename (default 'allmat.dat')
37
51
  --weight (-w) INTEGER: clustering level (PID) for the BLOSUM-like weighting (default: 60)
38
- --noweight: calculate substitution counts with no weights
52
+ --noweight: calculate substitution count with no weights
39
53
  --smooth (-s) INTEGER:
40
- 0 for parial smoothing (default)
54
+ 0 for partial smoothing (default)
41
55
  1 for full smoothing
56
+ --p1smooth: perform smoothing for p1 probability calculation when partial smoothing
42
57
  --nosmooth: perform no smoothing operation
43
58
  --cys (-y) INTEGER:
44
59
  0 for using C and J only for structure (default)
45
60
  1 for both structure and sequence
46
- 2 for using only C for both
61
+ 2 for using only C for both (must be set when you have no 'disulphide' or 'disulfide' annotation in templates)
47
62
  --output INTEGER:
48
- 0 for raw counts (no-smoothing performed)
63
+ 0 for raw count (no smoothing performed)
49
64
  1 for probabilities
50
- 2 for log-odds (default)
51
- --scale INTEGER: log-odds matrices in 1/n bit units (default 3)
52
- --sigma DOUBLE: change the sigma value for smoothing (default 5)
53
- --add DOUBLE: add this value to raw counts when deriving log-odds without smoothing (default 1/=classes)
54
- --penv: use environment-dependent frequencies for log-odds calculation (default false) (NOT implemented yet!!!)
65
+ 2 for log odds ratios (default)
66
+ --noroundoff: do not round off log odds ratio
67
+ --scale INTEGER: log odds ratio matrices in 1/n bit units (default 3)
68
+ --sigma DOUBLE: change the sigma value for smoothing (default 5.0)
69
+ --autosigma: automatically adjust the sigma value for smoothing
70
+ --add DOUBLE: add this value to raw count when deriving log odds ratios without smoothing (default 1/#classes)
55
71
  --pidmin DOUBLE: count substitutions only for pairs with PID equal to or greater than this value (default none)
56
72
  --pidmax DOUBLE: count substitutions only for pairs with PID smaller than this value (default none)
73
+ --heatmap INTEGER:
74
+ 0 create a heat map file for each substitution table
75
+ 1 create one big file containing all heat maps from substitution tables
76
+ 2 do both 0 and 1
77
+ --heatmap-format INTEGER:
78
+ 0 for Portable Network Graphics (PNG) Format (default)
79
+ 1 for Graphics Interchange Format (GIF)
80
+ 2 for Joint Photographic Experts Group (JPEG) Format
81
+ 3 for Microsoft Windows bitmap (BMP) Format
82
+ 4 for Portable Document Format (PDF)
83
+ --heatmap-columns INTEGER: number of tables to print in a row when --heatmap 1 or 2 set (default: sqrt(no. of tables))
84
+ --heatmap-stem STRING: stem for a file name when --heatmap 1 or 2 set (default: 'heatmap')
85
+ --heatmap-values: print values in the cells when generating heat maps
57
86
  --verbose (-v) INTEGER
58
- 0 for ERROR level (default)
59
- 1 for WARN or above level
87
+ 0 for ERROR level
88
+ 1 for WARN or above level (default)
60
89
  2 for INFO or above level
61
90
  3 for DEBUG or above level
62
91
  --version: print version
63
92
  --help (-h): show help
64
93
 
65
94
 
66
- == REQUIREMENTS:
95
+ == Usage
96
+
97
+ 1. Prepare an environmental class definition file. For more details, please check this notes (http://www-cryst.bioc.cam.ac.uk/~kenji/subst/NOTES).
98
+
99
+ ~user $ cat classdef.dat
100
+ #
101
+ # name of feature (string); values adopted in .tem file (string); class labels assigned for each value (string);
102
+ # constrained or not (T or F); silent (used as masks)? (T or F)
103
+ #
104
+ secondary structure and phi angle;HEPC;HEPC;T;F
105
+ solvent accessibility;TF;Aa;F;F
106
+
107
+ 2. Prepare structural alignments and their annotations of above environmental classes in PIR format.
108
+
109
+ ~user $ cat sample1.tem
110
+ >P1;1mnma
111
+ sequence
112
+ QKERRKIEIKFIENKTRRHVTFSKRKHGIMKKAFELSVLTGTQVLLLVVSETGLVYTFSTPKFEPIVTQQEGRNL
113
+ IQACLNAPDD*
114
+ >P1;1egwa
115
+ sequence
116
+ --GRKKIQITRIMDERNRQVTFTKRKFGLMKKAYELSVLCDCEIALIIFNSSNKLFQYASTDMDKVLLKYTEY--
117
+ ----------*
118
+ >P1;1mnma
119
+ secondary structure and phi angle
120
+ CPCCCCCCCCCCCCHHHHHHHHHHHHHHHHHHHHHHHHHHPCCCEEEEECCCPCEEEEECCCCCHHHHCHHHHHH
121
+ HHHHHCCCCP*
122
+ >P1;1egwa
123
+ secondary structure and phi angle
124
+ --CCCCCCCCCCCCHHHHHHHHHHHHHHHHHHHHHHHHHCPCCCEEEEECCCPCEEEEECCCHHHHHHHHHHC--
125
+ ----------*
126
+ >P1;1mnma
127
+ solvent accessibility
128
+ TTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTFTTTTTTTTTTTTTTTT
129
+ TTTTTTTTTT*
130
+ >P1;1egwa
131
+ solvent accessibility
132
+ --TTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTFTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT--
133
+ ----------*
134
+ ...
135
+
136
+ 3. When you have two or more alignment files, you should make a separate file containing all the paths for the alignment files.
137
+
138
+ ~user $ ls -1 *.tem > TEMLIST
139
+ ~user $ cat TEMLIST
140
+ sample1.tem
141
+ sample2.tem
142
+ ...
143
+
144
+ 4. To produce substitution count matrices, type
145
+
146
+ ~user $ egor -l TEMLIST --output 0 -o substcount.mat
147
+
148
+ 5. To produce substitution probability matrices, type
149
+
150
+ ~user $ egor -l TEMLIST --output 1 -o substprob.mat
67
151
 
68
- * ruby 1.8.7 or above (http://www.ruby-lang.org)
69
- * rubygems 1.2.0 or above (http://rubyforge.org/projects/rubygems/)
152
+ 6. To produce log odds ratio matrices, type
70
153
 
71
- Following RubyGems will be automatically installed if you have rubygems installed on your machine
154
+ ~user $ egor -l TEMLIST --output 2 -o substlogo.mat
155
+
156
+ 7. To produce substitution data only from the sequence pairs within a given PID range, type (if you don't provide any name for output, 'allmat.dat' will be used.)
157
+
158
+ ~user $ egor -l TEMLIST --pidmin 60 --pidmax 80 --output 1
159
+
160
+ 8. To change the clustering level (default 60), type
161
+
162
+ ~user $ egor -l TEMLIST --weight 80 --output 2
163
+
164
+ 9. In case any positions are masked with the character 'X' in any environmental features will be excluded from the calculation of substitution counts.
165
+
166
+ 10. Then, it will produce a file containing all the matrices, which will look like the one below. For more details, please check this notes (http://www-cryst.bioc.cam.ac.uk/~kenji/subst/NOTES).
167
+
168
+ # Environment-specific amino acid substitution matrices
169
+ # Creator: egor version 0.0.5
170
+ # Creation Date: 05/02/2009 17:29
171
+ #
172
+ # Definitions for structural environments:
173
+ # 2 features used
174
+ #
175
+ # secondary structure and phi angle;HEPC;HEPC;F;F
176
+ # solvent accessibility;TF;Aa;F;F
177
+ # (read in from classdef.dat)
178
+ #
179
+ # Number of alignments: 1187
180
+ # (list of .tem files read in from TEMLIST)
181
+ #
182
+ # Total number of environments: 8
183
+ #
184
+ # There are 21 amino acids considered.
185
+ # ACDEFGHIKLMNPQRSTVWYJ
186
+ #
187
+ # C: Cystine (the disulfide-bonded form)
188
+ # J: Cysteine (the free thiol form)
189
+ #
190
+ # Weighting scheme: clustering at PID 60 level
191
+ # ...
192
+ #
193
+ >HA 0
194
+ # A C D E F G H I K L M N P Q R S T V W Y J
195
+ A 3 -5 0 0 -1 2 0 0 1 0 0 0 1 1 0 1 1 1 -1 0 2
196
+ C -16 19 -16 -18 -11 -14 -13 -13 -14 -14 -14 -11 -17 -16 -13 -16 -14 -12 -12 -10 -4
197
+ D 1 -7 6 3 -3 1 0 -3 1 -3 -2 2 1 2 0 1 0 -2 -3 -2 -2
198
+ E 3 -7 5 7 -1 2 2 0 3 0 0 3 2 4 3 3 2 1 -1 0 -1
199
+ F -4 -4 -6 -6 7 -5 -1 0 -4 1 0 -5 -5 -4 -4 -4 -3 -1 3 3 0
200
+ G -2 -6 -3 -4 -5 5 -4 -5 -4 -5 -4 -2 -3 -4 -4 -2 -3 -5 -6 -4 -3
201
+ H 0 -6 0 0 1 0 8 -1 0 0 0 1 -2 1 1 0 0 0 1 3 0
202
+ I -3 -7 -6 -5 0 -5 -3 4 -4 1 1 -5 -4 -4 -3 -5 -2 2 -2 -1 0
203
+ K 2 -6 2 2 -1 1 2 0 5 1 1 2 0 3 4 2 2 0 -2 0 -1
204
+ L -2 -6 -5 -4 1 -4 -2 2 -3 4 2 -3 -4 -3 -2 -4 -2 1 0 0 1
205
+ M -2 -7 -4 -3 1 -2 -1 2 -2 2 6 -3 -4 -2 -1 -2 -1 1 0 0 1
206
+ N 0 -5 1 0 -3 1 1 -3 0 -2 -2 6 -2 0 0 1 1 -2 -3 -1 -1
207
+ P -1 -7 -1 -2 -4 -1 -3 -3 -2 -3 -4 -2 9 -2 -3 0 -1 -2 -4 -4 -4
208
+ Q 2 -7 2 2 -1 1 2 -1 2 0 0 2 0 5 2 1 1 0 -2 -1 0
209
+ R 1 -6 1 1 -1 0 2 0 3 0 1 1 -1 2 6 1 1 0 -1 0 0
210
+ S 0 -6 -1 -1 -3 0 -2 -3 -1 -3 -3 0 0 -1 -1 3 1 -2 -4 -3 0
211
+ T -1 -7 -2 -2 -3 -2 -2 -2 -2 -2 -2 -1 -2 -2 -2 0 3 -1 -3 -3 0
212
+ V -3 -6 -6 -5 -1 -4 -3 1 -4 0 0 -5 -3 -4 -4 -4 -2 2 -2 -2 0
213
+ W -4 -6 -6 -5 2 -6 -2 -2 -5 -1 -2 -5 -5 -4 -4 -5 -4 -2 12 2 -3
214
+ Y -3 -5 -5 -5 3 -4 1 -1 -3 -1 -1 -3 -5 -3 -3 -4 -3 -2 3 7 -1
215
+ J -2 0 -4 -5 0 -2 -1 0 -3 0 0 -3 -6 -2 -2 -1 -1 0 -1 0 9
216
+ U -5 16 -7 -8 -3 -5 -4 -3 -6 -3 -3 -5 -9 -6 -5 -4 -4 -3 -4 -3 6
217
+ ...
218
+
219
+ 11. To generate a heat map for each table with values in it,
220
+
221
+ ~user $ egor -l TEMLIST --heatmap 0 --heatmap-values
222
+
223
+ which will look like this,
224
+
225
+ http://www-cryst.bioc.cam.ac.uk/~semin/images/0.HA.png
226
+
227
+ 12. To generate one big figure, 'myheatmaps.gif' containing all the heat maps (4 maps in a row),
228
+
229
+ ~user $ egor -l TEMLIST --heatmap 1 --heatmap-stem myheatmaps --heatmap-format 1 --heatmap-columns 4
230
+
231
+ which will look like this,
232
+
233
+ http://www-cryst.bioc.cam.ac.uk/~semin/images/myheatmaps.gif
234
+
235
+ == Repository
236
+
237
+ You can download a pre-built RubyGems package from
238
+
239
+ * rubyforge: http://rubyforge.org/projects/egor
72
240
 
73
- * narray (http://narray.rubyforge.org/)
74
- * facets (http://facets.rubyforge.org/)
75
- * bio (http://bioruby.open-bio.org/)
76
- * simple_memoize (http://github.com/JackDanger/simple_memoize/tree/master)
241
+ or, You can fetch the source from
77
242
 
243
+ * github: http://github.com/semin/egor/tree/master
78
244
 
79
- == LICENSE:
80
245
 
81
- (The MIT License)
246
+ == Contact
82
247
 
83
- Copyright (c) 2008 Semin Lee
248
+ Comments are welcome, please send an email to me (seminlee at gmail dot com).
84
249
 
85
- Permission is hereby granted, free of charge, to any person obtaining
86
- a copy of this software and associated documentation files (the
87
- 'Software'), to deal in the Software without restriction, including
88
- without limitation the rights to use, copy, modify, merge, publish,
89
- distribute, sublicense, and/or sell copies of the Software, and to
90
- permit persons to whom the Software is furnished to do so, subject to
91
- the following conditions:
92
250
 
93
- The above copyright notice and this permission notice shall be
94
- included in all copies or substantial portions of the Software.
251
+ == License
95
252
 
96
- THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
97
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
98
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
99
- IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
100
- CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
101
- TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
102
- SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
253
+ http://i.creativecommons.org/l/by-nc/2.0/uk/88x31.png
254
+ This work is licensed under a {Creative Commons Attribution-Noncommercial 2.0 UK: England & Wales License}[http://creativecommons.org/licenses/by-nc/2.0/uk/].
data/Rakefile CHANGED
@@ -5,21 +5,21 @@ require File.dirname(__FILE__) + '/lib/egor'
5
5
  # Run 'rake -T' to see list of generated tasks (from gem root directory)
6
6
  $hoe = Hoe.new('egor', Egor::VERSION) do |p|
7
7
  p.developer('Semin Lee', 'seminlee@gmail.com')
8
- p.changes = p.paragraphs_of("History.txt", 0..1).join("\n\n")
9
- p.post_install_message = 'PostInstall.txt' # TODO remove if post-install message not required
10
- p.rubyforge_name = p.name # TODO this is default value
11
- p.extra_deps = [
12
- ['narray','>= 0.5.9.5'],
13
- ['bio', '>= 1.2.1'],
14
- ['facets','>= 2.4.5'],
15
- ['simple_memoize', '>= 1.0.0'],
8
+ p.changes = p.paragraphs_of("History.txt", 0..1).join("\n\n")
9
+ p.post_install_message = 'PostInstall.txt' # TODO remove if post-install message not required
10
+ p.rubyforge_name = p.name # TODO this is default value
11
+ p.extra_deps = [
12
+ ['narray', '>= 0.5.9.5'],
13
+ ['bio', '>= 1.2.1'],
14
+ ['facets', '>= 2.4.5'],
15
+ ['rmagick', '>= 2.9.1'],
16
16
  ]
17
17
 
18
18
  p.extra_dev_deps = [
19
19
  ['newgem', ">= #{::Newgem::VERSION}"]
20
20
  ]
21
21
 
22
- p.clean_globs |= %w[**/.DS_Store tmp *.log]
22
+ p.clean_globs |= %w[**/.DS_Store tmp *.log *.swp]
23
23
  path = (p.rubyforge_name == p.name) ? p.rubyforge_name : "\#{p.rubyforge_name}/\#{p.name}"
24
24
  p.remote_rdoc_dir = File.join(path.gsub(/^#{p.rubyforge_name}\/?/,''), 'rdoc')
25
25
  p.rsync_args = '-av --delete --ignore-errors'
@@ -2,28 +2,26 @@
2
2
 
3
3
  Gem::Specification.new do |s|
4
4
  s.name = %q{egor}
5
- s.version = "0.0.4"
5
+ s.version = "0.9.0"
6
6
 
7
7
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
8
8
  s.authors = ["Semin Lee"]
9
- s.cert_chain = ["/Users/semin/.gem/gem-public_cert.pem"]
10
- s.date = %q{2008-12-15}
9
+ s.date = %q{2009-02-13}
11
10
  s.default_executable = %q{egor}
12
- s.description = %q{egor: Esst GeneratOR, a program for calculating environment-specific substitution tables}
11
+ s.description = %q{'egor' is a program for calculating environment-specific substitution tables from user providing environmental class definitions and sequence alignments with the annotations of the environment classes.}
13
12
  s.email = ["seminlee@gmail.com"]
14
13
  s.executables = ["egor"]
15
14
  s.extra_rdoc_files = ["History.txt", "Manifest.txt", "PostInstall.txt", "README.rdoc", "website/index.txt"]
16
- s.files = ["History.txt", "Manifest.txt", "PostInstall.txt", "README.rdoc", "Rakefile", "bin/egor", "config/website.yml", "config/website.yml.sample", "egor.gemspec", "lib/egor.rb", "lib/egor/cli.rb", "lib/enumerable_extensions.rb", "lib/environment.rb", "lib/environment_feature.rb", "lib/math_extensions.rb", "lib/narray_extensions.rb", "lib/nmatrix_extensions.rb", "script/console", "script/destroy", "script/generate", "script/txt2html", "test/test_egor.rb", "test/test_egor_cli.rb", "test/test_enumerable_extensions.rb", "test/test_environment_feature.rb", "test/test_helper.rb", "test/test_nmatrix_extensions.rb", "website/index.html", "website/index.txt", "website/javascripts/rounded_corners_lite.inc.js", "website/stylesheets/screen.css", "website/template.html.erb"]
15
+ s.files = ["History.txt", "Manifest.txt", "PostInstall.txt", "README.rdoc", "Rakefile", "bin/egor", "config/website.yml", "config/website.yml.sample", "egor.gemspec", "lib/egor.rb", "lib/egor/cli.rb", "lib/egor/environment.rb", "lib/egor/environment_class_hash.rb", "lib/egor/environment_feature.rb", "lib/egor/environment_feature_array.rb", "lib/egor/heatmap_array.rb", "lib/math_extensions.rb", "lib/narray_extensions.rb", "lib/nmatrix_extensions.rb", "lib/string_extensions.rb", "script/console", "script/destroy", "script/generate", "script/txt2html", "test/egor/test_cli.rb", "test/egor/test_environment_class_hash.rb", "test/egor/test_environment_feature.rb", "test/test_egor.rb", "test/test_helper.rb", "test/test_math_extensions.rb", "test/test_narray_extensions.rb", "test/test_nmatrix_extensions.rb", "test/test_string_extensions.rb", "website/index.html", "website/index.txt", "website/javascripts/rounded_corners_lite.inc.js", "website/stylesheets/screen.css", "website/template.html.erb"]
17
16
  s.has_rdoc = true
18
- s.homepage = %q{http://egor.rubyforge.org}
17
+ s.homepage = %q{http://www-cryst.bioc.cam.ac.uk/egor}
19
18
  s.post_install_message = %q{PostInstall.txt}
20
19
  s.rdoc_options = ["--main", "README.rdoc"]
21
20
  s.require_paths = ["lib"]
22
21
  s.rubyforge_project = %q{egor}
23
22
  s.rubygems_version = %q{1.3.1}
24
- s.signing_key = %q{/Users/semin/.gem/gem-private_key.pem}
25
- s.summary = %q{egor: Esst GeneratOR, a program for calculating environment-specific substitution tables}
26
- s.test_files = ["test/test_egor.rb", "test/test_egor_cli.rb", "test/test_enumerable_extensions.rb", "test/test_environment_feature.rb", "test/test_helper.rb", "test/test_nmatrix_extensions.rb"]
23
+ s.summary = %q{'egor' is a program for calculating environment-specific substitution tables from user providing environmental class definitions and sequence alignments with the annotations of the environment classes.}
24
+ s.test_files = ["test/test_string_extensions.rb", "test/test_nmatrix_extensions.rb", "test/test_math_extensions.rb", "test/test_helper.rb", "test/test_narray_extensions.rb", "test/egor/test_environment_feature.rb", "test/egor/test_cli.rb", "test/egor/test_environment_class_hash.rb", "test/test_egor.rb"]
27
25
 
28
26
  if s.respond_to? :specification_version then
29
27
  current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
@@ -33,23 +31,23 @@ Gem::Specification.new do |s|
33
31
  s.add_runtime_dependency(%q<narray>, [">= 0.5.9.5"])
34
32
  s.add_runtime_dependency(%q<bio>, [">= 1.2.1"])
35
33
  s.add_runtime_dependency(%q<facets>, [">= 2.4.5"])
36
- s.add_runtime_dependency(%q<simple_memoize>, [">= 1.0.0"])
37
- s.add_development_dependency(%q<newgem>, [">= 1.2.1"])
34
+ s.add_runtime_dependency(%q<rmagick>, [">= 2.9.1"])
35
+ s.add_development_dependency(%q<newgem>, [">= 1.2.3"])
38
36
  s.add_development_dependency(%q<hoe>, [">= 1.8.0"])
39
37
  else
40
38
  s.add_dependency(%q<narray>, [">= 0.5.9.5"])
41
39
  s.add_dependency(%q<bio>, [">= 1.2.1"])
42
40
  s.add_dependency(%q<facets>, [">= 2.4.5"])
43
- s.add_dependency(%q<simple_memoize>, [">= 1.0.0"])
44
- s.add_dependency(%q<newgem>, [">= 1.2.1"])
41
+ s.add_dependency(%q<rmagick>, [">= 2.9.1"])
42
+ s.add_dependency(%q<newgem>, [">= 1.2.3"])
45
43
  s.add_dependency(%q<hoe>, [">= 1.8.0"])
46
44
  end
47
45
  else
48
46
  s.add_dependency(%q<narray>, [">= 0.5.9.5"])
49
47
  s.add_dependency(%q<bio>, [">= 1.2.1"])
50
48
  s.add_dependency(%q<facets>, [">= 2.4.5"])
51
- s.add_dependency(%q<simple_memoize>, [">= 1.0.0"])
52
- s.add_dependency(%q<newgem>, [">= 1.2.1"])
49
+ s.add_dependency(%q<rmagick>, [">= 2.9.1"])
50
+ s.add_dependency(%q<newgem>, [">= 1.2.3"])
53
51
  s.add_dependency(%q<hoe>, [">= 1.8.0"])
54
52
  end
55
53
  end