facets 2.1.3 → 2.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (303) hide show
  1. data/AUTHORS +14 -12
  2. data/CHANGES +45 -2
  3. data/NOTES +9 -7
  4. data/lib/core/facets/1stclassmethod.rb +15 -11
  5. data/lib/core/facets/array.rb +0 -1
  6. data/lib/core/facets/array/conjoin.rb +40 -8
  7. data/lib/core/facets/array/delete.rb +8 -2
  8. data/lib/core/facets/array/indexable.rb +30 -3
  9. data/lib/core/facets/array/merge.rb +11 -0
  10. data/lib/core/facets/array/only.rb +3 -3
  11. data/lib/core/facets/array/pad.rb +4 -46
  12. data/lib/core/facets/array/rotate.rb +4 -4
  13. data/lib/core/facets/array/select.rb +2 -0
  14. data/lib/core/facets/array/splice.rb +16 -2
  15. data/lib/core/facets/array/stackable.rb +6 -40
  16. data/lib/core/facets/binding.rb +3 -0
  17. data/lib/core/facets/binding/cflow.rb +10 -64
  18. data/lib/core/facets/binding/defined.rb +10 -0
  19. data/lib/core/facets/binding/eval.rb +10 -76
  20. data/lib/core/facets/binding/here.rb +9 -0
  21. data/lib/core/facets/binding/self.rb +10 -0
  22. data/lib/core/facets/binding/vars.rb +0 -45
  23. data/lib/core/facets/boolean.rb +31 -103
  24. data/lib/core/facets/class/descendents.rb +17 -44
  25. data/lib/core/facets/comparable/bound.rb +8 -70
  26. data/lib/core/facets/comparable/cmp.rb +12 -92
  27. data/lib/core/facets/conversion.rb +122 -321
  28. data/lib/core/facets/dir/multiglob.rb +0 -13
  29. data/lib/core/facets/dir/traverse.rb +61 -111
  30. data/lib/core/facets/enumerable.rb +4 -2
  31. data/lib/core/facets/enumerable/cartesian.rb +36 -85
  32. data/lib/core/facets/enumerable/collect.rb +64 -152
  33. data/lib/core/facets/enumerable/combination.rb +40 -42
  34. data/lib/core/facets/enumerable/count.rb +99 -174
  35. data/lib/core/facets/enumerable/each.rb +86 -0
  36. data/lib/core/facets/enumerable/mash.rb +58 -0
  37. data/lib/core/facets/enumerable/permutation.rb +39 -44
  38. data/lib/core/facets/enumerable/probability.rb +16 -90
  39. data/lib/core/facets/enumerable/split.rb +113 -0
  40. data/lib/core/facets/exception/detail.rb +1 -2
  41. data/lib/core/facets/facets.rb +3 -2
  42. data/lib/core/facets/file/read.rb +4 -59
  43. data/lib/core/facets/file/topath.rb +8 -96
  44. data/lib/core/facets/file/write.rb +21 -49
  45. data/lib/core/facets/filetest/root.rb +4 -3
  46. data/lib/core/facets/functor.rb +5 -43
  47. data/lib/core/facets/hash/at.rb +7 -37
  48. data/lib/core/facets/hash/delete.rb +9 -58
  49. data/lib/core/facets/hash/has_keys.rb +4 -43
  50. data/lib/core/facets/hash/insert.rb +5 -38
  51. data/lib/core/facets/hash/inverse.rb +2 -41
  52. data/lib/core/facets/hash/iterate.rb +4 -45
  53. data/lib/core/facets/hash/keyize.rb +24 -92
  54. data/lib/core/facets/hash/merge.rb +4 -38
  55. data/lib/core/facets/hash/new.rb +5 -38
  56. data/lib/core/facets/hash/op.rb +20 -66
  57. data/lib/core/facets/hash/rekey.rb +9 -87
  58. data/lib/core/facets/hash/select.rb +1 -1
  59. data/lib/core/facets/hash/slice.rb +42 -0
  60. data/lib/core/facets/hash/traverse.rb +6 -46
  61. data/lib/core/facets/hash/update.rb +27 -67
  62. data/lib/core/facets/hash/weave.rb +22 -42
  63. data/lib/core/facets/indexable.rb +42 -14
  64. data/lib/core/facets/integer/bitmask.rb +69 -106
  65. data/lib/core/facets/integer/factorial.rb +1 -44
  66. data/lib/core/facets/integer/multiples.rb +27 -22
  67. data/lib/core/facets/integer/of.rb +1 -33
  68. data/lib/core/facets/kernel.rb +4 -2
  69. data/lib/core/facets/kernel/ask.rb +15 -3
  70. data/lib/core/facets/kernel/callstack.rb +38 -69
  71. data/lib/core/facets/kernel/constant.rb +2 -38
  72. data/lib/core/facets/kernel/deepcopy.rb +3 -55
  73. data/lib/core/facets/kernel/dir.rb +2 -0
  74. data/lib/core/facets/kernel/ergo.rb +2 -2
  75. data/lib/core/facets/kernel/instance.rb +51 -120
  76. data/lib/core/facets/kernel/metaid.rb +35 -73
  77. data/lib/core/facets/kernel/object.rb +14 -39
  78. data/lib/core/facets/kernel/op_esc.rb +24 -2
  79. data/lib/core/facets/kernel/populate.rb +6 -69
  80. data/lib/core/facets/kernel/report.rb +28 -33
  81. data/lib/core/facets/kernel/require.rb +7 -21
  82. data/lib/core/facets/kernel/respond.rb +11 -1
  83. data/lib/core/facets/kernel/returning.rb +50 -0
  84. data/lib/core/facets/kernel/silence.rb +12 -24
  85. data/lib/core/facets/kernel/super.rb +12 -76
  86. data/lib/core/facets/kernel/tap.rb +25 -107
  87. data/lib/core/facets/kernel/val.rb +7 -46
  88. data/lib/core/facets/kernel/withattr.rb +6 -64
  89. data/lib/core/facets/matchdata/matchset.rb +8 -50
  90. data/lib/core/facets/module.rb +3 -1
  91. data/lib/core/facets/module/abstract.rb +9 -47
  92. data/lib/core/facets/module/alias.rb +11 -68
  93. data/lib/core/facets/module/attr.rb +36 -15
  94. data/lib/core/facets/module/cattr.rb +8 -76
  95. data/lib/core/facets/module/clone.rb +15 -66
  96. data/lib/core/facets/module/include.rb +54 -114
  97. data/lib/core/facets/module/methods.rb +15 -13
  98. data/lib/core/facets/module/modify.rb +20 -206
  99. data/lib/core/facets/module/name.rb +19 -83
  100. data/lib/core/facets/module/require.rb +48 -53
  101. data/lib/core/facets/module/traits.rb +74 -33
  102. data/lib/core/facets/nilclass/status.rb +25 -2
  103. data/lib/core/facets/numeric/round.rb +24 -89
  104. data/lib/core/facets/proc/bind.rb +16 -59
  105. data/lib/core/facets/proc/compose.rb +6 -40
  106. data/lib/core/facets/proc/fn.rb +2 -0
  107. data/lib/core/facets/range/combine.rb +15 -51
  108. data/lib/core/facets/range/overlap.rb +8 -64
  109. data/lib/core/facets/regexp/arity.rb +6 -41
  110. data/lib/core/facets/stackable.rb +43 -4
  111. data/lib/core/facets/string.rb +2 -0
  112. data/lib/core/facets/string/align.rb +45 -55
  113. data/lib/core/facets/string/blank.rb +2 -46
  114. data/lib/core/facets/string/bracket.rb +14 -87
  115. data/lib/core/facets/string/case.rb +45 -32
  116. data/lib/core/facets/string/crypt.rb +3 -40
  117. data/lib/core/facets/string/filter.rb +7 -49
  118. data/lib/core/facets/string/format.rb +24 -126
  119. data/lib/core/facets/string/indexable.rb +50 -133
  120. data/lib/core/facets/string/interpolate.rb +24 -59
  121. data/lib/core/facets/string/natcmp.rb +5 -39
  122. data/lib/core/facets/string/nchar.rb +37 -45
  123. data/lib/core/facets/string/op.rb +13 -0
  124. data/lib/core/facets/string/partitions.rb +38 -99
  125. data/lib/core/facets/string/range.rb +8 -49
  126. data/lib/core/facets/string/regesc.rb +9 -42
  127. data/lib/core/facets/string/scan.rb +6 -52
  128. data/lib/core/facets/string/splice.rb +8 -13
  129. data/lib/core/facets/string/tabs.rb +16 -153
  130. data/lib/core/facets/symbol.rb +3 -1
  131. data/lib/core/facets/symbol/chomp.rb +11 -29
  132. data/lib/core/facets/symbol/generate.rb +4 -43
  133. data/lib/core/facets/symbol/not.rb +13 -25
  134. data/lib/core/facets/symbol/shadow.rb +2 -40
  135. data/lib/core/facets/symbol/succ.rb +14 -13
  136. data/lib/core/facets/symbol/to_proc.rb +33 -28
  137. data/lib/core/facets/time.rb +1 -0
  138. data/lib/core/facets/time/change.rb +5 -38
  139. data/lib/core/facets/time/elapse.rb +2 -41
  140. data/lib/core/facets/time/stamp.rb +47 -0
  141. data/lib/core/facets/unboundmethod.rb +3 -0
  142. data/lib/core/facets/unboundmethod/arguments.rb +27 -4
  143. data/lib/core/facets/unboundmethod/name.rb +21 -7
  144. data/lib/methods/facets/enumerable/cluster_by.rb +1 -1
  145. data/lib/methods/facets/enumerable/collate.rb +1 -0
  146. data/lib/methods/facets/enumerable/divide.rb +1 -1
  147. data/lib/methods/facets/enumerable/each_by.rb +1 -1
  148. data/lib/methods/facets/enumerable/each_pair.rb +1 -1
  149. data/lib/methods/facets/enumerable/eachn.rb +1 -1
  150. data/lib/methods/facets/enumerable/graph.rb +1 -1
  151. data/lib/methods/facets/enumerable/group_by.rb +1 -1
  152. data/lib/methods/facets/enumerable/inject.rb +1 -0
  153. data/lib/methods/facets/enumerable/map_send.rb +1 -0
  154. data/lib/methods/facets/enumerable/modulate.rb +1 -0
  155. data/lib/methods/facets/enumerable/partition_by.rb +1 -1
  156. data/lib/methods/facets/hash/collate.rb +1 -1
  157. data/lib/methods/facets/hash/except.rb +1 -0
  158. data/lib/methods/facets/hash/graph.rb +1 -1
  159. data/lib/methods/facets/hash/mash.rb +1 -0
  160. data/lib/methods/facets/kernel/Bit.rb +1 -0
  161. data/lib/methods/facets/kernel/complete.rb +1 -1
  162. data/lib/methods/facets/kernel/here.rb +1 -1
  163. data/lib/methods/facets/kernel/non_nil.rb +1 -0
  164. data/lib/methods/facets/kernel/respond_with_value.rb +1 -0
  165. data/lib/methods/facets/kernel/with.rb +1 -1
  166. data/lib/methods/facets/module/class_def.rb +1 -0
  167. data/lib/methods/facets/string/camelcase.rb +1 -0
  168. data/lib/methods/facets/string/op_minus.rb +1 -0
  169. data/lib/methods/facets/string/snakecase.rb +1 -0
  170. data/lib/more/facets/attributes.rb +5 -5
  171. data/lib/more/facets/basicobject.rb +0 -62
  172. data/lib/{core/facets/continuation/create.rb → more/facets/continuation.rb} +4 -21
  173. data/lib/more/facets/duration.rb +534 -0
  174. data/lib/more/facets/lazy.rb +3 -3
  175. data/lib/more/facets/namespace.rb +23 -71
  176. data/lib/more/facets/rbsystem.rb +42 -8
  177. data/lib/more/facets/stylize.rb +6 -3
  178. data/lib/more/facets/thread.rb +55 -0
  179. data/meta/MANIFEST +49 -18
  180. data/meta/ROLLRC +1 -1
  181. data/meta/project.yaml +2 -2
  182. data/task/install +1 -1
  183. data/task/test/general +8 -2
  184. data/test/unit/array/test_pad.rb +30 -45
  185. data/test/unit/array/test_stackable.rb +14 -28
  186. data/test/unit/binding/test_cflow.rb +34 -49
  187. data/test/unit/binding/test_defined.rb +17 -0
  188. data/test/unit/binding/test_eval.rb +11 -39
  189. data/test/unit/binding/test_here.rb +17 -0
  190. data/test/unit/binding/test_self.rb +17 -0
  191. data/test/unit/binding/test_vars.rb +22 -37
  192. data/test/unit/class/test_descendents.rb +15 -30
  193. data/test/unit/class/test_initializer.rb +1 -8
  194. data/test/unit/comparable/test_bound.rb +38 -53
  195. data/test/unit/comparable/test_cmp.rb +45 -60
  196. data/test/unit/dir/test_traverse.rb +56 -0
  197. data/test/unit/enumerable/test_cartesian.rb +34 -47
  198. data/test/unit/enumerable/test_collect.rb +16 -125
  199. data/test/unit/enumerable/test_combination.rb +1 -8
  200. data/test/unit/enumerable/test_count.rb +51 -66
  201. data/test/unit/enumerable/test_each.rb +77 -0
  202. data/test/unit/enumerable/test_mash.rb +51 -0
  203. data/test/unit/enumerable/test_permutation.rb +1 -7
  204. data/test/unit/enumerable/test_probability.rb +42 -55
  205. data/test/unit/enumerable/test_split.rb +52 -0
  206. data/test/unit/exception/test_detail.rb +19 -0
  207. data/test/unit/file/test_read.rb +34 -0
  208. data/test/unit/file/test_topath.rb +17 -25
  209. data/test/unit/file/test_write.rb +6 -12
  210. data/test/unit/filetest/test_root.rb +14 -0
  211. data/test/unit/hash/test_at.rb +9 -21
  212. data/test/unit/hash/test_delete.rb +22 -37
  213. data/test/unit/hash/test_has_keys.rb +13 -28
  214. data/test/unit/hash/test_insert.rb +9 -23
  215. data/test/unit/hash/test_inverse.rb +11 -26
  216. data/test/unit/hash/test_iterate.rb +16 -31
  217. data/test/unit/hash/test_keyize.rb +40 -55
  218. data/test/unit/hash/test_merge.rb +10 -25
  219. data/test/unit/hash/test_new.rb +9 -24
  220. data/test/unit/hash/test_op.rb +1 -7
  221. data/test/unit/hash/test_rekey.rb +47 -62
  222. data/test/unit/hash/test_traverse.rb +17 -32
  223. data/test/unit/hash/test_update.rb +30 -45
  224. data/test/unit/hash/test_weave.rb +10 -23
  225. data/test/unit/integer/test_bitmask.rb +48 -44
  226. data/test/unit/integer/test_factorial.rb +11 -26
  227. data/test/unit/integer/test_multiples.rb +1 -5
  228. data/test/unit/integer/test_of.rb +14 -29
  229. data/test/unit/kernel/test_callstack.rb +13 -28
  230. data/test/unit/kernel/test_constant.rb +14 -28
  231. data/test/unit/kernel/test_deepcopy.rb +20 -35
  232. data/test/unit/kernel/test_instance.rb +46 -61
  233. data/test/unit/kernel/test_metaid.rb +42 -57
  234. data/test/unit/kernel/test_object.rb +14 -29
  235. data/test/unit/kernel/test_populate.rb +38 -53
  236. data/test/unit/kernel/test_report.rb +1 -7
  237. data/test/unit/kernel/test_returning.rb +16 -0
  238. data/test/unit/kernel/test_silence.rb +8 -23
  239. data/test/unit/kernel/test_super.rb +41 -56
  240. data/test/unit/kernel/test_tap.rb +15 -39
  241. data/test/unit/kernel/test_val.rb +7 -20
  242. data/test/unit/kernel/test_withattr.rb +29 -44
  243. data/test/unit/matchdata/test_matchset.rb +20 -35
  244. data/test/unit/module/test_abstract.rb +15 -30
  245. data/test/unit/module/test_alias.rb +32 -45
  246. data/test/unit/module/test_cattr.rb +39 -54
  247. data/test/unit/module/test_clone.rb +31 -43
  248. data/test/unit/module/test_include.rb +1 -35
  249. data/test/unit/module/test_modify.rb +102 -114
  250. data/test/unit/module/test_name.rb +1 -7
  251. data/test/unit/numeric/test_round.rb +46 -61
  252. data/test/unit/proc/test_bind.rb +29 -44
  253. data/test/unit/proc/test_compose.rb +20 -35
  254. data/test/unit/range/test_combine.rb +14 -29
  255. data/test/unit/range/test_overlap.rb +34 -51
  256. data/test/unit/regexp/test_arity.rb +14 -29
  257. data/test/unit/string/test_align.rb +13 -27
  258. data/test/unit/string/test_blank.rb +12 -27
  259. data/test/unit/string/test_bracket.rb +52 -67
  260. data/test/unit/string/test_case.rb +19 -38
  261. data/test/unit/string/test_crypt.rb +10 -25
  262. data/test/unit/string/test_filter.rb +1 -7
  263. data/test/unit/string/test_format.rb +2 -7
  264. data/test/unit/string/test_indexable.rb +54 -69
  265. data/test/unit/string/test_interpolate.rb +8 -21
  266. data/test/unit/string/test_natcmp.rb +11 -26
  267. data/test/unit/string/test_nchar.rb +1 -14
  268. data/test/unit/string/test_op.rb +14 -0
  269. data/test/unit/string/test_partitions.rb +39 -54
  270. data/test/unit/string/test_range.rb +17 -32
  271. data/test/unit/string/test_regesc.rb +1 -7
  272. data/test/unit/string/test_scan.rb +23 -38
  273. data/test/unit/string/test_stackable.rb +79 -98
  274. data/test/unit/string/test_tabs.rb +1 -7
  275. data/test/unit/symbol/test_chomp.rb +10 -21
  276. data/test/unit/symbol/test_generate.rb +7 -22
  277. data/test/unit/symbol/test_not.rb +10 -25
  278. data/test/unit/symbol/test_shadow.rb +8 -23
  279. data/test/unit/symbol/test_succ.rb +1 -7
  280. data/test/unit/symbol/test_to_proc.rb +1 -7
  281. data/test/unit/test_attributes.rb +1 -1
  282. data/test/unit/test_continuation.rb +13 -0
  283. data/test/unit/test_conversion.rb +1 -14
  284. data/test/unit/test_namespace.rb +30 -3
  285. data/test/unit/test_thread.rb +23 -0
  286. data/test/unit/time/test_change.rb +11 -26
  287. data/test/unit/time/test_elapse.rb +10 -25
  288. data/test/unit/time/test_stamp.rb +28 -0
  289. metadata +65 -25
  290. data/lib/core/facets/array/unzip.rb +0 -14
  291. data/lib/core/facets/continuation.rb +0 -1
  292. data/lib/core/facets/enumerable/collate.rb +0 -104
  293. data/lib/core/facets/kernel/require_esc.rb +0 -44
  294. data/lib/more/facets/mapsend.rb +0 -98
  295. data/lib/more/facets/pp_s.rb +0 -30
  296. data/log/history.rd +0 -38
  297. data/log/todo.rd +0 -4
  298. data/task/special/quickopts +0 -15
  299. data/test/unit/continuation/test_create.rb +0 -28
  300. data/test/unit/enumerable/test_collate.rb +0 -51
  301. data/test/unit/kernel/test_require_esc.rb +0 -29
  302. data/test/unit/test_mapsend.rb +0 -18
  303. data/test/unit/test_pp_s.rb +0 -17
