File: minimization_powell_spec_spec.rb

package info (click to toggle)
ruby-minimization 0.2.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 232 kB
  • sloc: ruby: 1,243; makefile: 3
file content (61 lines) | stat: -rw-r--r-- 1,746 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
begin
  require "#{File.expand_path(File.dirname(__FILE__))}/../lib/multidim/powell.rb"
rescue LoadError
  require "multidim/powell"
end

describe Minimization::Powell do
  before :all do
    @n           = 3
    @limit       = 100
    @epsilon     = 1e-5
    @p           = Array.new(@n)
    @start_point = Array.new(@n)

    0.upto(@n - 1) do |i|
      @p[i] = rand(@limit)
    end

    0.upto(@n - 1) do |i|
      @start_point[i] = rand(@limit)
    end

    # example 1
    f = proc{ |x| (x[0] - @p[0])**2 + (x[1] - @p[1])**2 + (x[2] - @p[2])**2 }
    @min1 = Minimization::Powell.minimize(f, @start_point, [-@limit, -@limit, -@limit], [@limit, @limit, @limit])

    # example 2
    @k = rand(@limit)
    f2 = proc{ |x| ( @p[0]*x[0] + @p[1]*x[1] + @p[2]*x[2] )**2 +  @k}
    @min2 = Minimization::Powell.minimize(f2, @start_point, [-@limit, -@limit, -@limit], [@limit, @limit, @limit])

    # example 3 : unidimensional
    f3 = proc{ |x| (x[0] - @p[0])**2 + @k}
    @min3 = Minimization::Powell.minimize(f3, @start_point, [-@limit, -@limit, -@limit], [@limit, @limit, @limit])

  end

  it "#x_minimum be close to expected in example 1" do 
    0.upto(@n - 1) do |i|
      expect(@min1.x_minimum[i]).to be_within(@epsilon).of(@p[i])
    end
  end

  it "#f_minimum be close to expected in example 1" do 
    expect(@min1.f_minimum).to be_within(@epsilon).of(0)
  end

  it "#f_minimum be close to expected in example 2" do 
    expect(@min2.f_minimum).to be_within(@epsilon).of(@k)
  end

  it "#x_minimum be close to expected in example 3" do 
    expect(@min3.x_minimum[0]).to be_within(@epsilon).of(@p[0])
  end

  it "#f_minimum be close to expected in example 3" do 
    expect(@min3.f_minimum).to be_within(@epsilon).of(@k)
  end

end