2007-08-13 14:06:31 +00:00
|
|
|
public class Floats {
|
|
|
|
private static void expect(boolean v) {
|
|
|
|
if (! v) throw new RuntimeException();
|
|
|
|
}
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
private static double multiply(double a, double b) {
|
|
|
|
return a * b;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static float multiply(float a, float b) {
|
|
|
|
return a * b;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static double divide(double a, double b) {
|
|
|
|
return a / b;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static double subtract(double a, double b) {
|
|
|
|
return a - b;
|
|
|
|
}
|
|
|
|
|
2009-11-28 04:15:12 +00:00
|
|
|
private double field = 100d;
|
|
|
|
|
|
|
|
private static int doubleToInt(Floats f) {
|
|
|
|
return (int) f.field;
|
|
|
|
}
|
|
|
|
|
2009-11-30 15:10:34 +00:00
|
|
|
private static void multiplyAndStore(double a, double b, Floats f) {
|
|
|
|
f.field = a * b;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static double loadAndMultiply(double a, Floats f) {
|
|
|
|
return f.field * a;
|
|
|
|
}
|
|
|
|
|
2011-07-06 17:09:06 +00:00
|
|
|
private static void subdivide(double src[], int srcoff,
|
|
|
|
double left[], int leftoff,
|
|
|
|
double right[], int rightoff)
|
|
|
|
{
|
|
|
|
double x1 = src[srcoff + 0];
|
|
|
|
double y1 = src[srcoff + 1];
|
|
|
|
double ctrlx1 = src[srcoff + 2];
|
|
|
|
double ctrly1 = src[srcoff + 3];
|
|
|
|
double ctrlx2 = src[srcoff + 4];
|
|
|
|
double ctrly2 = src[srcoff + 5];
|
|
|
|
double x2 = src[srcoff + 6];
|
|
|
|
double y2 = src[srcoff + 7];
|
|
|
|
if (left != null) {
|
|
|
|
left[leftoff + 0] = x1;
|
|
|
|
left[leftoff + 1] = y1;
|
|
|
|
}
|
|
|
|
if (right != null) {
|
|
|
|
right[rightoff + 6] = x2;
|
|
|
|
right[rightoff + 7] = y2;
|
|
|
|
}
|
|
|
|
x1 = (x1 + ctrlx1) / 2.0;
|
|
|
|
y1 = (y1 + ctrly1) / 2.0;
|
|
|
|
x2 = (x2 + ctrlx2) / 2.0;
|
|
|
|
y2 = (y2 + ctrly2) / 2.0;
|
|
|
|
double centerx = (ctrlx1 + ctrlx2) / 2.0;
|
|
|
|
double centery = (ctrly1 + ctrly2) / 2.0;
|
|
|
|
ctrlx1 = (x1 + centerx) / 2.0;
|
|
|
|
ctrly1 = (y1 + centery) / 2.0;
|
|
|
|
ctrlx2 = (x2 + centerx) / 2.0;
|
|
|
|
ctrly2 = (y2 + centery) / 2.0;
|
|
|
|
centerx = (ctrlx1 + ctrlx2) / 2.0;
|
|
|
|
centery = (ctrly1 + ctrly2) / 2.0;
|
|
|
|
if (left != null) {
|
|
|
|
left[leftoff + 2] = x1;
|
|
|
|
left[leftoff + 3] = y1;
|
|
|
|
left[leftoff + 4] = ctrlx1;
|
|
|
|
left[leftoff + 5] = ctrly1;
|
|
|
|
left[leftoff + 6] = centerx;
|
|
|
|
left[leftoff + 7] = centery;
|
|
|
|
}
|
|
|
|
if (right != null) {
|
|
|
|
right[rightoff + 0] = centerx;
|
|
|
|
right[rightoff + 1] = centery;
|
|
|
|
right[rightoff + 2] = ctrlx2;
|
|
|
|
right[rightoff + 3] = ctrly2;
|
|
|
|
right[rightoff + 4] = x2;
|
|
|
|
right[rightoff + 5] = y2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-09-13 02:26:32 +00:00
|
|
|
public static class Rectangle {
|
|
|
|
public double x;
|
|
|
|
public double y;
|
|
|
|
public double width;
|
|
|
|
public double height;
|
|
|
|
|
|
|
|
public void setX(double x) {
|
|
|
|
this.x = x;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
expect(new Double(42.0) == 42.0);
|
|
|
|
|
|
|
|
{ Rectangle r = new Rectangle();
|
|
|
|
Rectangle.class.getMethod("setX", double.class).invoke(r, 42.0);
|
|
|
|
expect(r.x == 42.0);
|
|
|
|
}
|
|
|
|
|
2011-07-06 17:09:06 +00:00
|
|
|
{ double input[] = new double[8];
|
|
|
|
double left[] = new double[8];
|
|
|
|
double right[] = new double[8];
|
|
|
|
|
|
|
|
input[0] = 732.0;
|
|
|
|
input[1] = 952.0;
|
|
|
|
input[2] = 761.0;
|
|
|
|
input[3] = 942.0;
|
|
|
|
input[4] = 786.0;
|
|
|
|
input[5] = 944.0;
|
|
|
|
input[6] = 813.0;
|
|
|
|
input[7] = 939.0;
|
|
|
|
|
|
|
|
subdivide(input, 0, left, 0, right, 0);
|
|
|
|
|
|
|
|
expect(left[0] == 732.0);
|
|
|
|
expect(left[1] == 952.0);
|
|
|
|
expect(left[2] == 746.5);
|
|
|
|
expect(left[3] == 947.0);
|
|
|
|
expect(left[4] == 760.0);
|
|
|
|
expect(left[5] == 945.0);
|
|
|
|
expect(left[6] == 773.25);
|
|
|
|
expect(left[7] == 943.625);
|
|
|
|
|
|
|
|
expect(right[0] == 773.25);
|
|
|
|
expect(right[1] == 943.625);
|
|
|
|
expect(right[2] == 786.5);
|
|
|
|
expect(right[3] == 942.25);
|
|
|
|
expect(right[4] == 799.5);
|
|
|
|
expect(right[5] == 941.5);
|
|
|
|
expect(right[6] == 813.0);
|
|
|
|
expect(right[7] == 939.0);
|
|
|
|
}
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
expect(multiply(0.5d, 0.5d) == 0.25d);
|
|
|
|
expect(multiply(0.5f, 0.5f) == 0.25f);
|
2007-08-13 14:06:31 +00:00
|
|
|
|
2009-03-05 00:52:06 +00:00
|
|
|
expect(multiply(0.5d, 0.1d) == 0.05d);
|
|
|
|
expect(multiply(0.5f, 0.1f) == 0.05f);
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
expect(multiply(0.5d, 0.5d) < 0.5d);
|
|
|
|
expect(multiply(0.5f, 0.5f) < 0.5f);
|
2007-08-13 14:06:31 +00:00
|
|
|
|
2009-03-05 00:52:06 +00:00
|
|
|
expect(multiply(0.5d, 0.1d) < 0.5d);
|
|
|
|
expect(multiply(0.5f, 0.1f) < 0.5f);
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
expect(multiply(0.5d, 0.5d) > 0.1d);
|
|
|
|
expect(multiply(0.5f, 0.5f) > 0.1f);
|
2007-08-13 14:06:31 +00:00
|
|
|
|
2009-03-05 00:52:06 +00:00
|
|
|
expect(multiply(0.5d, 0.1d) > 0.01d);
|
|
|
|
expect(multiply(0.5f, 0.1f) > 0.01f);
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
expect(divide(0.5d, 0.5d) == 1.0d);
|
2007-08-13 14:06:31 +00:00
|
|
|
|
2009-03-05 00:52:06 +00:00
|
|
|
expect(divide(0.5d, 0.1d) == 5.0d);
|
|
|
|
|
2007-10-15 19:12:38 +00:00
|
|
|
expect(subtract(0.5d, 0.5d) == 0.0d);
|
2008-05-23 00:08:41 +00:00
|
|
|
|
2009-03-05 00:52:06 +00:00
|
|
|
expect(subtract(0.5d, 0.1d) == 0.4d);
|
|
|
|
|
2009-11-04 00:02:38 +00:00
|
|
|
{ double d = 1d;
|
|
|
|
expect(((int) d) == 1);
|
|
|
|
}
|
2008-05-23 00:08:41 +00:00
|
|
|
|
2009-11-28 04:15:12 +00:00
|
|
|
{ double d = 12345d;
|
|
|
|
expect(((int) d) == 12345);
|
|
|
|
}
|
|
|
|
|
|
|
|
expect(doubleToInt(new Floats()) == 100);
|
|
|
|
|
2009-11-30 15:10:34 +00:00
|
|
|
{ Floats f = new Floats();
|
|
|
|
f.field = 32.0d;
|
|
|
|
expect(loadAndMultiply(2.0d, f) == 64.0d);
|
|
|
|
}
|
|
|
|
|
|
|
|
{ Floats f = new Floats();
|
|
|
|
f.field = 32.0d;
|
|
|
|
expect(multiply(2.0d, f.field) == 64.0d);
|
|
|
|
}
|
|
|
|
|
|
|
|
{ Floats f = new Floats();
|
|
|
|
multiplyAndStore(32.0d, 0.5d, f);
|
|
|
|
expect(f.field == 16.0d);
|
|
|
|
}
|
|
|
|
|
2009-11-04 00:02:38 +00:00
|
|
|
{ float f = 1f;
|
|
|
|
expect(((int) f) == 1);
|
|
|
|
}
|
2009-10-05 14:25:12 +00:00
|
|
|
|
2009-11-28 04:15:12 +00:00
|
|
|
{ float f = 1f;
|
|
|
|
expect(((long) f) == 1);
|
|
|
|
}
|
|
|
|
|
2008-05-23 00:08:41 +00:00
|
|
|
expect(Math.round(0.4f) == 0);
|
|
|
|
expect(Math.round(0.5f) == 1);
|
|
|
|
expect(Math.round(1.0f) == 1);
|
|
|
|
expect(Math.round(1.9f) == 2);
|
|
|
|
|
|
|
|
expect(Math.round(0.4d) == 0);
|
|
|
|
expect(Math.round(0.5d) == 1);
|
|
|
|
expect(Math.round(1.0d) == 1);
|
|
|
|
expect(Math.round(1.9d) == 2);
|
2009-10-20 21:43:24 +00:00
|
|
|
|
2009-11-04 00:02:38 +00:00
|
|
|
{ float b = 1.0f;
|
|
|
|
int blue = (int)(b * 255 + 0.5);
|
|
|
|
expect(blue == 255);
|
|
|
|
}
|
|
|
|
|
|
|
|
{ long z = 6553311036568663L;
|
|
|
|
double d = (double) z;
|
|
|
|
expect(d == 6553311036568663.0);
|
|
|
|
}
|
2009-11-28 04:15:12 +00:00
|
|
|
|
|
|
|
{ long z = 12345L;
|
|
|
|
float f = (float) z;
|
|
|
|
expect(f == 12345.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
{ int z = 12345;
|
|
|
|
float f = (float) z;
|
|
|
|
expect(f == 12345.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
{ int z = 12345;
|
|
|
|
double d = (double) z;
|
|
|
|
expect(d == 12345.0);
|
|
|
|
}
|
2011-12-29 16:51:44 +00:00
|
|
|
|
|
|
|
// Test floatToIntBits
|
2011-12-29 06:58:33 +00:00
|
|
|
{
|
|
|
|
int orig = 0x7f800001;
|
|
|
|
float NaN = Float.intBitsToFloat(orig);
|
2011-12-28 22:52:53 +00:00
|
|
|
int result = Float.floatToIntBits(NaN);
|
|
|
|
int expected = 0x7fc00000;
|
|
|
|
expect(result == expected);
|
|
|
|
}
|
|
|
|
|
2011-12-29 16:51:44 +00:00
|
|
|
{
|
|
|
|
int orig = 0x7f801001;
|
|
|
|
float NaN = Float.intBitsToFloat(orig);
|
|
|
|
int result = Float.floatToIntBits(NaN);
|
|
|
|
int expected = 0x7fc00000;
|
|
|
|
expect(result == expected);
|
|
|
|
}
|
|
|
|
|
2011-12-28 22:52:53 +00:00
|
|
|
{
|
2011-12-29 06:58:33 +00:00
|
|
|
int orig = 0x00800001;
|
|
|
|
float number = Float.intBitsToFloat(orig);
|
2011-12-28 22:52:53 +00:00
|
|
|
int result = Float.floatToIntBits(number);
|
2011-12-29 06:58:33 +00:00
|
|
|
expect(result == orig);
|
2011-12-28 22:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2011-12-29 06:58:33 +00:00
|
|
|
int orig = 0x80800003;
|
|
|
|
float number = Float.intBitsToFloat(orig);
|
2011-12-28 22:52:53 +00:00
|
|
|
int result = Float.floatToIntBits(number);
|
2011-12-29 06:58:33 +00:00
|
|
|
expect(result == orig);
|
2011-12-28 22:52:53 +00:00
|
|
|
}
|
2012-06-26 16:43:47 +00:00
|
|
|
|
|
|
|
for (int x = 0; x < 1000; ++x) {
|
|
|
|
int m = 100;
|
|
|
|
int n = 200;
|
|
|
|
double array[][] = new double[m][n];
|
|
|
|
|
|
|
|
for (int i = 0; i < m; ++i) {
|
|
|
|
for (int j = 0; j < n; ++j) {
|
|
|
|
array[i][j] = 1234567890.0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-08-12 20:31:58 +00:00
|
|
|
|
|
|
|
{ double v = Double.NaN;
|
|
|
|
expect(0 == (int) v); }
|
|
|
|
|
|
|
|
{ double v = Double.NEGATIVE_INFINITY;
|
|
|
|
expect(Integer.MIN_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ double v = Long.MIN_VALUE;
|
|
|
|
expect(Integer.MIN_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ double v = Double.POSITIVE_INFINITY;
|
|
|
|
expect(Integer.MAX_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ double v = Long.MAX_VALUE;
|
|
|
|
expect(Integer.MAX_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ float v = Float.NaN;
|
|
|
|
expect(0 == (int) v); }
|
|
|
|
|
|
|
|
{ float v = Float.NEGATIVE_INFINITY;
|
|
|
|
expect(Integer.MIN_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ float v = Integer.MIN_VALUE;
|
|
|
|
expect(Integer.MIN_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ float v = Float.POSITIVE_INFINITY;
|
|
|
|
expect(Integer.MAX_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ float v = Integer.MAX_VALUE;
|
|
|
|
expect(Integer.MAX_VALUE == (int) v); }
|
|
|
|
|
|
|
|
{ double v = Double.NaN;
|
|
|
|
expect(0 == (long) v); }
|
|
|
|
|
|
|
|
{ double v = Double.NEGATIVE_INFINITY;
|
|
|
|
expect(Long.MIN_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ double v = Long.MIN_VALUE;
|
|
|
|
expect(Long.MIN_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ double v = Double.POSITIVE_INFINITY;
|
|
|
|
expect(Long.MAX_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ double v = Long.MAX_VALUE;
|
|
|
|
expect(Long.MAX_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ float v = Float.NaN;
|
|
|
|
expect(0 == (long) v); }
|
|
|
|
|
|
|
|
{ float v = Float.NEGATIVE_INFINITY;
|
|
|
|
expect(Long.MIN_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ float v = Integer.MIN_VALUE;
|
|
|
|
expect(Integer.MIN_VALUE == (long) v); }
|
|
|
|
|
|
|
|
{ float v = Float.POSITIVE_INFINITY;
|
|
|
|
expect(Long.MAX_VALUE == (long) v); }
|
2007-08-13 14:06:31 +00:00
|
|
|
}
|
|
|
|
}
|