@@ -0,0 +1,58 @@
1
+ require 'enumerator'
2
+
3
+ module Enumerable
4
+
5
+ # Like <tt>#map</tt>/<tt>#collect</tt>, but generates a Hash. The block
6
+ # is expected to return two values: the key and the value for the new hash.
7
+ #
8
+ # numbers = (1..3)
9
+ # squares = numbers.mash { |n| [n, n*n] } # { 1=>1, 2=>4, 3=>9 }
10
+ # sq_roots = numbers.mash { |n| [n*n, n] } # { 1=>1, 4=>2, 9=>3 }
11
+ #
12
+ # CREDIT: Trans
13
+ # CREDIT: Andrew Dudzik (adudzik)
14
+ #
15
+ # NOTE: Would #correlate would be better?
16
+
17
+ def mash(&yld)
18
+ if yld
19
+ inject({}) do |h, *kv| # Used to be inject({}) do |h,kv|
20
+ r = *yld[*kv] # The *-op works differnt from to_a on single element hash!!!
21
+ nk, nv = *r # Used to be nk, nv = *yld[*kv].to_a.flatten
22
+ h[nk] = nv
23
+ h
24
+ end
25
+ else
26
+ Enumerator.new(self,:graph) # Used to be Hash[*self.to_a] or Hash[*self.to_a.flatten]
27
+ end
28
+ end
29
+
30
+ # Alias for #mash. This is the original name for this method.
31
+ alias_method :graph, :mash
32
+
33
+ # An alias for #mash that was used for a while b/c of it's similarity to #collect,
34
+ # but it seems like a misnomer and may well be deprecated in the future.
35
+ alias_method :collate, :mash
36
+
37
+ end
38
+
39
+
40
+ class Hash
41
+
42
+ # In place version of #mash.
43
+ #
44
+ # NOTE: Hash#mash! is only useful for Hash. It is not generally
45
+ # applicable to Enumerable.
46
+
47
+ def mash!(&yld)
48
+ replace(mash(&yld))
49
+ end
50
+
51
+ # Alias for #mash!. This is the original name for this method.
52
+ alias_method :graph!, :mash!
53
+
54
+ # An alias for #mash! that was used for a while b/c of it's similarity to #collect,
55
+ # but it seems like a misnomer and may well be deprecated in the future.
56
+ alias_method :collate!, :mash!
57
+
58
+ end
@@ -1,22 +1,12 @@
1
- # TITLE:
2
- # Permutations
3
- #
4
- # DESCRIPTION:
5
- # Enumerble permutation extensions.
6
- #
7
- # AUTHORS:
8
- # - Florian Gross
9
-
10
1
  require 'facets/integer/factorial'
