Class: BOAST::GenericOptimization

Inherits:
Object
  • Object
show all
Defined in:
lib/BOAST/Optimization.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(*parameters) ⇒ GenericOptimization

Returns a new instance of GenericOptimization.



60
61
62
63
64
65
66
67
68
69
70
# File 'lib/BOAST/Optimization.rb', line 60

def initialize( *parameters )
  if parameters.length == 1 and parameters[0].is_a?(Hash) then
    @parameters = []
    parameters[0].each { |key, value|
      @parameters.push( OptimizationParameter::new(key, value) )
    }
  else
    @parameters = parameters
  end
  @repeat = 3
end

Instance Attribute Details

#parametersObject (readonly)

Returns the value of attribute parameters.



24
25
26
# File 'lib/BOAST/Optimization.rb', line 24

def parameters
  @parameters
end

#repeatObject

Returns the value of attribute repeat.



23
24
25
# File 'lib/BOAST/Optimization.rb', line 23

def repeat
  @repeat
end

Instance Method Details

#each(&block) ⇒ Object



52
53
54
# File 'lib/BOAST/Optimization.rb', line 52

def each(&block)
  return self.points.each(&block)
end

#each_random(&block) ⇒ Object



56
57
58
# File 'lib/BOAST/Optimization.rb', line 56

def each_random(&block)
  return self.points.shuffle.each(&block)
end

#pointsObject



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/BOAST/Optimization.rb', line 31

def points
  pts=[]
  params2 = @parameters.dup
  param = params2.shift
  optim2 = GenericOptimization::new(*params2)
  param.values.each{ |val| 
    pts.push({param.name.to_sym => val})
  }
  if optim2.size == 0 then
    return pts
  else
    pts3=[]
    pts.each{ |p1| 
      optim2.each { |p2| 
        pts3.push(p1.dup.update(p2))
      }
    }
    return pts3
  end
end

#sizeObject



27
28
29
# File 'lib/BOAST/Optimization.rb', line 27

def size
  return @parameters.size
end