1
0

Formula#calculate is using QuantityInput

Updated FormulaBuilder to properly index parts[]
This commit is contained in:
cryptogopher 2020-05-17 18:14:19 +02:00
parent c402fe8353
commit fa9c329a81
3 changed files with 24 additions and 6 deletions

View File

@ -20,7 +20,7 @@ class Formula < ActiveRecord::Base
def calculate(inputs)
raise(InvalidInputs, 'No inputs') if inputs.empty?
deps = inputs.map { |q, v| [q.name, v.transpose.first] }.to_h
deps = inputs.map { |q, v| [q.name, QuantityInput.new(q, v.transpose.first)] }.to_h
length = deps.values.first.length
raise(InvalidFormula, 'Invalid formula') unless self.valid?
@ -47,6 +47,10 @@ class Formula < ActiveRecord::Base
super(*args)
@quantity = q
end
def lastBefore(timepoints)
self.map{ BigDecimal(2000) }
end
end
def parse
@ -77,7 +81,7 @@ class Formula < ActiveRecord::Base
errors
end
def get_binding(quantities, args, length)
def get_binding(quantities, parts, length)
binding
end
end

View File

@ -177,7 +177,14 @@ module BodyTracking
[
:bt_expression,
[left, right].map do |side|
side[0] == :bt_quantity ? "quantities['#{side[1]}'][_index]" : "#{side[1]}"
case side[0]
when :bt_quantity
"quantities['#{side[1]}'][_index]"
when :bt_quantity_method_call
"#{side[1]}[_index]"
else
"#{side[1]}"
end
end.join(op.to_s)
]
end

View File

@ -65,13 +65,20 @@ class FormulaTest < ActiveSupport::TestCase
# Model method calls
'100*Energy/RM.lastBefore(Meal.eaten_at||Meal.created_at)', Set['Energy', 'RM', 'Meal'],
# TODO: fill parts
[]
[
{type: :indexed, content: "quantities['Meal'][_index].eaten_at||" \
"quantities['Meal'][_index].created_at"},
{type: :unindexed, content: "quantities['RM'].lastBefore(parts[0])"},
{type: :indexed, content: "100*quantities['Energy'][_index]/parts[1][_index]"}
]
]
d_methods = ['nil?', 'abs']
q_methods = Hash.new(['all', 'lastBefore'])
q_methods['Meal'] = ['created_at', 'eaten_at']
vector.each_slice(3) do |formula, identifiers, parts|
parser = FormulaBuilder.new(formula, d_methods: d_methods)
parser = FormulaBuilder.new(formula, d_methods: d_methods, q_methods: q_methods)
i, p = parser.parse
assert_empty parser.errors
assert_equal identifiers, i