11
2
 
12
- #
13
3
  module Enumerable
14
4
 
15
5
  # Permutation proves the possible orders of an enumerable.
16
6
  # Each is index by a permutation number. The maximum number of
17
7
  # arrangements is the factorial of the size of the array.
18
8
  #
19
- # CREDIT Florian Gross
9
+ # CREDIT: Florian Gross
20
10
 
21
11
  def permutation(number)
22
12
  arr = to_a
@@ -24,7 +14,8 @@ module Enumerable
24
14
  nextfactor = factor = 1
25
15
  arr.each_with_index {|x,i|
26
16
  case i
27
- when 0: next
17
+ when 0
18
+ next
28
19
  else
29
20
  nextfactor = factor * (i+1)
30
21
  out.insert(number % nextfactor / factor, x)
@@ -33,11 +24,12 @@ module Enumerable
33
24
  }
34
25
  out
35
26
  end
36
- alias :permute :permutation
27
+
28
+ alias_method :permute, :permutation
37
29
 
38
30
  # Calculate permutation number.
39
31
  #
40
- # CREDIT Florian Gross
32
+ # CREDIT: Florian Gross
41
33
 
42
34
  def permutation_number(original_array=self.to_a.sort)
43
35
  arr = to_a
@@ -66,41 +58,44 @@ module Enumerable
66
58
  # cab
