rann 0.2.1 → 0.2.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 6dff2d631ccf502189d84d05fa9835cb8fa68c9d
4
- data.tar.gz: cb1df08ddd1421e2c4a4f736fb8d946bafabbd8e
3
+ metadata.gz: 1d6d82c495eff427af738f4734993fd2611848b9
4
+ data.tar.gz: de50063a5696ae822b565ce61629f4474e237d78
5
5
  SHA512:
6
- metadata.gz: aaa784026bb0e1a7efd2234b1bb906aee50dfb392677825264f8b77fd5f9a23a04679a6c23306d7a70bc8d0e15a553d804e76afdd4a448198d9f67b05ad50392
7
- data.tar.gz: ee77695cfb639fa917a5684628ba9681c4484a60c863b814805697f1fe81f9da834f866069136e38b60afcc1322575627714716bd228764b7a5ddd978860c9f5
6
+ metadata.gz: 478e37a62c101eec3f8bc23125c308fb49f27257b80a119dea4747c481fe65f5d53397db7013cf4642e097ff81699471d4e6ff860720e2366fd90cf2760ca61a
7
+ data.tar.gz: 1a131eb754900d36f2353064cd8b05f1e179adbbee95e25063511a029636378490dff0b2f1bc7678a31027d0dbc6b0fee6bd20df14ef25ace465b6b31fff828e
data/lib/rann/backprop.rb CHANGED
@@ -34,9 +34,12 @@ module RANN
34
34
  avg_gradients = Hash.new{ |h, k| h[k] = 0 }
35
35
  avg_batch_error = 0
36
36
 
37
- # force longer bits of work per iteration, to maximise CPU usage
38
- # less marshalling data etc, more work.
39
- grouped_inputs = in_groups(inputs, [1, opts[:processes]].max * 10, false).reject &:empty?
37
+ # force longer bits of work per iteration, to maximise CPU usage less
38
+ # marshalling data and process overhead etc. best for small networks. for
39
+ # larger networks where one unit of work takes a long time, and the work
40
+ # can vary in time taken, use num_groups == inputs.size
41
+ num_groups = opts[:num_groups] || ([1, opts[:processes]].max * 10)
42
+ grouped_inputs = in_groups(inputs, num_groups, false).reject &:empty?
40
43
  reduce_proc =
41
44
  lambda do |_, _, result|
42
45
  group_avg_gradients, group_avg_error = result
@@ -110,8 +113,8 @@ module RANN
110
113
  error = mse targets, outputs
111
114
 
112
115
  # backward pass with unravelling for recurrent networks
113
- node_deltas = Hash.new{ |h, k| h[k] = Hash.new(0.to_d) }
114
- gradients = Hash.new(0)
116
+ node_deltas = Hash.new{ |h, k| h[k] = Hash.new 0.to_d }
117
+ gradients = Hash.new 0.to_d
115
118
 
116
119
  initial_timestep = inputs.size - 1
117
120
  neuron_stack = network.output_neurons.map{ |n| [n, initial_timestep] }
data/lib/rann/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module RANN
2
- VERSION = "0.2.1"
2
+ VERSION = "0.2.2"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rann
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.2.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Michael Campbell
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2017-11-24 00:00:00.000000000 Z
11
+ date: 2017-11-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: parallel