chrislo-sourceclassifier 0.2.0 → 0.2.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.
Files changed (316) hide show
  1. data/Manifest +0 -312
  2. data/Rakefile +2 -2
  3. data/sourceclassifier.gemspec +6 -6
  4. metadata +4 -316
  5. data/sources/gcc/ackermann.gcc-2.gcc +0 -93
  6. data/sources/gcc/ackermann.gcc-3.gcc +0 -20
  7. data/sources/gcc/ary.gcc +0 -40
  8. data/sources/gcc/binarytrees.gcc +0 -136
  9. data/sources/gcc/binarytrees.gcc-2.gcc +0 -140
  10. data/sources/gcc/binarytrees.gcc-3.gcc +0 -134
  11. data/sources/gcc/chameneos.gcc +0 -117
  12. data/sources/gcc/chameneos.gcc-2.gcc +0 -134
  13. data/sources/gcc/chameneos.gcc-3.gcc +0 -120
  14. data/sources/gcc/chameneosredux.gcc +0 -306
  15. data/sources/gcc/echo.gcc +0 -144
  16. data/sources/gcc/except.gcc +0 -52
  17. data/sources/gcc/fannkuch.gcc +0 -105
  18. data/sources/gcc/fannkuch.gcc-2.gcc +0 -94
  19. data/sources/gcc/fasta.gcc +0 -158
  20. data/sources/gcc/fasta.gcc-2.gcc +0 -132
  21. data/sources/gcc/fasta.gcc-3.gcc +0 -145
  22. data/sources/gcc/fasta.gcc-4.gcc +0 -141
  23. data/sources/gcc/fibo.gcc +0 -20
  24. data/sources/gcc/harmonic.gcc +0 -22
  25. data/sources/gcc/hash.gcc +0 -31
  26. data/sources/gcc/hash2.gcc +0 -38
  27. data/sources/gcc/heapsort.gcc +0 -72
  28. data/sources/gcc/hello.gcc-2.gcc +0 -12
  29. data/sources/gcc/hello.gcc-3.gcc +0 -20
  30. data/sources/gcc/knucleotide.gcc +0 -173
  31. data/sources/gcc/knucleotide.gcc-2.gcc +0 -168
  32. data/sources/gcc/lists.gcc +0 -226
  33. data/sources/gcc/magicsquares.gcc +0 -378
  34. data/sources/gcc/mandelbrot.gcc +0 -84
  35. data/sources/gcc/mandelbrot.gcc-2.gcc +0 -63
  36. data/sources/gcc/mandelbrot.gcc-3.gcc +0 -91
  37. data/sources/gcc/mandelbrot.gcc-4.gcc +0 -78
  38. data/sources/gcc/matrix.gcc +0 -66
  39. data/sources/gcc/message.gcc-2.gcc +0 -72
  40. data/sources/gcc/message.gcc-3.gcc +0 -64
  41. data/sources/gcc/methcall.gcc +0 -89
  42. data/sources/gcc/moments.gcc +0 -120
  43. data/sources/gcc/nbody.gcc +0 -142
  44. data/sources/gcc/nbody.gcc-2.gcc +0 -143
  45. data/sources/gcc/nbody.gcc-3.gcc +0 -142
  46. data/sources/gcc/nestedloop.gcc +0 -25
  47. data/sources/gcc/nsieve.gcc +0 -35
  48. data/sources/gcc/nsievebits.gcc-2.gcc +0 -37
  49. data/sources/gcc/nsievebits.gcc-3.gcc +0 -53
  50. data/sources/gcc/objinst.gcc +0 -95
  51. data/sources/gcc/partialsums.gcc +0 -86
  52. data/sources/gcc/partialsums.gcc-3.gcc +0 -81
  53. data/sources/gcc/partialsums.gcc-4.gcc +0 -68
  54. data/sources/gcc/pidigits.gcc +0 -105
  55. data/sources/gcc/primes.gcc +0 -75
  56. data/sources/gcc/prodcons.gcc +0 -86
  57. data/sources/gcc/random.gcc +0 -29
  58. data/sources/gcc/raytracer.gcc +0 -125
  59. data/sources/gcc/raytracer.gcc-2.gcc +0 -181
  60. data/sources/gcc/recursive.gcc +0 -68
  61. data/sources/gcc/recursive.gcc-2.gcc +0 -55
  62. data/sources/gcc/regexdna.gcc-2.gcc +0 -126
  63. data/sources/gcc/regexmatch.gcc +0 -136
  64. data/sources/gcc/revcomp.gcc +0 -85
  65. data/sources/gcc/revcomp.gcc-2.gcc +0 -88
  66. data/sources/gcc/revcomp.gcc-4.gcc +0 -71
  67. data/sources/gcc/reversefile.gcc +0 -103
  68. data/sources/gcc/reversefile.gcc-2.gcc +0 -56
  69. data/sources/gcc/sieve.gcc +0 -34
  70. data/sources/gcc/spectralnorm.gcc +0 -54
  71. data/sources/gcc/spellcheck.gcc +0 -72
  72. data/sources/gcc/spellcheck.gcc-2.gcc +0 -61
  73. data/sources/gcc/strcat.gcc +0 -38
  74. data/sources/gcc/sumcol.gcc-2.gcc +0 -98
  75. data/sources/gcc/sumcol.gcc-3.gcc +0 -22
  76. data/sources/gcc/sumcol.gcc-4.gcc +0 -18
  77. data/sources/gcc/sumcol.gcc-5.gcc +0 -32
  78. data/sources/gcc/takfp.gcc +0 -23
  79. data/sources/gcc/tcp-stream.gcc +0 -122
  80. data/sources/gcc/tcpecho.gcc +0 -122
  81. data/sources/gcc/tcpecho.gcc-2.gcc +0 -136
  82. data/sources/gcc/tcprequest.gcc +0 -122
  83. data/sources/gcc/threadring.gcc +0 -73
  84. data/sources/gcc/wc.gcc +0 -52
  85. data/sources/gcc/wc.gcc-2.gcc +0 -40
  86. data/sources/gcc/wc.gcc-3.gcc +0 -46
  87. data/sources/gcc/wordfreq.gcc-2.gcc +0 -85
  88. data/sources/perl/ackermann.perl +0 -28
  89. data/sources/perl/ackermann.perl-2.perl +0 -25
  90. data/sources/perl/ackermann.perl-3.perl +0 -20
  91. data/sources/perl/ackermann.perl-4.perl +0 -18
  92. data/sources/perl/ary.perl +0 -25
  93. data/sources/perl/ary.perl-2.perl +0 -23
  94. data/sources/perl/binarytrees.perl +0 -66
  95. data/sources/perl/binarytrees.perl-2.perl +0 -71
  96. data/sources/perl/chameneos.perl +0 -67
  97. data/sources/perl/echo.perl +0 -81
  98. data/sources/perl/except.perl +0 -73
  99. data/sources/perl/fannkuch.perl +0 -44
  100. data/sources/perl/fannkuch.perl-2.perl +0 -38
  101. data/sources/perl/fasta.perl +0 -112
  102. data/sources/perl/fasta.perl-2.perl +0 -135
  103. data/sources/perl/fasta.perl-4.perl +0 -122
  104. data/sources/perl/fibo.perl +0 -15
  105. data/sources/perl/fibo.perl-2.perl +0 -0
  106. data/sources/perl/fibo.perl-3.perl +0 -0
  107. data/sources/perl/harmonic.perl +0 -7
  108. data/sources/perl/hash.perl +0 -23
  109. data/sources/perl/hash.perl-2.perl +0 -17
  110. data/sources/perl/hash.perl-3.perl +0 -24
  111. data/sources/perl/hash2.perl +0 -16
  112. data/sources/perl/heapsort.perl +0 -65
  113. data/sources/perl/heapsort.perl-2.perl +0 -0
  114. data/sources/perl/hello.perl +0 -5
  115. data/sources/perl/knucleotide.perl-2.perl +0 -30
  116. data/sources/perl/lists.perl +0 -48
  117. data/sources/perl/mandelbrot.perl-2.perl +0 -32
  118. data/sources/perl/matrix.perl +0 -59
  119. data/sources/perl/matrix.perl-2.perl +0 -0
  120. data/sources/perl/matrix.perl-3.perl +0 -0
  121. data/sources/perl/message.perl +0 -27
  122. data/sources/perl/methcall.perl +0 -66
  123. data/sources/perl/moments.perl +0 -44
  124. data/sources/perl/nbody.perl +0 -108
  125. data/sources/perl/nestedloop.perl +0 -28
  126. data/sources/perl/nsieve.perl-2.perl +0 -41
  127. data/sources/perl/nsieve.perl-4.perl +0 -43
  128. data/sources/perl/nsievebits.perl +0 -37
  129. data/sources/perl/objinst.perl +0 -73
  130. data/sources/perl/partialsums.perl-3.perl +0 -31
  131. data/sources/perl/pidigits.perl +0 -52
  132. data/sources/perl/pidigits.perl-2.perl +0 -47
  133. data/sources/perl/process.perl +0 -50
  134. data/sources/perl/prodcons.perl +0 -47
  135. data/sources/perl/random.perl-4.perl +0 -17
  136. data/sources/perl/recursive.perl-2.perl +0 -57
  137. data/sources/perl/regexdna.perl +0 -48
  138. data/sources/perl/regexdna.perl-2.perl +0 -43
  139. data/sources/perl/regexdna.perl-3.perl +0 -50
  140. data/sources/perl/regexdna.perl-4.perl +0 -49
  141. data/sources/perl/regexdna.perl-5.perl +0 -42
  142. data/sources/perl/regexdna.perl-6.perl +0 -43
  143. data/sources/perl/regexmatch.perl +0 -35
  144. data/sources/perl/revcomp.perl-2.perl +0 -34
  145. data/sources/perl/reversefile.perl +0 -8
  146. data/sources/perl/reversefile.perl-2.perl +0 -0
  147. data/sources/perl/reversefile.perl-3.perl +0 -0
  148. data/sources/perl/sieve.perl +0 -23
  149. data/sources/perl/spectralnorm.perl-2.perl +0 -54
  150. data/sources/perl/spellcheck.perl +0 -24
  151. data/sources/perl/strcat.perl +0 -13
  152. data/sources/perl/strcat.perl-2.perl +0 -0
  153. data/sources/perl/sumcol.perl +0 -8
  154. data/sources/perl/takfp.perl +0 -23
  155. data/sources/perl/takfp.perl-3.perl +0 -20
  156. data/sources/perl/tcpecho.perl +0 -61
  157. data/sources/perl/tcprequest.perl +0 -61
  158. data/sources/perl/tcpstream.perl +0 -61
  159. data/sources/perl/threadring.perl +0 -55
  160. data/sources/perl/threadring.perl-2.perl +0 -43
  161. data/sources/perl/wc.perl +0 -20
  162. data/sources/perl/wc.perl-2.perl +0 -14
  163. data/sources/perl/wordfreq.perl +0 -22
  164. data/sources/perl/wordfreq.perl-3.perl +0 -0
  165. data/sources/perl/wordfreq.perl3.perl +0 -0
  166. data/sources/python/ackermann.python +0 -21
  167. data/sources/python/ary.python +0 -19
  168. data/sources/python/binarytrees.python +0 -39
  169. data/sources/python/binarytrees.python-3.python +0 -44
  170. data/sources/python/chameneos.python-6.python +0 -73
  171. data/sources/python/chameneosredux.python +0 -126
  172. data/sources/python/chameneosredux.python-2.python +0 -122
  173. data/sources/python/dispatch.python +0 -176
  174. data/sources/python/dispatch.python-2.python +0 -136
  175. data/sources/python/echo.python +0 -64
  176. data/sources/python/except.python +0 -62
  177. data/sources/python/fannkuch.python +0 -50
  178. data/sources/python/fannkuch.python-2.python +0 -54
  179. data/sources/python/fasta.python-2.python +0 -79
  180. data/sources/python/fibo.python +0 -17
  181. data/sources/python/fibo.python-2.python +0 -0
  182. data/sources/python/fibo.python-3.python +0 -0
  183. data/sources/python/harmonic.python-2.python +0 -9
  184. data/sources/python/hash.python +0 -21
  185. data/sources/python/hash.python-2.python +0 -0
  186. data/sources/python/hash2.python +0 -30
  187. data/sources/python/heapsort.python-3.python +0 -66
  188. data/sources/python/hello.python +0 -5
  189. data/sources/python/implicitode.python +0 -231
  190. data/sources/python/knucleotide.python +0 -55
  191. data/sources/python/lists.python +0 -44
  192. data/sources/python/magicsquares.python +0 -145
  193. data/sources/python/mandelbrot.python +0 -44
  194. data/sources/python/mandelbrot.python-2.python +0 -35
  195. data/sources/python/mandelbrot.python-3.python +0 -46
  196. data/sources/python/matrix.python +0 -34
  197. data/sources/python/matrix.python-2.python +0 -23
  198. data/sources/python/message.python +0 -24
  199. data/sources/python/message.python-2.python +0 -20
  200. data/sources/python/message.python-3.python +0 -19
  201. data/sources/python/meteor.python +0 -210
  202. data/sources/python/meteor.python-2.python +0 -192
  203. data/sources/python/methcall.python +0 -51
  204. data/sources/python/moments.python +0 -65
  205. data/sources/python/nbody.python +0 -123
  206. data/sources/python/nbody.python-2.python +0 -120
  207. data/sources/python/nestedloop.python +0 -24
  208. data/sources/python/nsieve.python +0 -27
  209. data/sources/python/nsieve.python-2.python +0 -23
  210. data/sources/python/nsieve.python-4.python +0 -25
  211. data/sources/python/nsievebits.python +0 -27
  212. data/sources/python/nsievebits.python-2.python +0 -43
  213. data/sources/python/objinst.python +0 -53
  214. data/sources/python/partialsums.python +0 -37
  215. data/sources/python/partialsums.python-2.python +0 -35
  216. data/sources/python/partialsums.python-3.python +0 -48
  217. data/sources/python/pidigits.python +0 -38
  218. data/sources/python/pidigits.python-3.python +0 -63
  219. data/sources/python/pidigits.python-4.python +0 -24
  220. data/sources/python/process.python +0 -51
  221. data/sources/python/process.python-2.python +0 -133
  222. data/sources/python/prodcons.python +0 -51
  223. data/sources/python/prodcons.python-2.python +0 -0
  224. data/sources/python/random.python +0 -27
  225. data/sources/python/raytracer.python +0 -203
  226. data/sources/python/recursive.python +0 -35
  227. data/sources/python/regexdna.python +0 -39
  228. data/sources/python/regexdna.python-2.python +0 -34
  229. data/sources/python/regexmatch.python +0 -36
  230. data/sources/python/revcomp.python-3.python +0 -31
  231. data/sources/python/reversefile.python +0 -13
  232. data/sources/python/reversefile.python-2.python +0 -0
  233. data/sources/python/reversefile.python-3.python +0 -0
  234. data/sources/python/sieve.python +0 -50
  235. data/sources/python/spectralnorm.python-2.python +0 -36
  236. data/sources/python/spellcheck.python +0 -17
  237. data/sources/python/strcat.python +0 -35
  238. data/sources/python/strcat.python-2.python +0 -0
  239. data/sources/python/sumcol.python-2.python +0 -0
  240. data/sources/python/sumcol.python-3.python +0 -0
  241. data/sources/python/takfp.python +0 -19
  242. data/sources/python/tcpecho.python +0 -67
  243. data/sources/python/tcprequest.python +0 -67
  244. data/sources/python/tcpstream.python +0 -67
  245. data/sources/python/threadring.python +0 -47
  246. data/sources/python/threadring.python-2.python +0 -40
  247. data/sources/python/threadring.python-3.python +0 -34
  248. data/sources/python/wc.python-2.python +0 -19
  249. data/sources/python/wordfreq.python +0 -43
  250. data/sources/python/wordfreq.python-2.python +0 -0
  251. data/sources/python/wordfreq.python-3.python +0 -28
  252. data/sources/python/wordfreq.python-4.python +0 -38
  253. data/sources/python/wordfreq.python-5.python +0 -39
  254. data/sources/ruby/ackermann.ruby +0 -17
  255. data/sources/ruby/ackermann.ruby-5.ruby +0 -153
  256. data/sources/ruby/ary.ruby +0 -22
  257. data/sources/ruby/binarytrees.ruby-2.ruby +0 -55
  258. data/sources/ruby/chameneos.ruby-2.ruby +0 -71
  259. data/sources/ruby/dispatch.ruby +0 -114
  260. data/sources/ruby/echo.ruby +0 -41
  261. data/sources/ruby/except.ruby +0 -61
  262. data/sources/ruby/except.ruby-2.ruby +0 -61
  263. data/sources/ruby/fannkuch.ruby +0 -42
  264. data/sources/ruby/fasta.ruby +0 -81
  265. data/sources/ruby/fibo.ruby +0 -15
  266. data/sources/ruby/harmonic.ruby-2.ruby +0 -15
  267. data/sources/ruby/hash.ruby +0 -19
  268. data/sources/ruby/hash2.ruby +0 -23
  269. data/sources/ruby/heapsort.ruby +0 -55
  270. data/sources/ruby/hello.ruby +0 -6
  271. data/sources/ruby/knucleotide.ruby-2.ruby +0 -44
  272. data/sources/ruby/lists.ruby +0 -46
  273. data/sources/ruby/mandelbrot.ruby-3.ruby +0 -63
  274. data/sources/ruby/matrix.ruby +0 -40
  275. data/sources/ruby/matrix.ruby-2.ruby +0 -30
  276. data/sources/ruby/message.ruby +0 -29
  277. data/sources/ruby/message.ruby-2.ruby +0 -24
  278. data/sources/ruby/meteor.ruby +0 -386
  279. data/sources/ruby/meteor.ruby-2.ruby +0 -561
  280. data/sources/ruby/methcall.ruby +0 -58
  281. data/sources/ruby/methcall.ruby-2.ruby +0 -54
  282. data/sources/ruby/moments.ruby +0 -64
  283. data/sources/ruby/nbody.ruby-2.ruby +0 -145
  284. data/sources/ruby/nestedloop.ruby +0 -22
  285. data/sources/ruby/nsieve.ruby +0 -36
  286. data/sources/ruby/nsieve.ruby-2.ruby +0 -25
  287. data/sources/ruby/nsievebits.ruby-2.ruby +0 -42
  288. data/sources/ruby/objinst.ruby +0 -58
  289. data/sources/ruby/partialsums.ruby +0 -39
  290. data/sources/ruby/pidigits.ruby +0 -92
  291. data/sources/ruby/pidigits.ruby-2.ruby +0 -109
  292. data/sources/ruby/prodcons.ruby +0 -41
  293. data/sources/ruby/random.ruby +0 -17
  294. data/sources/ruby/recursive.ruby-2.ruby +0 -53
  295. data/sources/ruby/regexdna.ruby +0 -32
  296. data/sources/ruby/regexdna.ruby-2.ruby +0 -38
  297. data/sources/ruby/regexmatch.ruby +0 -33
  298. data/sources/ruby/revcomp.ruby +0 -28
  299. data/sources/ruby/reversefile.ruby +0 -7
  300. data/sources/ruby/sieve.ruby +0 -30
  301. data/sources/ruby/spectralnorm.ruby +0 -48
  302. data/sources/ruby/spellcheck.ruby +0 -18
  303. data/sources/ruby/spellcheck.ruby-2.ruby +0 -0
  304. data/sources/ruby/strcat.ruby +0 -12
  305. data/sources/ruby/strcat.ruby-2.ruby +0 -12
  306. data/sources/ruby/sumcol.ruby +0 -12
  307. data/sources/ruby/sumcol.ruby-2.ruby +0 -5
  308. data/sources/ruby/takfp.ruby +0 -15
  309. data/sources/ruby/tcpecho.ruby +0 -45
  310. data/sources/ruby/tcprequest.ruby +0 -45
  311. data/sources/ruby/tcpstream.ruby +0 -45
  312. data/sources/ruby/threadring.ruby +0 -61
  313. data/sources/ruby/threadring.ruby-2.ruby +0 -33
  314. data/sources/ruby/wc.ruby +0 -15
  315. data/sources/ruby/wordfreq.ruby +0 -17
  316. data/sources/ruby/wordfreq.ruby2.ruby +0 -0