67
59
  # cba
68
60
  #
69
- # CREDIT Florian Gross
61
+ # CREDIT: Daniel Sheppard
70
62
 
71
63
  def each_permutation()
72
- arr = to_a
73
- size = arr.size
74
- perm_count = (1...size).inject(0) { |s,x| s + x * x.factorial }
75
- weights = Array.new(size-1) {|i| (i+1).factorial }
76
- s = weights.size
77
- x,i,v,pos = nil
78
- 0.upto(perm_count) do |v|
79
- out = arr[0..0]
80
- arr.each_with_index {|x,i|
81
- case i
82
- when 0: next
83
- when s: out.insert(v / weights[i-1], x)
84
- else out.insert(v % weights[i] / weights[i-1], x)
85
- end
86
- }
64
+ pos = Array.new(size) {|i| i}
65
+ s = (0...size).to_a.reverse
66
+ out = nil
67
+ while true
68
+ out = []
69
+ pos.each_with_index {|p,i| out.insert(p, self[i]) }
87
70
  yield out
71
+ break if s.each do |i|
72
+ break if pos[i] > 0 && pos[i] -= 1
73
+ pos[i] = i
74
+ end
88
75
  end
89
76
  end
90
77
 
91
- #-- OLD VERSION
92
- #def each_permutation( prefixed=[] )
93
- # s = self.to_a
94
- # if (length < 2)
95
- # # there are no elements left to permute
96
- # yield(prefixed + self)
97
- # else
98
- # # recursively permute the remaining elements
99
- # s.each_with_index do |e, i|
100
- # (s[0,i]+s[(i+1)..-1]).each_permutation(prefixed+[e]) { |a| yield a }
101
- # end
102
- # end
103
- #end
104
- #++
78
+ # OLD VERSION
79
+ # # CREDIT: Florian Gross
80
+ #
81
+ # def each_permutation()
82
+ # arr = to_a
83
+ # size = arr.size
84
+ # perm_count = (1...size).inject(0) { |s,x| s + x * x.factorial }
85
+ # weights = Array.new(size-1) {|i| (i+1).factorial }
86
+ # s = weights.size
87
+ # x,i,v,pos = nil
88
+ # 0.upto(perm_count) do |v|
89
+ # out = arr[0..0]
90
+ # arr.each_with_index {|x,i|
91
+ # case i
92
+ # when 0: next
93
+ # when s: out.insert(v / weights[i-1], x)
94
+ # else out.insert(v % weights[i] / weights[i-1], x)
95
+ # end
96
+ # }
97
+ # yield out
98
+ # end
99
+ # end
105
100
 
