mirror of
https://github.com/i-net-software/JWebAssembly.git
synced 2025-03-15 02:44:47 +01:00
404 lines
10 KiB
Java
404 lines
10 KiB
Java
/*
|
|
* Copyright 2019 Volker Berlin (i-net software)
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
package de.inetsoftware.jwebassembly.runtime;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
|
|
import org.junit.ClassRule;
|
|
import org.junit.runners.Parameterized.Parameters;
|
|
|
|
import de.inetsoftware.jwebassembly.ScriptEngine;
|
|
import de.inetsoftware.jwebassembly.WasmRule;
|
|
import de.inetsoftware.jwebassembly.api.annotation.Export;
|
|
|
|
/**
|
|
* @author Volker Berlin
|
|
*/
|
|
public class MathAPI extends AbstractBaseTest {
|
|
|
|
@ClassRule
|
|
public static WasmRule rule = new WasmRule( TestClass.class );
|
|
|
|
public MathAPI( ScriptEngine script, String method, Object[] params ) {
|
|
super( rule, script, method, params );
|
|
}
|
|
|
|
@Parameters(name="{0}-{1}")
|
|
public static Collection<Object[]> data() {
|
|
ArrayList<Object[]> list = new ArrayList<>();
|
|
for( ScriptEngine script : ScriptEngine.testEngines() ) {
|
|
addParam( list, script, "floatToIntBits" );
|
|
addParam( list, script, "intBitsToFloat" );
|
|
addParam( list, script, "doubleToLongBits" );
|
|
addParam( list, script, "longBitsToDouble" );
|
|
addParam( list, script, "sin0" );
|
|
addParam( list, script, "sinPI" );
|
|
addParam( list, script, "cos0" );
|
|
addParam( list, script, "tan0" );
|
|
addParam( list, script, "asin1" );
|
|
addParam( list, script, "acos1" );
|
|
addParam( list, script, "atan1" );
|
|
addParam( list, script, "toRadians90" );
|
|
addParam( list, script, "toDegrees1" );
|
|
addParam( list, script, "exp1" );
|
|
addParam( list, script, "log1" );
|
|
addParam( list, script, "log10" );
|
|
addParam( list, script, "cbrt8" );
|
|
addParam( list, script, "IEEEremainder" );
|
|
addParam( list, script, "ceil8_5" );
|
|
addParam( list, script, "floor8_5" );
|
|
addParam( list, script, "rint8_5" );
|
|
addParam( list, script, "atan2_5_5" );
|
|
addParam( list, script, "pow3_4" );
|
|
addParam( list, script, "roundF3_5" );
|
|
addParam( list, script, "roundF_3_5" );
|
|
addParam( list, script, "roundD3_8" );
|
|
addParam( list, script, "roundD_3_8" );
|
|
addParam( list, script, "random" );
|
|
addParam( list, script, "absF" );
|
|
addParam( list, script, "absD" );
|
|
addParam( list, script, "maxF" );
|
|
addParam( list, script, "maxD" );
|
|
addParam( list, script, "minF" );
|
|
addParam( list, script, "minD" );
|
|
//TODO addParam( list, script, "ulpD" );
|
|
//TODO addParam( list, script, "ulpF" );
|
|
addParam( list, script, "signumD" );
|
|
addParam( list, script, "signumF" );
|
|
addParam( list, script, "sinhPI" );
|
|
addParam( list, script, "coshPI" );
|
|
addParam( list, script, "tanhPI" );
|
|
addParam( list, script, "hypot" );
|
|
addParam( list, script, "expm1" );
|
|
addParam( list, script, "log1p" );
|
|
addParam( list, script, "copySignD" );
|
|
addParam( list, script, "copySignF" );
|
|
addParam( list, script, "getExponentD" );
|
|
addParam( list, script, "getExponentF" );
|
|
//TODO addParam( list, script, "nextAfterD" );
|
|
//TODO addParam( list, script, "nextAfterF" );
|
|
addParam( list, script, "nextUpD" );
|
|
addParam( list, script, "nextUpF" );
|
|
addParam( list, script, "nextDownD" );
|
|
addParam( list, script, "nextDownF" );
|
|
//TODO addParam( list, script, "scalbD" );
|
|
//TODO addParam( list, script, "scalbF" );
|
|
}
|
|
rule.setTestParameters( list );
|
|
return list;
|
|
}
|
|
|
|
static class TestClass {
|
|
|
|
@Export
|
|
static int floatToIntBits() {
|
|
return Float.floatToIntBits( 7 );
|
|
}
|
|
|
|
@Export
|
|
static float intBitsToFloat() {
|
|
return Float.intBitsToFloat( 0x41f8_0000 ); // 31.0
|
|
}
|
|
|
|
@Export
|
|
static int doubleToLongBits() {
|
|
return (int)Double.doubleToLongBits( 7 );
|
|
}
|
|
|
|
@Export
|
|
static double longBitsToDouble() {
|
|
return Double.longBitsToDouble( 0x41f8_0000 ); // 31.0
|
|
}
|
|
|
|
@Export
|
|
static double sin0() {
|
|
return Math.sin( 0 );
|
|
}
|
|
|
|
@Export
|
|
static double sinPI() {
|
|
return Math.sin( Math.PI / 2 );
|
|
}
|
|
|
|
@Export
|
|
static double cos0() {
|
|
return Math.cos( 0 );
|
|
}
|
|
|
|
@Export
|
|
static double tan0() {
|
|
return Math.tan( 0 );
|
|
}
|
|
|
|
@Export
|
|
static double asin1() {
|
|
return Math.asin( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double acos1() {
|
|
return Math.acos( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double atan1() {
|
|
return Math.atan( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double toRadians90() {
|
|
return Math.toRadians( 90 );
|
|
}
|
|
|
|
@Export
|
|
static double toDegrees1() {
|
|
return Math.toDegrees( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double exp1() {
|
|
return Math.exp( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double log1() {
|
|
return Math.log( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double log10() {
|
|
return Math.log10( 1 );
|
|
}
|
|
|
|
@Export
|
|
static double sqrt() {
|
|
return Math.sqrt( 6.25 );
|
|
}
|
|
|
|
@Export
|
|
static double cbrt8() {
|
|
return Math.cbrt( 8 );
|
|
}
|
|
|
|
@Export
|
|
static double IEEEremainder() {
|
|
return Math.IEEEremainder( 11, 3 );
|
|
}
|
|
|
|
@Export
|
|
static double ceil8_5() {
|
|
return Math.ceil( 8.5 );
|
|
}
|
|
|
|
@Export
|
|
static double floor8_5() {
|
|
return Math.floor( 8.5 );
|
|
}
|
|
|
|
@Export
|
|
static double rint8_5() {
|
|
return Math.rint( 8.5 );
|
|
}
|
|
|
|
@Export
|
|
static double atan2_5_5() {
|
|
return Math.atan2( 5, 5 );
|
|
}
|
|
|
|
@Export
|
|
static double pow3_4() {
|
|
return Math.pow( 3, 4 );
|
|
}
|
|
|
|
@Export
|
|
static int roundF3_5() {
|
|
return Math.round( 3.5F );
|
|
}
|
|
|
|
@Export
|
|
static int roundF_3_5() {
|
|
return Math.round( -3.5F );
|
|
}
|
|
|
|
@Export
|
|
static long roundD3_8() {
|
|
return Math.round( 3.8 );
|
|
}
|
|
|
|
@Export
|
|
static long roundD_3_8() {
|
|
return Math.round( -3.8 );
|
|
}
|
|
|
|
@Export
|
|
static int random() {
|
|
if( Math.random() < 0 ) {
|
|
return 1;
|
|
} else if( Math.random() > 1 ) {
|
|
return 2;
|
|
} else if( Math.random() == Math.random() ) {
|
|
return 3;
|
|
} else {
|
|
return 4;
|
|
}
|
|
}
|
|
|
|
@Export
|
|
static float absF() {
|
|
return Math.abs( -3.8F );
|
|
}
|
|
|
|
@Export
|
|
static double absD() {
|
|
return Math.abs( -3.8 );
|
|
}
|
|
|
|
@Export
|
|
static float maxF() {
|
|
return Math.max( -3.8F, 7.5F );
|
|
}
|
|
|
|
@Export
|
|
static double maxD() {
|
|
return Math.max( -3.8, 7.5 );
|
|
}
|
|
|
|
@Export
|
|
static float minF() {
|
|
return Math.min( -3.8F, 7.5F );
|
|
}
|
|
|
|
@Export
|
|
static double minD() {
|
|
return Math.min( -3.8, 7.5 );
|
|
}
|
|
|
|
// TODO assert expression in ulp()
|
|
// @Export
|
|
// static double ulpD() {
|
|
// return Math.ulp( 1.5 );
|
|
// }
|
|
//
|
|
// @Export
|
|
// static float ulpF() {
|
|
// return Math.ulp( 1.5F );
|
|
// }
|
|
|
|
@Export
|
|
static double signumD() {
|
|
return Math.signum( -3.8 );
|
|
}
|
|
|
|
@Export
|
|
static double signumF() {
|
|
return Math.signum( -3.8F );
|
|
}
|
|
|
|
@Export
|
|
static double sinhPI() {
|
|
return Math.sinh( Math.PI / 2 );
|
|
}
|
|
|
|
@Export
|
|
static double coshPI() {
|
|
return Math.cosh( Math.PI / 2 );
|
|
}
|
|
|
|
@Export
|
|
static double tanhPI() {
|
|
return Math.tanh( Math.PI / 2 );
|
|
}
|
|
|
|
@Export
|
|
static double hypot() {
|
|
return Math.hypot( 3, 4 );
|
|
}
|
|
|
|
@Export
|
|
static double expm1() {
|
|
return Math.expm1( 1.5 );
|
|
}
|
|
|
|
@Export
|
|
static double log1p() {
|
|
return Math.log1p( 1.5 );
|
|
}
|
|
|
|
@Export
|
|
static double copySignD() {
|
|
return Math.copySign( 1.25, -1 );
|
|
}
|
|
|
|
@Export
|
|
static float copySignF() {
|
|
return Math.copySign( -1.25F, 1F );
|
|
}
|
|
|
|
@Export
|
|
static int getExponentD() {
|
|
return Math.getExponent( 12345678.0 );
|
|
}
|
|
|
|
@Export
|
|
static int getExponentF() {
|
|
return Math.getExponent( -1.25F );
|
|
}
|
|
|
|
// TODO assert expression in nextAfter()
|
|
// @Export
|
|
// static double nextAfterD() {
|
|
// return Math.nextAfter( 12345678.0, 0 );
|
|
// }
|
|
//
|
|
// @Export
|
|
// static float nextAfterF() {
|
|
// return Math.nextAfter( -1.25F, 2 );
|
|
// }
|
|
|
|
@Export
|
|
static double nextUpD() {
|
|
return Math.nextUp( 12345678.0 );
|
|
}
|
|
|
|
@Export
|
|
static float nextUpF() {
|
|
return Math.nextUp( -1.25F );
|
|
}
|
|
|
|
@Export
|
|
static double nextDownD() {
|
|
return Math.nextDown( 12345678.0 );
|
|
}
|
|
|
|
@Export
|
|
static float nextDownF() {
|
|
return Math.nextDown( -1.25F );
|
|
}
|
|
|
|
// TODO assert expression
|
|
// @Export
|
|
// static double scalbD() {
|
|
// return Math.scalb( -1.25, 3 );
|
|
// }
|
|
//
|
|
// @Export
|
|
// static float scalbF() {
|
|
// return Math.scalb( -1.25F, 3 );
|
|
// }
|
|
}
|
|
}
|