Finished fixing all the classes.
This commit is contained in:
parent
ceb1304675
commit
a8508eea8e
@ -41,10 +41,10 @@ public class Root extends FunctionTwoValues {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isSolvable() {
|
protected boolean isSolvable() {
|
||||||
if (variable1 instanceof Number & variable2 instanceof Number) {
|
if (variable1 instanceof Number & variable2 instanceof Number) {
|
||||||
if (root.exactMode == false) {
|
if (root.exactMode == false) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
Number exponent = new Number(root, BigDecimal.ONE);
|
Number exponent = new Number(root, BigDecimal.ONE);
|
||||||
exponent = exponent.divide((Number) variable1);
|
exponent = exponent.divide((Number) variable1);
|
||||||
@ -55,7 +55,7 @@ public class Root extends FunctionTwoValues {
|
|||||||
}
|
}
|
||||||
} catch (Exception | Error ex) {
|
} catch (Exception | Error ex) {
|
||||||
ex.printStackTrace();
|
ex.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (variable1 instanceof Number && ((Number)variable1).equals(new Number(root, 2))) {
|
if (variable1 instanceof Number && ((Number)variable1).equals(new Number(root, 2))) {
|
||||||
return true;
|
return true;
|
||||||
@ -65,7 +65,7 @@ public class Root extends FunctionTwoValues {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ArrayList<Function> solve() throws Error {
|
public ArrayList<Function> solve() throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
if (root.exactMode) {
|
if (root.exactMode) {
|
||||||
if (variable1 instanceof Number && ((Number)variable1).equals(new Number(root, 2))) {
|
if (variable1 instanceof Number && ((Number)variable1).equals(new Number(root, 2))) {
|
||||||
result.add(new RootSquare(root, variable2));
|
result.add(new RootSquare(root, variable2));
|
||||||
@ -78,7 +78,7 @@ public class Root extends FunctionTwoValues {
|
|||||||
Number exp = (Number) variable1;
|
Number exp = (Number) variable1;
|
||||||
Number numb = (Number) variable2;
|
Number numb = (Number) variable2;
|
||||||
|
|
||||||
result.add(numb.pow(new Number(root, 1).divide(exp)));
|
result.add(numb.pow(new Number(root, 1).divide(exp)));
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -36,8 +36,8 @@ public class RootSquare extends AnteriorFunction {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean isSolvable() {
|
protected boolean isSolvable() {
|
||||||
if (variable instanceof Number) {
|
if (variable instanceof Number) {
|
||||||
if (root.exactMode == false) {
|
if (root.exactMode == false) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
@ -57,7 +57,7 @@ public class RootSquare extends AnteriorFunction {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ArrayList<Function> solve() throws Error {
|
public ArrayList<Function> solve() throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
if (root.exactMode) {
|
if (root.exactMode) {
|
||||||
Number exponent = new Number(root, BigInteger.ONE);
|
Number exponent = new Number(root, BigInteger.ONE);
|
||||||
exponent = exponent.divide(new Number(root, 2));
|
exponent = exponent.divide(new Number(root, 2));
|
||||||
@ -66,7 +66,7 @@ public class RootSquare extends AnteriorFunction {
|
|||||||
Number exp = new Number(root, 2);
|
Number exp = new Number(root, 2);
|
||||||
Number numb = (Number) variable;
|
Number numb = (Number) variable;
|
||||||
|
|
||||||
result.add(numb.pow(new Number(root, 1).divide(exp)));
|
result.add(numb.pow(new Number(root, 1).divide(exp)));
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -74,14 +74,14 @@ public class Sum extends FunctionTwoValues {
|
|||||||
} else if (SumMethod1.compare(this)) {
|
} else if (SumMethod1.compare(this)) {
|
||||||
result = SumMethod1.execute(this);
|
result = SumMethod1.execute(this);
|
||||||
} else if (variable1.isSolved() & variable2.isSolved()) {
|
} else if (variable1.isSolved() & variable2.isSolved()) {
|
||||||
if ((root.getChild().equals(this))) {
|
if ((root.getChild().equals(this))) {
|
||||||
if (((Number)variable1).term.compareTo(new BigDecimal(2)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(2)) == 0) {
|
if (((Number)variable1).term.compareTo(new BigDecimal(2)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(2)) == 0) {
|
||||||
result.add(new Joke(root, Joke.FISH));
|
result.add(new Joke(root, Joke.FISH));
|
||||||
return result;
|
return result;
|
||||||
} else if (((Number)variable1).term.compareTo(new BigDecimal(20)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(20)) == 0) {
|
} else if (((Number)variable1).term.compareTo(new BigDecimal(20)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(20)) == 0) {
|
||||||
result.add(new Joke(root, Joke.TORNADO));
|
result.add(new Joke(root, Joke.TORNADO));
|
||||||
return result;
|
return result;
|
||||||
} else if (((Number)variable1).term.compareTo(new BigDecimal(29)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(29)) == 0) {
|
} else if (((Number)variable1).term.compareTo(new BigDecimal(29)) == 0 && ((Number)variable2).term.compareTo(new BigDecimal(29)) == 0) {
|
||||||
result.add(new Joke(root, Joke.SHARKNADO));
|
result.add(new Joke(root, Joke.SHARKNADO));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Negative;
|
import org.warp.picalculator.math.functions.Negative;
|
||||||
@ -39,10 +40,10 @@ public class ExpandRule5 {
|
|||||||
|
|
||||||
if (f instanceof Negative) {
|
if (f instanceof Negative) {
|
||||||
Negative fnc = (Negative) f;
|
Negative fnc = (Negative) f;
|
||||||
result.add(((Negative)((Expression)fnc.getVariable()).getVariable(0)).getVariable().setParent(root));
|
result.add(((Negative)((Expression)fnc.getVariable()).getVariable(0)).getVariable());
|
||||||
} else if (f instanceof Subtraction) {
|
} else if (f instanceof Subtraction) {
|
||||||
Subtraction fnc = (Subtraction) f;
|
Subtraction fnc = (Subtraction) f;
|
||||||
result.add(((Negative)((Expression)fnc.getVariable2()).getVariable(0)).getVariable().setParent(root));
|
result.add(((Negative)((Expression)fnc.getVariable2()).getVariable(0)).getVariable());
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
@ -29,13 +30,14 @@ public class ExponentRule16 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Multiplication fnc = (Multiplication) f;
|
Multiplication fnc = (Multiplication) f;
|
||||||
Power p = new Power(fnc.getParent(), null, null);
|
Power p = new Power(fnc.getRoot(), null, null);
|
||||||
Expression expr = new Expression(p);
|
Expression expr = new Expression(root);
|
||||||
Function a = fnc.getVariable1().setParent(expr);
|
Function a = fnc.getVariable1();
|
||||||
expr.addFunctionToEnd(a);
|
expr.addFunctionToEnd(a);
|
||||||
Number two = new Number(p, 2);
|
Number two = new Number(root, 2);
|
||||||
p.setVariable1(expr);
|
p.setVariable1(expr);
|
||||||
p.setVariable2(two);
|
p.setVariable2(two);
|
||||||
result.add(p);
|
result.add(p);
|
||||||
|
@ -17,7 +17,7 @@ public class ExponentRule2 {
|
|||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
if (fnc.getVariable2().equals(new Number(root, 1))) {
|
if (fnc.getVariable2().equals(new Number(f.getRoot(), 1))) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -25,7 +25,7 @@ public class ExponentRule2 {
|
|||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(((Power)f).getVariable1().setParent(root));
|
result.add(((Power)f).getVariable1());
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ public class ExponentRule3 {
|
|||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
if (fnc.getVariable2().equals(new Number(root, 0))) {
|
if (fnc.getVariable2().equals(new Number(f.getRoot(), 0))) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -25,7 +25,7 @@ public class ExponentRule3 {
|
|||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Number(f.getParent(), 1));
|
result.add(new Number(f.getRoot(), 1));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
@ -26,6 +27,7 @@ public class ExponentRule4 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
Expression expr = (Expression) fnc.getVariable1();
|
Expression expr = (Expression) fnc.getVariable1();
|
||||||
@ -33,14 +35,14 @@ public class ExponentRule4 {
|
|||||||
Function a = mult.getVariable1();
|
Function a = mult.getVariable1();
|
||||||
Function b = mult.getVariable2();
|
Function b = mult.getVariable2();
|
||||||
Number n = (Number) fnc.getVariable2();
|
Number n = (Number) fnc.getVariable2();
|
||||||
Multiplication retMult = new Multiplication(f.getParent(), null, null);
|
Multiplication retMult = new Multiplication(root, null, null);
|
||||||
Power p1 = new Power(retMult, null, null);
|
Power p1 = new Power(root, null, null);
|
||||||
Expression e1 = new Expression(p1);
|
Expression e1 = new Expression(root);
|
||||||
e1.addFunctionToEnd(a);
|
e1.addFunctionToEnd(a);
|
||||||
p1.setVariable1(e1);
|
p1.setVariable1(e1);
|
||||||
p1.setVariable2(n);
|
p1.setVariable2(n);
|
||||||
Power p2 = new Power(retMult, null, null);
|
Power p2 = new Power(root, null, null);
|
||||||
Expression e2 = new Expression(p2);
|
Expression e2 = new Expression(root);
|
||||||
e2.addFunctionToEnd(b);
|
e2.addFunctionToEnd(b);
|
||||||
p2.setVariable1(e2);
|
p2.setVariable1(e2);
|
||||||
p2.setVariable2(n);
|
p2.setVariable2(n);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Division;
|
import org.warp.picalculator.math.functions.Division;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
@ -16,25 +17,26 @@ import org.warp.picalculator.math.functions.Number;
|
|||||||
public class FractionsRule1 {
|
public class FractionsRule1 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
Division fnc = (Division) f;
|
Calculator root = f.getRoot();
|
||||||
if (fnc.getVariable1() instanceof Number) {
|
Division fnc = (Division) f;
|
||||||
Number numb1 = (Number) fnc.getVariable1();
|
if (fnc.getVariable1() instanceof Number) {
|
||||||
if (numb1.equals(new Number(root, 0))) {
|
Number numb1 = (Number) fnc.getVariable1();
|
||||||
if (fnc.getVariable2() instanceof Number) {
|
if (numb1.equals(new Number(root, 0))) {
|
||||||
Number numb2 = (Number) fnc.getVariable2();
|
if (fnc.getVariable2() instanceof Number) {
|
||||||
if (numb2.equals(new Number(root, 0))) {
|
Number numb2 = (Number) fnc.getVariable2();
|
||||||
return false;
|
if (numb2.equals(new Number(root, 0))) {
|
||||||
}
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Number(f.getParent(), 0));
|
result.add(new Number(f.getRoot(), 0));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ public class FractionsRule2 {
|
|||||||
Division fnc = (Division) f;
|
Division fnc = (Division) f;
|
||||||
if (fnc.getVariable2() instanceof Number) {
|
if (fnc.getVariable2() instanceof Number) {
|
||||||
Number numb = (Number) fnc.getVariable2();
|
Number numb = (Number) fnc.getVariable2();
|
||||||
if (numb.equals(new Number(root, 1))) {
|
if (numb.equals(new Number(f.getRoot(), 1))) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -29,7 +29,7 @@ public class FractionsRule2 {
|
|||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Division fnc = (Division) f;
|
Division fnc = (Division) f;
|
||||||
result.add(fnc.getVariable1().setParent(root));
|
result.add(fnc.getVariable1());
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ public class FractionsRule3 {
|
|||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Number(f.getParent(), 1));
|
result.add(new Number(f.getRoot(), 1));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ public class FractionsRule4 {
|
|||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
if (fnc.getVariable1() instanceof Division && fnc.getVariable2() instanceof Number) {
|
if (fnc.getVariable1() instanceof Division && fnc.getVariable2() instanceof Number) {
|
||||||
Number n2 = (Number) fnc.getVariable2();
|
Number n2 = (Number) fnc.getVariable2();
|
||||||
if (n2.equals(new Number(root, -1))) {
|
if (n2.equals(new Number(f.getRoot(), -1))) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -32,7 +32,7 @@ public class FractionsRule4 {
|
|||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
Function a = ((Division)fnc.getVariable1()).getVariable1();
|
Function a = ((Division)fnc.getVariable1()).getVariable1();
|
||||||
Function b = ((Division)fnc.getVariable1()).getVariable2();
|
Function b = ((Division)fnc.getVariable1()).getVariable2();
|
||||||
Division res = new Division(f.getParent(), b, a);
|
Division res = new Division(f.getRoot(), b, a);
|
||||||
result.add(res);
|
result.add(res);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
package org.warp.picalculator.math.rules;
|
package org.warp.picalculator.math.rules;
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
import org.warp.picalculator.math.functions.Division;
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Division;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
|
import org.warp.picalculator.math.functions.Number;
|
||||||
import org.warp.picalculator.math.functions.Power;
|
import org.warp.picalculator.math.functions.Power;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -20,7 +21,7 @@ public class FractionsRule5 {
|
|||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
if (fnc.getVariable1() instanceof Division && fnc.getVariable2() instanceof Number) {
|
if (fnc.getVariable1() instanceof Division && fnc.getVariable2() instanceof Number) {
|
||||||
Number n2 = (Number) fnc.getVariable2();
|
Number n2 = (Number) fnc.getVariable2();
|
||||||
if (n2.getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
if (n2.getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -28,14 +29,14 @@ public class FractionsRule5 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
Function a = ((Division)fnc.getVariable1()).getVariable1();
|
Function a = ((Division)fnc.getVariable1()).getVariable1();
|
||||||
Function b = ((Division)fnc.getVariable1()).getVariable2();
|
Function b = ((Division)fnc.getVariable1()).getVariable2();
|
||||||
Function c = ((Number)fnc.getVariable2()).multiply(new Number(root, "-1"));
|
Function c = ((Number)fnc.getVariable2()).multiply(new Number(root, "-1"));
|
||||||
Division dv = new Division(root, b, a);
|
Division dv = new Division(root, b, a);
|
||||||
Power pow = new Power(f.getParent(), dv, c);
|
Power pow = new Power(root, dv, c);
|
||||||
dv.setParent(pow);
|
|
||||||
result.add(pow);
|
result.add(pow);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
@ -16,6 +17,7 @@ import org.warp.picalculator.math.functions.Number;
|
|||||||
public class NumberRule1 {
|
public class NumberRule1 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
Multiplication mult = (Multiplication) f;
|
Multiplication mult = (Multiplication) f;
|
||||||
if (mult.getVariable1() instanceof Number) {
|
if (mult.getVariable1() instanceof Number) {
|
||||||
Number numb = (Number) mult.getVariable1();
|
Number numb = (Number) mult.getVariable1();
|
||||||
@ -34,7 +36,7 @@ public class NumberRule1 {
|
|||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Number(f.getParent(), "0"));
|
result.add(new Number(f.getRoot(), "0"));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
@ -16,6 +17,7 @@ import org.warp.picalculator.math.functions.Number;
|
|||||||
public class NumberRule2 {
|
public class NumberRule2 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
Multiplication mult = (Multiplication) f;
|
Multiplication mult = (Multiplication) f;
|
||||||
if (mult.getVariable1() instanceof Number) {
|
if (mult.getVariable1() instanceof Number) {
|
||||||
Number numb = (Number) mult.getVariable1();
|
Number numb = (Number) mult.getVariable1();
|
||||||
@ -33,6 +35,7 @@ public class NumberRule2 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Function a = null;
|
Function a = null;
|
||||||
boolean aFound = false;
|
boolean aFound = false;
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
import org.warp.picalculator.math.functions.Negative;
|
import org.warp.picalculator.math.functions.Negative;
|
||||||
@ -45,14 +46,15 @@ public class NumberRule3 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
if (f instanceof SumSubtraction) {
|
if (f instanceof SumSubtraction) {
|
||||||
Multiplication mul = new Multiplication(f.getParent(), null, null);
|
Multiplication mul = new Multiplication(root, null, null);
|
||||||
mul.setVariable1(new Number(root, 2));
|
mul.setVariable1(new Number(root, 2));
|
||||||
mul.setVariable2(f);
|
mul.setVariable2(f);
|
||||||
result.add(mul);
|
result.add(mul);
|
||||||
}
|
}
|
||||||
result.add(new Number(f.getParent(), 0));
|
result.add(new Number(root, 0));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Subtraction;
|
import org.warp.picalculator.math.functions.Subtraction;
|
||||||
import org.warp.picalculator.math.functions.Sum;
|
import org.warp.picalculator.math.functions.Sum;
|
||||||
@ -24,10 +25,11 @@ public class NumberRule4 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
SumSubtraction ss = (SumSubtraction) f;
|
SumSubtraction ss = (SumSubtraction) f;
|
||||||
result.add(new Sum(f.getParent(), ss.getVariable1(), ss.getVariable2()));
|
result.add(new Sum(root, ss.getVariable1(), ss.getVariable2()));
|
||||||
result.add(new Subtraction(f.getParent(), ss.getVariable1(), ss.getVariable2()));
|
result.add(new Subtraction(root, ss.getVariable1(), ss.getVariable2()));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ import org.warp.picalculator.math.functions.Number;
|
|||||||
public class NumberRule5 {
|
public class NumberRule5 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
FunctionTwoValues fnc = (FunctionTwoValues) f;
|
FunctionTwoValues fnc = (FunctionTwoValues) f;
|
||||||
if (fnc.getVariable1().equals(new Number(root, 0)) || fnc.getVariable2().equals(new Number(root, 0))) {
|
if (fnc.getVariable1().equals(new Number(root, 0)) || fnc.getVariable2().equals(new Number(root, 0))) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
import org.warp.picalculator.math.functions.Negative;
|
import org.warp.picalculator.math.functions.Negative;
|
||||||
@ -17,6 +18,7 @@ import org.warp.picalculator.math.functions.Number;
|
|||||||
public class NumberRule6 {
|
public class NumberRule6 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
Multiplication mult = (Multiplication) f;
|
Multiplication mult = (Multiplication) f;
|
||||||
if (mult.getVariable1() instanceof Number) {
|
if (mult.getVariable1() instanceof Number) {
|
||||||
Number numb = (Number) mult.getVariable1();
|
Number numb = (Number) mult.getVariable1();
|
||||||
@ -34,6 +36,7 @@ public class NumberRule6 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Function a = null;
|
Function a = null;
|
||||||
boolean aFound = false;
|
boolean aFound = false;
|
||||||
@ -53,7 +56,7 @@ public class NumberRule6 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Negative minus = new Negative(f.getParent(), null);
|
Negative minus = new Negative(root, null);
|
||||||
minus.setVariable(a);
|
minus.setVariable(a);
|
||||||
|
|
||||||
result.add(minus);
|
result.add(minus);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
@ -27,6 +28,7 @@ public class SyntaxRule1 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
FunctionTwoValues mOut = (FunctionTwoValues) f;
|
FunctionTwoValues mOut = (FunctionTwoValues) f;
|
||||||
Function a = ((FunctionTwoValues)mOut.getVariable1()).getVariable1();
|
Function a = ((FunctionTwoValues)mOut.getVariable1()).getVariable1();
|
||||||
@ -34,9 +36,9 @@ public class SyntaxRule1 {
|
|||||||
Function c = mOut.getVariable2();
|
Function c = mOut.getVariable2();
|
||||||
FunctionTwoValues mIn;
|
FunctionTwoValues mIn;
|
||||||
if (f instanceof Multiplication) {
|
if (f instanceof Multiplication) {
|
||||||
mIn = new Multiplication(mOut, null, null);
|
mIn = new Multiplication(root, null, null);
|
||||||
} else {
|
} else {
|
||||||
mIn = new Sum(mOut, null, null);
|
mIn = new Sum(root, null, null);
|
||||||
}
|
}
|
||||||
mOut.setVariable1(a);
|
mOut.setVariable1(a);
|
||||||
mIn.setVariable1(b);
|
mIn.setVariable1(b);
|
||||||
|
@ -29,6 +29,7 @@ public class SyntaxRule2 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Sum f) throws Error {
|
public static ArrayList<Function> execute(Sum f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Function a = f.getVariable1();
|
Function a = f.getVariable1();
|
||||||
Function b, c;
|
Function b, c;
|
||||||
@ -39,7 +40,7 @@ public class SyntaxRule2 {
|
|||||||
b = ((Sum)((Expression)f.getVariable2()).getVariable(0)).getVariable1();
|
b = ((Sum)((Expression)f.getVariable2()).getVariable(0)).getVariable1();
|
||||||
c = ((Sum)((Expression)f.getVariable2()).getVariable(0)).getVariable2();
|
c = ((Sum)((Expression)f.getVariable2()).getVariable(0)).getVariable2();
|
||||||
}
|
}
|
||||||
Sum mIn = new Sum(f, null, null);
|
Sum mIn = new Sum(root, null, null);
|
||||||
f.setVariable1(mIn);
|
f.setVariable1(mIn);
|
||||||
mIn.setVariable1(a);
|
mIn.setVariable1(a);
|
||||||
mIn.setVariable2(b);
|
mIn.setVariable2(b);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
import org.warp.picalculator.math.functions.Power;
|
import org.warp.picalculator.math.functions.Power;
|
||||||
@ -17,6 +18,7 @@ import org.warp.picalculator.math.functions.Undefined;
|
|||||||
public class UndefinedRule1 {
|
public class UndefinedRule1 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
Power fnc = (Power) f;
|
Power fnc = (Power) f;
|
||||||
if (fnc.getVariable1().equals(new Number(root, 0)) && fnc.getVariable2().equals(new Number(root, 0))) {
|
if (fnc.getVariable1().equals(new Number(root, 0)) && fnc.getVariable2().equals(new Number(root, 0))) {
|
||||||
return true;
|
return true;
|
||||||
@ -25,6 +27,7 @@ public class UndefinedRule1 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Undefined(root));
|
result.add(new Undefined(root));
|
||||||
return result;
|
return result;
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Division;
|
import org.warp.picalculator.math.functions.Division;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
@ -17,6 +18,7 @@ import org.warp.picalculator.math.functions.Undefined;
|
|||||||
public class UndefinedRule2 {
|
public class UndefinedRule2 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
Division fnc = (Division) f;
|
Division fnc = (Division) f;
|
||||||
if (fnc.getVariable2() instanceof Number) {
|
if (fnc.getVariable2() instanceof Number) {
|
||||||
Number numb = (Number) fnc.getVariable2();
|
Number numb = (Number) fnc.getVariable2();
|
||||||
@ -28,6 +30,7 @@ public class UndefinedRule2 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
result.add(new Undefined(root));
|
result.add(new Undefined(root));
|
||||||
return result;
|
return result;
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
||||||
@ -30,6 +31,7 @@ public class VariableRule1 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
||||||
|
Calculator root = fnc.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Multiplication m1 = (Multiplication) fnc.getVariable1();
|
Multiplication m1 = (Multiplication) fnc.getVariable1();
|
||||||
Multiplication m2 = (Multiplication) fnc.getVariable2();
|
Multiplication m2 = (Multiplication) fnc.getVariable2();
|
||||||
@ -37,13 +39,13 @@ public class VariableRule1 {
|
|||||||
Function b = m2.getVariable1();
|
Function b = m2.getVariable1();
|
||||||
Function x = m1.getVariable2();
|
Function x = m1.getVariable2();
|
||||||
|
|
||||||
Multiplication retm = new Multiplication(fnc.getParent(), null, null);
|
Multiplication retm = new Multiplication(root, null, null);
|
||||||
Expression rete = new Expression(retm);
|
Expression rete = new Expression(root);
|
||||||
FunctionTwoValues rets;
|
FunctionTwoValues rets;
|
||||||
if (fnc instanceof Sum){
|
if (fnc instanceof Sum){
|
||||||
rets = new Sum(rete, null, null);
|
rets = new Sum(root, null, null);
|
||||||
} else {
|
} else {
|
||||||
rets = new Subtraction(rete, null, null);
|
rets = new Subtraction(root, null, null);
|
||||||
}
|
}
|
||||||
rets.setVariable1(a);
|
rets.setVariable1(a);
|
||||||
rets.setVariable2(b);
|
rets.setVariable2(b);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
||||||
@ -30,22 +31,23 @@ public class VariableRule2 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
||||||
|
Calculator root = fnc.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Multiplication m1 = (Multiplication) fnc.getVariable1();
|
Multiplication m1 = (Multiplication) fnc.getVariable1();
|
||||||
Function a = m1.getVariable1();
|
Function a = m1.getVariable1();
|
||||||
Function x = fnc.getVariable2();
|
Function x = fnc.getVariable2();
|
||||||
|
|
||||||
Multiplication retm = new Multiplication(fnc.getParent(), null, null);
|
Multiplication retm = new Multiplication(root, null, null);
|
||||||
Expression rete = new Expression(retm);
|
Expression rete = new Expression(root);
|
||||||
|
|
||||||
FunctionTwoValues rets;
|
FunctionTwoValues rets;
|
||||||
if (fnc instanceof Sum) {
|
if (fnc instanceof Sum) {
|
||||||
rets = new Sum(rete, null, null);
|
rets = new Sum(root, null, null);
|
||||||
} else {
|
} else {
|
||||||
rets = new Subtraction(rete, null, null);
|
rets = new Subtraction(root, null, null);
|
||||||
}
|
}
|
||||||
rets.setVariable1(a);
|
rets.setVariable1(a);
|
||||||
rets.setVariable2(new Number(rets, 1));
|
rets.setVariable2(new Number(root, 1));
|
||||||
rete.addFunctionToEnd(rets);
|
rete.addFunctionToEnd(rets);
|
||||||
retm.setVariable1(rete);
|
retm.setVariable1(rete);
|
||||||
retm.setVariable2(x);
|
retm.setVariable2(x);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Expression;
|
import org.warp.picalculator.math.functions.Expression;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
||||||
@ -30,21 +31,22 @@ public class VariableRule3 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
public static ArrayList<Function> execute(FunctionTwoValues fnc) throws Error {
|
||||||
|
Calculator root = fnc.getRoot();
|
||||||
ArrayList<Function> result = new ArrayList<>();
|
ArrayList<Function> result = new ArrayList<>();
|
||||||
Multiplication m2 = (Multiplication) fnc.getVariable2();
|
Multiplication m2 = (Multiplication) fnc.getVariable2();
|
||||||
Function a = m2.getVariable1();
|
Function a = m2.getVariable1();
|
||||||
Function x = fnc.getVariable1();
|
Function x = fnc.getVariable1();
|
||||||
|
|
||||||
Multiplication retm = new Multiplication(fnc.getParent(), null, null);
|
Multiplication retm = new Multiplication(root, null, null);
|
||||||
Expression rete = new Expression(retm);
|
Expression rete = new Expression(root);
|
||||||
FunctionTwoValues rets;
|
FunctionTwoValues rets;
|
||||||
if (fnc instanceof Sum) {
|
if (fnc instanceof Sum) {
|
||||||
rets = new Sum(rete, null, null);
|
rets = new Sum(root, null, null);
|
||||||
} else {
|
} else {
|
||||||
rets = new Subtraction(rete, null, null);
|
rets = new Subtraction(root, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
rets.setVariable1(new Number(rets, 1));
|
rets.setVariable1(new Number(root, 1));
|
||||||
rets.setVariable2(a);
|
rets.setVariable2(a);
|
||||||
rete.addFunctionToEnd(rets);
|
rete.addFunctionToEnd(rets);
|
||||||
retm.setVariable1(rete);
|
retm.setVariable1(rete);
|
||||||
|
@ -3,6 +3,7 @@ package org.warp.picalculator.math.rules.methods;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.Multiplication;
|
import org.warp.picalculator.math.functions.Multiplication;
|
||||||
import org.warp.picalculator.math.functions.Number;
|
import org.warp.picalculator.math.functions.Number;
|
||||||
@ -21,6 +22,7 @@ public class MultiplicationMethod1 {
|
|||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
Function result;
|
Function result;
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> elements = getMultiplicationElements(f);
|
ArrayList<Function> elements = getMultiplicationElements(f);
|
||||||
int[] workingElementCouple = getFirstWorkingMultiplicationCouple(elements);
|
int[] workingElementCouple = getFirstWorkingMultiplicationCouple(elements);
|
||||||
Function elem1 = elements.get(workingElementCouple[0]);
|
Function elem1 = elements.get(workingElementCouple[0]);
|
||||||
@ -28,18 +30,13 @@ public class MultiplicationMethod1 {
|
|||||||
|
|
||||||
final int size = elements.size();
|
final int size = elements.size();
|
||||||
Function prec = new Multiplication(root, elem1, elem2);
|
Function prec = new Multiplication(root, elem1, elem2);
|
||||||
elem1.setParent(prec);
|
|
||||||
elem2.setParent(prec);
|
|
||||||
for (int i = size-1; i >= 0; i--) {
|
for (int i = size-1; i >= 0; i--) {
|
||||||
if (i != workingElementCouple[0] & i != workingElementCouple[1]) {
|
if (i != workingElementCouple[0] & i != workingElementCouple[1]) {
|
||||||
Function a = prec;
|
Function a = prec;
|
||||||
Function b = elements.get(i);
|
Function b = elements.get(i);
|
||||||
prec = new Multiplication(root, a, b);
|
prec = new Multiplication(root, a, b);
|
||||||
a.setParent(prec);
|
|
||||||
b.setParent(prec);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
prec.setParent(root);
|
|
||||||
|
|
||||||
result = prec;
|
result = prec;
|
||||||
|
|
||||||
@ -62,9 +59,13 @@ public class MultiplicationMethod1 {
|
|||||||
final int size = elements.size();
|
final int size = elements.size();
|
||||||
Function a;
|
Function a;
|
||||||
Function b;
|
Function b;
|
||||||
|
if (elements.size() == 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
if (elements.size() == 2) {
|
if (elements.size() == 2) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
Calculator root = elements.get(0).getRoot();
|
||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
a = elements.get(i);
|
a = elements.get(i);
|
||||||
for (int j = 0; j < size; j++) {
|
for (int j = 0; j < size; j++) {
|
||||||
|
@ -4,6 +4,7 @@ import java.math.BigDecimal;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.warp.picalculator.Error;
|
import org.warp.picalculator.Error;
|
||||||
|
import org.warp.picalculator.math.Calculator;
|
||||||
import org.warp.picalculator.math.functions.Function;
|
import org.warp.picalculator.math.functions.Function;
|
||||||
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
import org.warp.picalculator.math.functions.FunctionTwoValues;
|
||||||
import org.warp.picalculator.math.functions.Negative;
|
import org.warp.picalculator.math.functions.Negative;
|
||||||
@ -20,40 +21,35 @@ import org.warp.picalculator.math.functions.Sum;
|
|||||||
public class SumMethod1 {
|
public class SumMethod1 {
|
||||||
|
|
||||||
public static boolean compare(Function f) {
|
public static boolean compare(Function f) {
|
||||||
return (f instanceof Sum || f instanceof Subtraction) && ((FunctionTwoValues)f).getVariable1().isSolved() && ((FunctionTwoValues)f).getVariable2().isSolved() && !(((FunctionTwoValues)f).getVariable1() instanceof Number && ((FunctionTwoValues)f).getVariable2() instanceof Number) && getFirstWorkingSumCouple(getSumElements(f)) != null;
|
Calculator root = f.getRoot();
|
||||||
|
return (f instanceof Sum || f instanceof Subtraction) && ((FunctionTwoValues)f).getVariable1().isSolved() && ((FunctionTwoValues)f).getVariable2().isSolved() && !(((FunctionTwoValues)f).getVariable1() instanceof Number && ((FunctionTwoValues)f).getVariable2() instanceof Number) && getFirstWorkingSumCouple(root, getSumElements(f)) != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ArrayList<Function> execute(Function f) throws Error {
|
public static ArrayList<Function> execute(Function f) throws Error {
|
||||||
Function result;
|
Function result;
|
||||||
|
Calculator root = f.getRoot();
|
||||||
ArrayList<Function> elements = getSumElements(f);
|
ArrayList<Function> elements = getSumElements(f);
|
||||||
int[] workingElementCouple = getFirstWorkingSumCouple(elements);
|
int[] workingElementCouple = getFirstWorkingSumCouple(root, elements);
|
||||||
Function elem1 = elements.get(workingElementCouple[0]);
|
Function elem1 = elements.get(workingElementCouple[0]);
|
||||||
Function elem2 = elements.get(workingElementCouple[1]);
|
Function elem2 = elements.get(workingElementCouple[1]);
|
||||||
|
|
||||||
final int size = elements.size();
|
final int size = elements.size();
|
||||||
Function prec = new Sum(root, elem1, elem2);
|
Function prec = new Sum(root, elem1, elem2);
|
||||||
elem1.setParent(prec);
|
|
||||||
elem2.setParent(prec);
|
|
||||||
for (int i = size-1; i >= 0; i--) {
|
for (int i = size-1; i >= 0; i--) {
|
||||||
if (i != workingElementCouple[0] & i != workingElementCouple[1]) {
|
if (i != workingElementCouple[0] & i != workingElementCouple[1]) {
|
||||||
Function a = prec;
|
Function a = prec;
|
||||||
Function b = elements.get(i);
|
Function b = elements.get(i);
|
||||||
if (b instanceof Negative) {
|
if (b instanceof Negative) {
|
||||||
prec = new Subtraction(root, a, ((Negative)b).getVariable());
|
prec = new Subtraction(root, a, ((Negative)b).getVariable());
|
||||||
a.setParent(prec);
|
((FunctionTwoValues)prec).getVariable2();
|
||||||
((FunctionTwoValues)prec).getVariable2().setParent(prec);
|
|
||||||
} else if (b instanceof Number && ((Number) b).getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
} else if (b instanceof Number && ((Number) b).getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
||||||
prec = new Subtraction(root, a, ((Number)b).multiply(new Number(root, -1)));
|
prec = new Subtraction(root, a, ((Number)b).multiply(new Number(root, -1)));
|
||||||
a.setParent(prec);
|
((FunctionTwoValues)prec).getVariable2();
|
||||||
((FunctionTwoValues)prec).getVariable2().setParent(prec);
|
|
||||||
} else {
|
} else {
|
||||||
prec = new Sum(root, a, b);
|
prec = new Sum(root, a, b);
|
||||||
a.setParent(prec);
|
|
||||||
b.setParent(prec);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
prec.setParent(root);
|
|
||||||
|
|
||||||
result = prec;
|
result = prec;
|
||||||
|
|
||||||
@ -63,6 +59,7 @@ public class SumMethod1 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static ArrayList<Function> getSumElements(Function sum) {
|
private static ArrayList<Function> getSumElements(Function sum) {
|
||||||
|
Calculator root = sum.getRoot();
|
||||||
ArrayList<Function> elements = new ArrayList<>();
|
ArrayList<Function> elements = new ArrayList<>();
|
||||||
while (sum instanceof Sum || sum instanceof Subtraction) {
|
while (sum instanceof Sum || sum instanceof Subtraction) {
|
||||||
if (sum instanceof Sum) {
|
if (sum instanceof Sum) {
|
||||||
@ -76,7 +73,7 @@ public class SumMethod1 {
|
|||||||
return elements;
|
return elements;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int[] getFirstWorkingSumCouple(ArrayList<Function> elements) {
|
private static int[] getFirstWorkingSumCouple(Calculator root, ArrayList<Function> elements) {
|
||||||
final int size = elements.size();
|
final int size = elements.size();
|
||||||
Function a;
|
Function a;
|
||||||
Function b;
|
Function b;
|
||||||
@ -95,7 +92,7 @@ public class SumMethod1 {
|
|||||||
testFunc = new Subtraction(root, a, ((Number)b).multiply(new Number(root, -1)));
|
testFunc = new Subtraction(root, a, ((Number)b).multiply(new Number(root, -1)));
|
||||||
} else if (a instanceof Negative) {
|
} else if (a instanceof Negative) {
|
||||||
testFunc = new Subtraction(root, b, ((Negative)a).getVariable());
|
testFunc = new Subtraction(root, b, ((Negative)a).getVariable());
|
||||||
} else if (a instanceof Number && ((Number) a).getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
} else if (a instanceof Number && ((Number) a).getTerm().compareTo(BigDecimal.ZERO) < 0) {
|
||||||
testFunc = new Subtraction(root, b, ((Number)a).multiply(new Number(root, -1)));
|
testFunc = new Subtraction(root, b, ((Number)a).multiply(new Number(root, -1)));
|
||||||
} else {
|
} else {
|
||||||
testFunc = new Sum(root, a, b);
|
testFunc = new Sum(root, a, b);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user