106
101
  end
@@ -1,30 +1,10 @@
1
- # TITLE:
2
- #
3
- # Enumerable Statistical Extensions
4
- #
5
- # FILE:
6
- #
7
- # statistics.rb
8
- #
9
- # DESCRIPTION:
10
- #
11
- # Extensions for statistical information.
12
- #
13
- # Note that String#entropy has been deprecated.
14
- # Use str.chars.entropy instead.
15
- #
16
- # AUTHORS:
17
- #
18
- # CREDIT Derek
19
- # CREDIT Brian Schröder
20
- # CREDIT Florian Gross
21
-
22
- #
23
1
  module Enumerable
24
2
 
25
3
  # In Statistics mode is the value that occurs most
26
4
  # frequently in a given set of data.
27
5
  #
6
+ # CREDIT: Trans
7
+
28
8
  def mode
29
9
  count = Hash.new(0)
30
10
  each {|x| count[x] += 1 }
@@ -34,10 +14,9 @@ module Enumerable
34
14
  # Generates a hash mapping each unique symbol in the array
35
15
  # to the relative frequency, i.e. the probablity, of
36
16
  # it appearence.
37
- #--
38
- # Credit goes to Brian Schröder for current code
39
- # and Derek for original.
40
- #++
17
+ #
18
+ # CREDIT: Brian Schröder
19
+
41
20
  def probability
