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

54 lines
1.7 KiB
Java
Raw Normal View History

package it.cavallium.warppi.math.functions;
2018-05-05 23:06:36 +02:00
import it.cavallium.warppi.gui.expression.blocks.Block;
import it.cavallium.warppi.gui.expression.blocks.BlockContainer;
import it.cavallium.warppi.gui.expression.blocks.BlockLogarithm;
import it.cavallium.warppi.math.Function;
import it.cavallium.warppi.math.FunctionOperator;
import it.cavallium.warppi.math.MathContext;
import it.cavallium.warppi.util.Error;
2018-05-05 23:06:36 +02:00
import it.unimi.dsi.fastutil.objects.ObjectArrayList;
public class Logarithm extends FunctionOperator {
2018-09-22 11:17:30 +02:00
public Logarithm(final MathContext root, final Function value1, final Function value2) {
2018-05-05 23:06:36 +02:00
super(root, value1, value2);
}
@Override
2018-09-22 11:17:30 +02:00
public boolean equals(final Object o) {
2018-05-05 23:06:36 +02:00
if (o instanceof Logarithm) {
final FunctionOperator f = (FunctionOperator) o;
return parameter1.equals(f.getParameter1()) && parameter2.equals(f.getParameter2());
}
return false;
}
@Override
public Logarithm clone() {
return new Logarithm(mathContext, parameter1, parameter2);
}
@Override
2018-09-22 11:17:30 +02:00
public ObjectArrayList<Block> toBlock(final MathContext context) throws Error {
2018-05-12 21:18:29 +02:00
final ObjectArrayList<Block> result = new ObjectArrayList<>();
final ObjectArrayList<Block> sub1 = getParameter1().toBlock(context);
final ObjectArrayList<Block> sub2 = getParameter2().toBlock(context);
final BlockLogarithm bd = new BlockLogarithm();
final BlockContainer uc = bd.getBaseContainer();
final BlockContainer lc = bd.getNumberContainer();
2018-09-28 11:39:28 +02:00
for (final Block b : sub1) {
2018-05-05 23:06:36 +02:00
uc.appendBlockUnsafe(b);
2018-09-28 11:39:28 +02:00
}
for (final Block b : sub2) {
2018-05-05 23:06:36 +02:00
lc.appendBlockUnsafe(b);
2018-09-28 11:39:28 +02:00
}
2018-05-05 23:06:36 +02:00
uc.recomputeDimensions();
lc.recomputeDimensions();
bd.recomputeDimensions();
result.add(bd);
return result;
}
}