WarpPI/core/src/main/java/it/cavallium/warppi/math/rules/functions/MultiplicationRule.java

62 lines
2.0 KiB
Java

package it.cavallium.warppi.math.rules.functions;
/*
SETTINGS: (please don't move this part)
PATH=functions.MultiplicationRule
*/
import it.cavallium.warppi.math.Function;
import it.cavallium.warppi.math.functions.Multiplication;
import it.cavallium.warppi.math.functions.Number;
import it.cavallium.warppi.math.rules.Rule;
import it.cavallium.warppi.math.rules.RuleType;
import it.unimi.dsi.fastutil.objects.ObjectArrayList;
/**
* Multiplication
* a*b = c
*
* @author Andrea Cavalli
*
*/
public class MultiplicationRule implements Rule {
// Rule name
@Override
public String getRuleName() {
return "Multiplication";
}
// Rule type
@Override
public RuleType getRuleType() {
return RuleType.CALCULATION;
}
/* Rule function
Returns:
- null if it's not executable on the function "f"
- An ObjectArrayList<Function> if it did something
*/
@Override
public ObjectArrayList<Function> execute(final Function f) {
if (f instanceof Multiplication) {
final ObjectArrayList<Function> result = new ObjectArrayList<>();
final Function variable1 = ((Multiplication) f).getParameter1();
final Function variable2 = ((Multiplication) f).getParameter2();
if (variable1 instanceof Number && variable2 instanceof Number) {
//multiply a by b (a*b = c)
result.add(((Number) variable1).multiply((Number) variable2));
return result;
} else if (!(variable1 instanceof Number) && variable2 instanceof Number) {
//fix order: x*n -> n*x
result.add(new Multiplication(f.getMathContext(), variable2, variable1));
return result;
} else if (!(variable1 instanceof Multiplication) && variable2 instanceof Multiplication) {
//fix order: x*(y*z) -> (x*y)*z
result.add(new Multiplication(f.getMathContext(), new Multiplication(f.getMathContext(), variable1, ((Multiplication) variable2).getParameter1()), ((Multiplication) variable2).getParameter2()));
return result;
}
}
return null;
}
}