@@ -1,81 +0,0 @@
1
- # The Computer Language Shootout
2
- # http://shootout.alioth.debian.org/
3
- # Contributed by Sokolov Yura
4
-
5
- $last = 42.0
6
- def gen_random (max,im=139968,ia=3877,ic=29573)
7
- (max * ($last = ($last * ia + ic) % im)) / im
8
- end
9
-
10
- alu =
11
- "GGCCGGGCGCGGTGGCTCACGCCTGTAATCCCAGCACTTTGG"+
12
- "GAGGCCGAGGCGGGCGGATCACCTGAGGTCAGGAGTTCGAGA"+
13
- "CCAGCCTGGCCAACATGGTGAAACCCCGTCTCTACTAAAAAT"+
14
- "ACAAAAATTAGCCGGGCGTGGTGGCGCGCGCCTGTAATCCCA"+
15
- "GCTACTCGGGAGGCTGAGGCAGGAGAATCGCTTGAACCCGGG"+
16
- "AGGCGGAGGTTGCAGTGAGCCGAGATCGCGCCACTGCACTCC"+
17
- "AGCCTGGGCGACAGAGCGAGACTCCGTCTCAAAAA"
18
-
19
- iub = [
20
- ["a", 0.27],
21
- ["c", 0.12],
22
- ["g", 0.12],
23
- ["t", 0.27],
24
-
25
- ["B", 0.02],
26
- ["D", 0.02],
27
- ["H", 0.02],
28
- ["K", 0.02],
29
- ["M", 0.02],
30
- ["N", 0.02],
31
- ["R", 0.02],
32
- ["S", 0.02],
33
- ["V", 0.02],
34
- ["W", 0.02],
35
- ["Y", 0.02],
36
- ]
37
- homosapiens = [
38
- ["a", 0.3029549426680],
39
- ["c", 0.1979883004921],
40
- ["g", 0.1975473066391],
41
- ["t", 0.3015094502008],
42
- ]
43
-
44
- def make_repeat_fasta(id, desc, src, n)
45
- puts ">#{id} #{desc}"
46
- v = nil
47
- width = 60
48
- l = src.length
49
- s = src * ((n / l) + 1)
50
- s.slice!(n, l)
51
- puts (s.scan(/.{1,#{width}}/).join("\n"))
52
- end
53
-
54
- def make_random_fasta(id, desc, table, n)
55
- puts ">#{id} #{desc}"
56
- rand, v = nil,nil
57
- width = 60
58
- chunk = 1 * width
59
- prob = 0.0
60
- table.each{|v| v[1]= (prob += v[1])}
61
- for i in 1..(n/width)
62
- puts (1..width).collect{
63
- rand = gen_random(1.0)
64
- table.find{|v| v[1]>rand}[0]
65
- }.join
66
- end
67
- if n%width != 0
68
- puts (1..(n%width)).collect{
69
- rand = gen_random(1.0)
70
- table.find{|v| v[1]>rand}[0]
71
- }.join
72
- end
73
- end
74
-
75
-
76
- n = (ARGV[0] or 27).to_i
77
-
78
- make_repeat_fasta('ONE', 'Homo sapiens alu', alu, n*2)
79
- make_random_fasta('TWO', 'IUB ambiguity codes', iub, n*3)
80
- make_random_fasta('THREE', 'Homo sapiens frequency', homosapiens, n*5)
81
-
@@ -1,15 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: fibo.ruby,v 1.3 2005-04-25 19:01:38 igouy-guest Exp $
4
- # http://www.bagley.org/~doug/shootout/
5
-
6
- def fib(n)
7
- if n < 2 then
8
- 1
9
- else
10
- fib(n-2) + fib(n-1)
11
- end
12
- end
13
-
14
- N = Integer(ARGV.shift || 1)
15
- puts fib(N)
@@ -1,15 +0,0 @@
1
- #!/usr/bin/ruby
2
- # http://shootout.alioth.debian.org/
3
- #
4
- # Contributed by Christopher Williams
5
- # modified by Daniel South
6
- # modified by Doug King
7
-
8
- n = (ARGV[0] || 10000000).to_i
9
-
10
- partialSum = 0.0
11
- for i in (1..n)
12
- partialSum += (1.0 / i)
13
- end
14
-
15
- printf("%.9f\n", partialSum)
@@ -1,19 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: hash.ruby,v 1.1.1.1 2004-05-19 18:09:55 bfulgham Exp $
4
- # http://www.bagley.org/~doug/shootout/
5
- # with help from Aristarkh A Zagorodnikov
6
-
7
- n = (ARGV.shift || 1).to_i
8
-
9
- hash = {}
10
- for i in 1..n
11
- hash['%x' % i] = 1
12
- end
13
-
14
- c = 0
15
- n.downto 1 do |i|
16
- c += 1 if hash.has_key? i.to_s
17
- end
18
-
19
- puts c
@@ -1,23 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: hash2.ruby,v 1.2 2004-11-10 06:36:29 bfulgham Exp $
4
- # http://shootout.alioth.debian.org/
5
- # Revised by Dave Anderson
6
-
7
- n = Integer(ARGV.shift || 1)
8
-
9
- hash1 = {}
10
- i = 0
11
- for i in 0 .. 9999
12
- hash1["foo_" << i.to_s] = i
13
- end
14
-
15
- hash2 = Hash.new(0)
16
- n.times do
17
- for i in hash1.keys
18
- hash2[i] += hash1[i]
19
- end
20
- end
21
-
22
- printf "%d %d %d %d\n",
23
- hash1["foo_1"], hash1["foo_9999"], hash2["foo_1"], hash2["foo_9999"]
@@ -1,55 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: heapsort.ruby,v 1.5 2005-04-14 15:59:37 igouy-guest Exp $
4
- #
5
- # The Great Computer Language Shootout
6
- # http://shootout.alioth.debian.org/
7
- #
8
- # modified by Jabari Zakiya
9
-
10
- IM = 139968
11
- IA = 3877
12
- IC = 29573
13
-
14
- $last = 42.0
15
- def gen_random (max) (max * ($last = ($last * IA + IC) % IM)) / IM end
16
-
17
- def heapsort(n, ra)
18
- j = i = rra = 0
19
- l = (n >> 1) + 1
20
- ir = n - 1
21
-
22
- while (1) do
23
- if (l > 1) then
24
- rra = ra.at(l -= 1)
25
- else
26
- rra = ra.at(ir)
27
- ra[ir] = ra.at(1)
28
- if ((ir -= 1) == 1) then
29
- ra[1] = rra
30
- return
31
- end
32
- end
33
- i = l
34
- j = l << 1
35
- while (j <= ir) do
36
- if ((j < ir) and (ra.at(j) < ra.at(j+1))) then
37
- j += 1
38
- end
39
- if (rra < ra.at(j)) then
40
- ra[i] = ra.at(j)
41
- j += (i = j)
42
- else
43
- j = ir + 1
44
- end
45
- end
46
- ra[i] = rra
47
- end
48
- end
49
-
50
- N = Integer(ARGV.shift || 1)
51
- ary = Array.new(N) { gen_random(1.0) }
52
-
53
- heapsort(N, ary)
54
-
55
- printf "%.10f\n", ary.last
@@ -1,6 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: hello.ruby,v 1.1.1.1 2004-05-19 18:10:16 bfulgham Exp $
4
- # http://www.bagley.org/~doug/shootout/
5
-
6
- puts "hello world"
@@ -1,44 +0,0 @@
1
- # The Computer Language Shootout
2
- # http://shootout.alioth.debian.org
3
- #
4
- # contributed by jose fco. gonzalez
5
- # modified by Sokolov Yura
6
-
7
- seq = String.new
8
-
9
- def frecuency( seq,length )
10
- n, table = seq.length - length + 1, Hash.new(0)
11
- f, i = nil, nil
12
- (0 ... length).each do |f|
13
- (f ... n).step(length) do |i|
14
- table[seq[i,length]] += 1
15
- end
16
- end
17
- [n,table]
18
-
19
- end
20
-
21
- def sort_by_freq( seq,length )
22
- n,table = frecuency( seq,length )
23
- a, b, v = nil, nil, nil
24
- table.sort{|a,b| b[1] <=> a[1]}.each do |v|
25
- puts "%s %.3f" % [v[0].upcase,((v[1]*100).to_f/n)]
26
- end
27
- puts
28
- end
29
-
30
- def find_seq( seq,s )
31
- n,table = frecuency( seq,s.length )
32
- puts "#{table[s].to_s}\t#{s.upcase}"
33
- end
34
-
35
- line = STDIN.gets while line !~ /^>THREE/
36
- line = STDIN.gets
37
- while (line !~ /^>/) & line do
38
- seq << line.chomp
39
- line = STDIN.gets
40
- end
41
-
42
- [1,2].each {|i| sort_by_freq( seq,i ) }
43
-
44
- %w(ggt ggta ggtatt ggtattttaatt ggtattttaatttatagt).each{|s| find_seq( seq,s) }
@@ -1,46 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: lists.ruby,v 1.3 2005-06-10 16:59:56 igouy-guest Exp $
4
- # http://www.bagley.org/~doug/shootout/
5
-
6
- NUM = Integer(ARGV.shift || 1)
7
-
8
- SIZE = 10000
9
-
10
- def test_lists()
11
- # create a list of integers (Li1) from 1 to SIZE
12
- li1 = (1..SIZE).to_a
13
- # copy the list to li2 (not by individual items)
14
- li2 = li1.dup
15
- # remove each individual item from left side of li2 and
16
- # append to right side of li3 (preserving order)
17
- li3 = Array.new
18
- while (not li2.empty?)
19
- li3.push(li2.shift)
20
- end
21
- # li2 must now be empty
22
- # remove each individual item from right side of li3 and
23
- # append to right side of li2 (reversing list)
24
- while (not li3.empty?)
25
- li2.push(li3.pop)
26
- end
27
- # li3 must now be empty
28
- # reverse li1 in place
29
- li1.reverse!
30
- # check that first item is now SIZE
31
- if li1[0] != SIZE then
32
- p "not SIZE"
33
- return(0)
34
- end
35
- # compare li1 and li2 for equality
36
- if li1 != li2 then
37
- return(0)
38
- end
39
- # return the length of the list
40
- return(li1.length)
41
- end
42
-
43
- for iter in 1 .. NUM
44
- result = test_lists()
45
- end
46
- print result, "\n"
@@ -1,63 +0,0 @@
1
- # The Computer Language Benchmarks Game
2
- # http://shootout.alioth.debian.org/
3
- #
4
- # contributed by Karl von Laudermann
5
- # modified by Jeremy Echols
6
- # modified by Detlef Reichl
7
-
8
- size = ARGV[0].to_i
9
-
10
- puts "P4\n#{size} #{size}"
11
-
12
- ITER = 50 # Iterations
13
- LIMIT_SQUARED = 4.0 # Presquared limit
14
-
15
- byte_acc = 0
16
- bit_num = 0
17
-
18
- count_size = size - 1 # Precomputed size for easy for..in looping
19
-
20
- # For..in loops are faster than .upto, .downto, .times, etc.
21
- # That's not true, but left it here
22
- for y in 0..count_size
23
- for x in 0..count_size
24
- zr = 0.0
25
- zi = 0.0
26
- cr = (2.0*x/size)-1.5
27
- ci = (2.0*y/size)-1.0
28
- escape = false
29
-
30
- zrzr = zr*zr
31
- zizi = zi*zi
32
- ITER.times do
33
- tr = zrzr - zizi + cr
34
- ti = 2.0*zr*zi + ci
35
- zr = tr
36
- zi = ti
37
- # preserve recalculation
38
- zrzr = zr*zr
39
- zizi = zi*zi
40
- if zrzr+zizi > LIMIT_SQUARED
41
- escape = true
42
- break
43
- end
44
- end
45
-
46
- byte_acc = (byte_acc << 1) | (escape ? 0b0 : 0b1)
47
- bit_num += 1
48
-
49
- # Code is very similar for these cases, but using separate blocks
50
- # ensures we skip the shifting when it's unnecessary, which is most cases.
51
- if (bit_num == 8)
52
- print byte_acc.chr
53
- byte_acc = 0
54
- bit_num = 0
55
- elsif (x == count_size)
56
- byte_acc <<= (8 - bit_num)
57
- print byte_acc.chr
58
- byte_acc = 0
59
- bit_num = 0
60
- end
61
- end
62
- end
63
-
@@ -1,40 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: matrix.ruby,v 1.2 2005-03-23 06:11:41 bfulgham Exp $
4
- # http://shootout.alioth.debian.org/
5
- #
6
- # Contributed by Christopher Williams
7
-
8
- n = (ARGV[0] || 60).to_i
9
- size = 30
10
-
11
- def mkmatrix(rows, cols)
12
- count = 0
13
- Array.new(rows) do |i|
14
- Array.new(cols) {|j| count +=1 }
15
- end
16
- end
17
-
18
- def mmult(rows, cols, m1, m2)
19
- m3 = []
20
- for i in 0 .. (rows - 1)
21
- row = []
22
- for j in 0 .. (cols - 1)
23
- val = 0
24
- for k in 0 .. (cols - 1)
25
- val += m1[i][k] * m2[k][j]
26
- end
27
- row << val
28
- end
29
- m3 << row
30
- end
31
- m3
32
- end
33
-
34
- m1 = mkmatrix(size, size)
35
- m2 = mkmatrix(size, size)
36
- mm = []
37
- n.times do
38
- mm = mmult(size, size, m1, m2)
39
- end
40
- puts "#{mm[0][0]} #{mm[2][3]} #{mm[3][2]} #{mm[4][4]}"
@@ -1,30 +0,0 @@
1
- #!/usr/bin/ruby
2
- # -*- mode: ruby -*-
3
- # $Id: matrix.ruby-2.ruby,v 1.1 2005-03-23 06:11:41 bfulgham Exp $
4
- # http://shootout.alioth.debian.org/
5
- #
6
- # Contributed by Christopher Williams
7
-
8
- n = (ARGV[0] || 60).to_i
9
- size = 30
10
- require 'matrix'
11
- n = (ARGV[0] || 600).to_i
12
- size = 30
13
-
14
- def mkmatrix(rows,cols)
15
- count = 0
16
- the_rows = Array.new(rows) do |i|
17
- Array.new(cols) {|j| count +=1 }
18
- end
19
- Matrix[*the_rows]
20
- end
21
-
22
- m1 = mkmatrix(size,size)
23
- m2 = mkmatrix(size,size)
24
- mm = []
25
- n.times do
26
- mm = m1 * m2
27
- end
28
- puts "#{mm[0,0]} #{mm[2,3]} #{mm[3,2]} #{mm[4,4]}"
29
-
30
-