42
21
  probs = Hash.new(0.0)
43
22
  size = 0.0
@@ -64,8 +43,6 @@ module Enumerable
64
43
  # probHash
65
44
  # end
66
45
 
67
- # CREDIT Derek
68
-
69
46
  # Shannon's entropy for an array - returns the average
70
47
  # bits per symbol required to encode the array.
71
48
  # Lower values mean less "entropy" - i.e. less unique
@@ -73,6 +50,8 @@ module Enumerable
73
50
  #
74
51
  # %w{ a b c d e e e }.entropy #=>
75
52
  #
53
+ # CREDIT: Derek
54
+
76
55
  def entropy
77
56
  arr = to_a
78
57
  probHash = arr.probability
@@ -83,12 +62,12 @@ module Enumerable
83
62
  h
84
63
  end
85
64
 
86
- # CREDIT Derek
87
-
88
65
  # Returns the maximum possible Shannon entropy of the array
89
66
  # with given size assuming that it is an "order-0" source
90
67
  # (each element is selected independently of the next).
91
68
  #
69
+ # CREDIT: Derek
70
+
92
71
  def ideal_entropy
93
72
  arr = to_a
94
73
  unitProb = 1.0.to_f / arr.size.to_f
@@ -97,9 +76,9 @@ module Enumerable
97
76
 
