233 lines
5.7 KiB
Java
233 lines
5.7 KiB
Java
package org.luaj.vm2;
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
import org.luaj.vm2.lib.jme.JmePlatform;
|
|
import org.luaj.vm2.lib.jse.JsePlatform;
|
|
|
|
public class MathLibTest extends TestCase {
|
|
|
|
private LuaValue j2se;
|
|
private LuaValue j2me;
|
|
private boolean supportedOnJ2me;
|
|
|
|
public MathLibTest() {
|
|
j2se = JsePlatform.standardGlobals().get("math");
|
|
j2me = JmePlatform.standardGlobals().get("math");
|
|
}
|
|
|
|
protected void setUp() throws Exception {
|
|
supportedOnJ2me = true;
|
|
}
|
|
|
|
public void testMathDPow() {
|
|
assertEquals( 1, j2mepow(2, 0), 0 );
|
|
assertEquals( 2, j2mepow(2, 1), 0 );
|
|
assertEquals( 8, j2mepow(2, 3), 0 );
|
|
assertEquals( -8, j2mepow(-2, 3), 0 );
|
|
assertEquals( 1/8., j2mepow(2, -3), 0 );
|
|
assertEquals( -1/8., j2mepow(-2, -3), 0 );
|
|
assertEquals( 16, j2mepow(256, .5), 0 );
|
|
assertEquals( 4, j2mepow(256, .25), 0 );
|
|
assertEquals( 64, j2mepow(256, .75), 0 );
|
|
assertEquals( 1./16, j2mepow(256, - .5), 0 );
|
|
assertEquals( 1./ 4, j2mepow(256, -.25), 0 );
|
|
assertEquals( 1./64, j2mepow(256, -.75), 0 );
|
|
assertEquals( Double.NaN, j2mepow(-256, .5), 0 );
|
|
assertEquals( 1, j2mepow(.5, 0), 0 );
|
|
assertEquals( .5, j2mepow(.5, 1), 0 );
|
|
assertEquals(.125, j2mepow(.5, 3), 0 );
|
|
assertEquals( 2, j2mepow(.5, -1), 0 );
|
|
assertEquals( 8, j2mepow(.5, -3), 0 );
|
|
assertEquals(1, j2mepow(0.0625, 0), 0 );
|
|
assertEquals(0.00048828125, j2mepow(0.0625, 2.75), 0 );
|
|
}
|
|
|
|
private double j2mepow(double x, double y) {
|
|
return j2me.get("pow").call(LuaValue.valueOf(x),LuaValue.valueOf(y)).todouble();
|
|
}
|
|
|
|
public void testAbs() {
|
|
tryMathOp( "abs", 23.45 );
|
|
tryMathOp( "abs", -23.45 );
|
|
}
|
|
|
|
public void testCos() {
|
|
tryTrigOps( "cos" );
|
|
}
|
|
|
|
public void testCosh() {
|
|
supportedOnJ2me = false;
|
|
tryTrigOps( "cosh" );
|
|
}
|
|
|
|
public void testDeg() {
|
|
tryTrigOps( "deg" );
|
|
}
|
|
|
|
public void testExp() {
|
|
//supportedOnJ2me = false;
|
|
tryMathOp( "exp", 0 );
|
|
tryMathOp( "exp", 0.1 );
|
|
tryMathOp( "exp", .9 );
|
|
tryMathOp( "exp", 1. );
|
|
tryMathOp( "exp", 9 );
|
|
tryMathOp( "exp", -.1 );
|
|
tryMathOp( "exp", -.9 );
|
|
tryMathOp( "exp", -1. );
|
|
tryMathOp( "exp", -9 );
|
|
}
|
|
|
|
public void testLog() {
|
|
supportedOnJ2me = false;
|
|
tryMathOp( "log", 0.1 );
|
|
tryMathOp( "log", .9 );
|
|
tryMathOp( "log", 1. );
|
|
tryMathOp( "log", 9 );
|
|
tryMathOp( "log", -.1 );
|
|
tryMathOp( "log", -.9 );
|
|
tryMathOp( "log", -1. );
|
|
tryMathOp( "log", -9 );
|
|
}
|
|
|
|
public void testRad() {
|
|
tryMathOp( "rad", 0 );
|
|
tryMathOp( "rad", 0.1 );
|
|
tryMathOp( "rad", .9 );
|
|
tryMathOp( "rad", 1. );
|
|
tryMathOp( "rad", 9 );
|
|
tryMathOp( "rad", 10 );
|
|
tryMathOp( "rad", 100 );
|
|
tryMathOp( "rad", -.1 );
|
|
tryMathOp( "rad", -.9 );
|
|
tryMathOp( "rad", -1. );
|
|
tryMathOp( "rad", -9 );
|
|
tryMathOp( "rad", -10 );
|
|
tryMathOp( "rad", -100 );
|
|
}
|
|
|
|
public void testSin() {
|
|
tryTrigOps( "sin" );
|
|
}
|
|
|
|
public void testSinh() {
|
|
supportedOnJ2me = false;
|
|
tryTrigOps( "sinh" );
|
|
}
|
|
|
|
public void testSqrt() {
|
|
tryMathOp( "sqrt", 0 );
|
|
tryMathOp( "sqrt", 0.1 );
|
|
tryMathOp( "sqrt", .9 );
|
|
tryMathOp( "sqrt", 1. );
|
|
tryMathOp( "sqrt", 9 );
|
|
tryMathOp( "sqrt", 10 );
|
|
tryMathOp( "sqrt", 100 );
|
|
}
|
|
public void testTan() {
|
|
tryTrigOps( "tan" );
|
|
}
|
|
|
|
public void testTanh() {
|
|
supportedOnJ2me = false;
|
|
tryTrigOps( "tanh" );
|
|
}
|
|
|
|
public void testAtan2() {
|
|
supportedOnJ2me = false;
|
|
tryDoubleOps( "atan2", false );
|
|
}
|
|
|
|
public void testFmod() {
|
|
tryDoubleOps( "fmod", false );
|
|
}
|
|
|
|
public void testPow() {
|
|
tryDoubleOps( "pow", true );
|
|
}
|
|
|
|
private void tryDoubleOps( String op, boolean positiveOnly ) {
|
|
// y>0, x>0
|
|
tryMathOp( op, 0.1, 4.0 );
|
|
tryMathOp( op, .9, 4.0 );
|
|
tryMathOp( op, 1., 4.0 );
|
|
tryMathOp( op, 9, 4.0 );
|
|
tryMathOp( op, 10, 4.0 );
|
|
tryMathOp( op, 100, 4.0 );
|
|
|
|
// y>0, x<0
|
|
tryMathOp( op, 0.1, -4.0 );
|
|
tryMathOp( op, .9, -4.0 );
|
|
tryMathOp( op, 1., -4.0 );
|
|
tryMathOp( op, 9, -4.0 );
|
|
tryMathOp( op, 10, -4.0 );
|
|
tryMathOp( op, 100, -4.0 );
|
|
|
|
if ( ! positiveOnly ) {
|
|
// y<0, x>0
|
|
tryMathOp( op, -0.1, 4.0 );
|
|
tryMathOp( op, -.9, 4.0 );
|
|
tryMathOp( op, -1., 4.0 );
|
|
tryMathOp( op, -9, 4.0 );
|
|
tryMathOp( op, -10, 4.0 );
|
|
tryMathOp( op, -100, 4.0 );
|
|
|
|
// y<0, x<0
|
|
tryMathOp( op, -0.1, -4.0 );
|
|
tryMathOp( op, -.9, -4.0 );
|
|
tryMathOp( op, -1., -4.0 );
|
|
tryMathOp( op, -9, -4.0 );
|
|
tryMathOp( op, -10, -4.0 );
|
|
tryMathOp( op, -100, -4.0 );
|
|
}
|
|
|
|
// degenerate cases
|
|
tryMathOp( op, 0, 1 );
|
|
tryMathOp( op, 1, 0 );
|
|
tryMathOp( op, -1, 0 );
|
|
tryMathOp( op, 0, -1 );
|
|
tryMathOp( op, 0, 0 );
|
|
}
|
|
|
|
private void tryTrigOps(String op) {
|
|
tryMathOp( op, 0 );
|
|
tryMathOp( op, Math.PI/8 );
|
|
tryMathOp( op, Math.PI*7/8 );
|
|
tryMathOp( op, Math.PI*8/8 );
|
|
tryMathOp( op, Math.PI*9/8 );
|
|
tryMathOp( op, -Math.PI/8 );
|
|
tryMathOp( op, -Math.PI*7/8 );
|
|
tryMathOp( op, -Math.PI*8/8 );
|
|
tryMathOp( op, -Math.PI*9/8 );
|
|
}
|
|
|
|
private void tryMathOp(String op, double x) {
|
|
try {
|
|
double expected = j2se.get(op).call( LuaValue.valueOf(x)).todouble();
|
|
double actual = j2me.get(op).call( LuaValue.valueOf(x)).todouble();
|
|
if ( supportedOnJ2me )
|
|
assertEquals( expected, actual, 1.e-4 );
|
|
else
|
|
fail("j2me should throw exception for math."+op+" but returned "+actual);
|
|
} catch ( LuaError lee ) {
|
|
if ( supportedOnJ2me )
|
|
throw lee;
|
|
}
|
|
}
|
|
|
|
|
|
private void tryMathOp(String op, double a, double b) {
|
|
try {
|
|
double expected = j2se.get(op).call( LuaValue.valueOf(a), LuaValue.valueOf(b)).todouble();
|
|
double actual = j2me.get(op).call( LuaValue.valueOf(a), LuaValue.valueOf(b)).todouble();
|
|
if ( supportedOnJ2me )
|
|
assertEquals( expected, actual, 1.e-5 );
|
|
else
|
|
fail("j2me should throw exception for math."+op+" but returned "+actual);
|
|
} catch ( LuaError lee ) {
|
|
if ( supportedOnJ2me )
|
|
throw lee;
|
|
}
|
|
}
|
|
}
|