98
77
  # Generates a hash mapping each unique symbol in the array
99
78
  # to the absolute frequency it appears.
100
- #--
101
- # Credit goes to Brian Schröder and Derek for inspiration.
102
- #++
79
+ #
80
+ # CREDIT: Brian Schröder
81
+
103
82
  def frequency
104
83
  #probs = Hash.new(0)
105
84
  #each do |e|
@@ -121,9 +100,8 @@ module Enumerable
121
100
  # # Returns all persons that share their last name with another person.
122
101
  # persons.collisions { |person| person.last_name }
123
102
  #
124
- #--
125
- # Credit goes to Florian Gross.
126
- #++
103
+ # CREDIT: Florian Gross
104
+
127
105
  def commonality( &block )
128
106
  had_no_block = !block
129
107
  block ||= lambda { |item| item }
@@ -152,6 +130,8 @@ end
152
130
 
153
131
  # class String
154
132
  #
133
+ # NOTE: String#entropy has been deprecated.
134
+ # Use str.chars.entropy instead.
155
135
  # def entropy
156
136
  # split(//).entropy
157
137
  # end
@@ -162,57 +142,3 @@ end
162
142
  # # end
163
143
  #
164
144
  # end
165
-
166
-
167
-
168
- # _____ _
169
- # |_ _|__ ___| |_
170
- # | |/ _ \/ __| __|
171
- # | | __/\__ \ |_
172
- # |_|\___||___/\__|
173
- #
174
- =begin test
175
-
176
- require 'test/unit'
177
-
178
- class TestEnumerable < Test::Unit::TestCase
179
-
180
- def test_entropy
181
- assert_equal( 1.0, %w{ a b }.entropy )
182
- end
183
-
184
- def test_ideal_entropy
185
- assert_equal( 1.0, %w{ a b }.ideal_entropy )
186
- assert_equal( 2.0, %w{ a a b b }.ideal_entropy )
187
- end
188
-
189
- def test_probability
190
- assert_equal( {'a'=>0.5,'b'=>0.5}, %w{a b}.probability )
191
- assert_equal( {'tom'=>0.5,'boy'=>0.5}, %w{tom boy}.probability )
192
- end
193
-
194
- def test_frequency
195
- assert_equal( {'a'=>1,'b'=>1}, %w{a b}.frequency )
196
- assert_equal( {'tom'=>1,'boy'=>1}, %w{tom boy}.frequency )
197
- end
198
-
199
- def test_commonality
200
- a = [1,2,2,3,3,3]
201
- r = { 2 => [2,2], 3 => [3,3,3] }
202
- assert_equal( r, a.commonality )
203
- a = [1,2,2,3,3,3]
204
- r = {false=>[1, 2, 2], true=>[3, 3, 3]}
205
- assert_equal( r, a.commonality { |x| x > 2 } )
206
- end
207
-
208
- # def test_collisions
209
- # a = [1,2,2,3,3,3]
210
- # assert_equal( [2,3], a.collisions )
211
- # a = [1,2,2,3,3,3]
212
- # r = {false=>[1, 2, 2], true=>[3, 3, 3]}
213
- # assert_equal( r, a.collisions { |x| x > 2 } )
214
- # end
215
-
216
- end
217
-
218
- =end
@@ -0,0 +1,113 @@
1
+ module Enumerable
2
+
3
+ unless (RUBY_VERSION[0,3] == '1.9')
4
+ # #group_by is used to group items in a collection by something they
5
+ # have in common. The common factor is the key in the resulting hash, the
6
+ # array of like elements is the value.
7
+ #
8
+ # (1..5).group_by { |n| n % 3 }
9
+ # #=> { 0 => [3], 1 => [1, 4], 2 => [2,5] }
10
+ #
11
+ # ["I had", 1, "dollar and", 50, "cents"].group_by { |e| e.class }
12
+ # #=> { String => ["I had","dollar and","cents"], Fixnum => [1,50] }
13
+ #
14
+ # CREDIT: Erik Veenstra
15
+ #
16
+ # TODO:
17
+ # - Deprecate #group_by when released for Ruby 1.9.
18
+
19
+ def group_by #:yield:
20
+ #h = k = e = nil
21
+ r = Hash.new
22
+ each{ |e| (r[yield(e)] ||= []) << e }
23
+ r
24
+ end
25
+ end
26
+
27
+ # This alias is the original Facets name for the method, but Ruby 1.9 has
28
+ # adopted #group_by as the name, so eventually #partition_by will be deprecated.
29
+
30
+ alias_method :partition_by, :group_by
31
+
32
+ # Split on matching pattern. Unlike #divide this does not include matching elements.
33
+ #
34
+ # ['a1','a2','b1','a3','b2','a4'].split(/^b/)
35
+ # => [['a1','a2'],['a3'],['a4']]
36
+ #
37
+ # CREDIT: Trans
38
+
39
+ def split(pattern)
40
+ memo = []
41
+ each do |obj|
42
+ if pattern === obj
43
+ memo.push []
44
+ else
45
+ memo.last << obj
46
+ end
47
+ end
48
+ memo
49
+ end
50
+
51
+ # Divide on matching pattern.
52
+ #
53
+ # ['a1','b1','a2','b2'].divide(/^a/)
54
+ # => [['a1,'b1'],['a2','b2']]
55
+ #
56
+ # CREDIT: Trans
57
+
58
+ def divide(pattern)
59
+ memo = []
60
+ each do |obj|
61
+ memo.push [] if pattern === obj
62
+ memo.last << obj
63
+ end
64
+ memo
65
+ end
66
+
67
+ # Similar to #group_by but returns an array of the groups.
68
+ # Returned elements are sorted by block.
69
+ #
70
+ # %w{this is a test}.cluster_by {|x| x[0]}
71
+ #
72
+ # _produces_
73
+ #
74
+ # [ ['a'], ['is'], ['this', 'test'] ]
75
+ #
76
+ # CREDIT Erik Veenstra
77
+
78
+ def cluster_by(&b)
79
+ group_by(&b).sort.transpose.pop || [] # group_by(&b).values ?
80
+ end
81
+
82
+ # Modulate. Divide an array into groups by modulo of the index.
83
+ #
84
+ # [2,4,6,8].modulate(2) #=> [[2,6],[4,8]]
85
+ #
86
+ # CREDIT: Trans
87
+ #
88
+ # NOTE: Would this be better named 'collate'?
89
+
90
+ def modulate(modulo)
91
+ return to_a if modulo == 1
92
+ raise ArgumentError, 'bad modulo' if size % modulo != 0
93
+ r = Array.new(modulo, [])
94
+ (0...size).each do |i|
95
+ r[i % level] += [self[i]]
96
+ end
97
+ r
98
+ end
99
+
100
+ # DEPRECATED -- Use 'each_slice(n).to_a' as of 1.9.
101
+ # Partition an array into parts of given length.
102
+ #
103
+ # CREDIT WhyTheLuckyStiff
104
+ #
105
+ # def / len
106
+ # inject([]) do |ary, x|
107
+ # ary << [] if [*ary.last].nitems % len == 0
108
+ # ary.last << x
109
+ # ary
110
+ # end
111
+ # end
112
+
113
+ end