You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1130 lines
34 KiB
JavaScript

import { AttributeCompression } from "../../Source/Cesium.js";
import { Cartesian2 } from "../../Source/Cesium.js";
import { Cartesian3 } from "../../Source/Cesium.js";
import { Cartesian4 } from "../../Source/Cesium.js";
import { defined } from "../../Source/Cesium.js";
import { Math as CesiumMath } from "../../Source/Cesium.js";
describe("Core/AttributeCompression", function () {
var negativeUnitZ = new Cartesian3(0.0, 0.0, -1.0);
it("oct decode(0, 0)", function () {
var result = new Cartesian3();
AttributeCompression.octDecode(0, 0, result);
expect(result).toEqual(negativeUnitZ);
});
it("oct encode(0, 0, -1)", function () {
var result = new Cartesian2();
AttributeCompression.octEncode(negativeUnitZ, result);
expect(result).toEqual(new Cartesian2(255, 255));
});
it("oct encode(0, 0, 1)", function () {
var result = new Cartesian2();
AttributeCompression.octEncode(Cartesian3.UNIT_Z, result);
expect(result).toEqual(new Cartesian2(128, 128));
});
it("oct encode(0, 0, -1) to 4 components", function () {
var result = new Cartesian4();
AttributeCompression.octEncodeToCartesian4(negativeUnitZ, result);
expect(result).toEqual(new Cartesian4(255, 255, 255, 255));
});
it("oct encode(0, 0, 1) to 4 components", function () {
var result = new Cartesian4();
AttributeCompression.octEncodeToCartesian4(Cartesian3.UNIT_Z, result);
expect(result).toEqual(new Cartesian4(128, 0, 128, 0));
});
it("oct extents are equal", function () {
var result = new Cartesian3();
// lower left
AttributeCompression.octDecode(0, 0, result);
expect(result).toEqual(negativeUnitZ);
// lower right
AttributeCompression.octDecode(255, 0, result);
expect(result).toEqual(negativeUnitZ);
// upper right
AttributeCompression.octDecode(255, 255, result);
expect(result).toEqual(negativeUnitZ);
// upper left
AttributeCompression.octDecode(255, 0, result);
expect(result).toEqual(negativeUnitZ);
});
it("throws oct encode vector undefined", function () {
var vector;
var result = new Cartesian3();
expect(function () {
AttributeCompression.octEncode(vector, result);
}).toThrowDeveloperError();
});
it("throws oct encode result undefined", function () {
var result;
expect(function () {
AttributeCompression.octEncode(Cartesian3.UNIT_Z, result);
}).toThrowDeveloperError();
});
it("throws oct encode non unit vector", function () {
var nonUnitLengthVector = new Cartesian3(2.0, 0.0, 0.0);
var result = new Cartesian2();
expect(function () {
AttributeCompression.octEncode(nonUnitLengthVector, result);
}).toThrowDeveloperError();
});
it("throws oct encode zero length vector", function () {
var result = new Cartesian2();
expect(function () {
AttributeCompression.octEncode(Cartesian3.ZERO, result);
}).toThrowDeveloperError();
});
it("throws oct decode result undefined", function () {
var result;
expect(function () {
AttributeCompression.octDecode(0, 0, result);
}).toThrowDeveloperError();
});
it("throws oct decode x out of bounds", function () {
var result = new Cartesian3();
expect(function () {
AttributeCompression.octDecode(256, 0, result);
}).toThrowDeveloperError();
});
it("throws oct decode y out of bounds", function () {
var result = new Cartesian3();
expect(function () {
AttributeCompression.octDecode(0, 256, result);
}).toThrowDeveloperError();
});
it("throws 4-component oct decode out of bounds", function () {
var result = new Cartesian3();
expect(function () {
AttributeCompression.octDecodeFromCartesian4(
new Cartesian4(256, 0, 0, 0),
result
);
}).toThrowDeveloperError();
expect(function () {
AttributeCompression.octDecodeFromCartesian4(
new Cartesian4(0, 256, 0, 0),
result
);
}).toThrowDeveloperError();
expect(function () {
AttributeCompression.octDecodeFromCartesian4(
new Cartesian4(0, 0, 256, 0),
result
);
}).toThrowDeveloperError();
expect(function () {
AttributeCompression.octDecodeFromCartesian4(
new Cartesian4(0, 0, 0, 256),
result
);
}).toThrowDeveloperError();
});
it("oct encoding", function () {
var epsilon = CesiumMath.EPSILON1;
var encoded = new Cartesian2();
var result = new Cartesian3();
var normal = new Cartesian3(0.0, 0.0, 1.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 0.0, -1.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 1.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, -1.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 0.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 0.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
expect(
AttributeCompression.octDecode(encoded.x, encoded.y, result)
).toEqualEpsilon(normal, epsilon);
});
it("oct encoding high precision", function () {
var rangeMax = 4294967295;
var epsilon = CesiumMath.EPSILON8;
var encoded = new Cartesian2();
var result = new Cartesian3();
var normal = new Cartesian3(0.0, 0.0, 1.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 0.0, -1.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 1.0, 0.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, -1.0, 0.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 0.0, 0.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 0.0, 0.0);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeInRange(normal, rangeMax, encoded);
expect(
AttributeCompression.octDecodeInRange(
encoded.x,
encoded.y,
rangeMax,
result
)
).toEqualEpsilon(normal, epsilon);
});
it("oct encoding to 4 components", function () {
var epsilon = CesiumMath.EPSILON1;
var encoded = new Cartesian4();
var result = new Cartesian3();
var normal = new Cartesian3(0.0, 0.0, 1.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 0.0, -1.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 1.0, 0.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, -1.0, 0.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 0.0, 0.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 0.0, 0.0);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncodeToCartesian4(normal, encoded);
expect(
AttributeCompression.octDecodeFromCartesian4(encoded, result)
).toEqualEpsilon(normal, epsilon);
});
it("octFloat encoding", function () {
var epsilon = CesiumMath.EPSILON1;
var result = new Cartesian3();
var normal = new Cartesian3(0.0, 0.0, 1.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 0.0, -1.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, 1.0, 0.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(0.0, -1.0, 0.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 0.0, 0.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 0.0, 0.0);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
normal = new Cartesian3(-1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
expect(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result
)
).toEqualEpsilon(normal, epsilon);
});
it("octFloat encoding is equivalent to oct encoding", function () {
var encoded = new Cartesian2();
var result1 = new Cartesian3();
var result2 = new Cartesian3();
var normal = new Cartesian3(0.0, 0.0, 1.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(0.0, 0.0, -1.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(0.0, 1.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(0.0, -1.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(1.0, 0.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(-1.0, 0.0, 0.0);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(-1.0, -1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(-1.0, 1.0, 1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(-1.0, 1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
normal = new Cartesian3(-1.0, -1.0, -1.0);
Cartesian3.normalize(normal, normal);
AttributeCompression.octEncode(normal, encoded);
AttributeCompression.octDecode(encoded.x, encoded.y, result1);
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(normal),
result2
);
expect(result1).toEqual(result2);
});
it("encodeFloat throws without vector", function () {
expect(function () {
AttributeCompression.octEncodeFloat(undefined);
}).toThrowDeveloperError();
});
it("decodeFloat throws without value", function () {
expect(function () {
AttributeCompression.octDecodeFloat(undefined, new Cartesian3());
}).toThrowDeveloperError();
});
it("decodeFloat throws without result", function () {
expect(function () {
AttributeCompression.octDecodeFloat(0.0, undefined);
}).toThrowDeveloperError();
});
it("encode and packFloat is equivalent to oct encoding", function () {
var vector = new Cartesian3(1.0, 1.0, 1.0);
Cartesian3.normalize(vector, vector);
var encoded = AttributeCompression.octEncode(vector, new Cartesian2());
var encodedFloat = AttributeCompression.octPackFloat(encoded);
expect(
AttributeCompression.octDecodeFloat(encodedFloat, new Cartesian3())
).toEqual(
AttributeCompression.octDecode(encoded.x, encoded.y, new Cartesian3())
);
});
it("packFloat throws without encoded", function () {
expect(function () {
AttributeCompression.octPackFloat(undefined);
}).toThrowDeveloperError();
});
it("pack is equivalent to oct encoding", function () {
var x = Cartesian3.UNIT_X;
var y = Cartesian3.UNIT_Y;
var z = Cartesian3.UNIT_Z;
var packed = AttributeCompression.octPack(x, y, z, new Cartesian2());
var decodedX = new Cartesian3();
var decodedY = new Cartesian3();
var decodedZ = new Cartesian3();
AttributeCompression.octUnpack(packed, decodedX, decodedY, decodedZ);
expect(decodedX).toEqual(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(x),
new Cartesian3()
)
);
expect(decodedY).toEqual(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(y),
new Cartesian3()
)
);
expect(decodedZ).toEqual(
AttributeCompression.octDecodeFloat(
AttributeCompression.octEncodeFloat(z),
new Cartesian3()
)
);
});
it("pack throws without v1", function () {
expect(function () {
AttributeCompression.octPack(
undefined,
new Cartesian3(),
new Cartesian3(),
new Cartesian2()
);
}).toThrowDeveloperError();
});
it("pack throws without v2", function () {
expect(function () {
AttributeCompression.octPack(
new Cartesian3(),
undefined,
new Cartesian3(),
new Cartesian2()
);
}).toThrowDeveloperError();
});
it("pack throws without v3", function () {
expect(function () {
AttributeCompression.octPack(
new Cartesian3(),
new Cartesian3(),
undefined,
new Cartesian2()
);
}).toThrowDeveloperError();
});
it("pack throws without result", function () {
expect(function () {
AttributeCompression.octPack(
new Cartesian3(),
new Cartesian3(),
new Cartesian3(),
undefined
);
}).toThrowDeveloperError();
});
it("unpack throws without packed", function () {
expect(function () {
AttributeCompression.octUnpack(
undefined,
new Cartesian3(),
new Cartesian3(),
new Cartesian3()
);
}).toThrowDeveloperError();
});
it("unpack throws without v1", function () {
expect(function () {
AttributeCompression.octUnpack(
new Cartesian2(),
undefined,
new Cartesian3(),
new Cartesian3()
);
}).toThrowDeveloperError();
});
it("unpack throws without v2", function () {
expect(function () {
AttributeCompression.octUnpack(
new Cartesian2(),
new Cartesian3(),
undefined,
new Cartesian3()
);
}).toThrowDeveloperError();
});
it("unpack throws without v3", function () {
expect(function () {
AttributeCompression.octUnpack(
new Cartesian2(),
new Cartesian3(),
new Cartesian3(),
undefined
);
}).toThrowDeveloperError();
});
it("compresses texture coordinates", function () {
var coords = new Cartesian2(0.5, 0.5);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqualEpsilon(coords, 1.0 / 4096.0);
});
it("compress texture coordinates throws without texture coordinates", function () {
expect(function () {
AttributeCompression.compressTextureCoordinates(undefined);
}).toThrowDeveloperError();
});
it("decompress texture coordinates throws without encoded texture coordinates", function () {
expect(function () {
AttributeCompression.decompressTextureCoordinates(
undefined,
new Cartesian2()
);
}).toThrowDeveloperError();
});
it("decompress texture coordinates throws without result", function () {
expect(function () {
AttributeCompression.decompressTextureCoordinates(0.0, undefined);
}).toThrowDeveloperError();
});
it("compresses/decompresses 1.0", function () {
var coords = new Cartesian2(1.0, 1.0);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqual(coords);
});
it("compresses/decompresses 0.0", function () {
var coords = new Cartesian2(1.0, 1.0);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqual(coords);
});
it("compresses/decompresses 0.5 / 1.0", function () {
var coords = new Cartesian2(0.5, 1.0);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqualEpsilon(coords, 1.0 / 4095.0);
});
it("compresses/decompresses 1.0 / 0.5", function () {
var coords = new Cartesian2(1.0, 0.5);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqualEpsilon(coords, 1.0 / 4095.0);
});
it("compresses/decompresses values very close but not equal to 1.0", function () {
var coords = new Cartesian2(0.99999999999999, 0.99999999999999);
expect(
AttributeCompression.decompressTextureCoordinates(
AttributeCompression.compressTextureCoordinates(coords),
new Cartesian2()
)
).toEqualEpsilon(coords, 1.0 / 4095.0);
});
function zigZag(value) {
return ((value << 1) ^ (value >> 15)) & 0xffff;
}
var maxShort = 32767;
function deltaZigZagEncode(uBuffer, vBuffer, heightBuffer) {
var length = uBuffer.length;
var buffer = new Uint16Array(length * (defined(heightBuffer) ? 3 : 2));
var lastU = 0;
var lastV = 0;
var lastHeight = 0;
for (var i = 0; i < length; ++i) {
var u = uBuffer[i];
var v = vBuffer[i];
buffer[i] = zigZag(u - lastU);
buffer[i + length] = zigZag(v - lastV);
lastU = u;
lastV = v;
if (defined(heightBuffer)) {
var height = heightBuffer[i];
buffer[i + length * 2] = zigZag(height - lastHeight);
lastHeight = height;
}
}
return buffer;
}
it("decodes delta and ZigZag encoded vertices without height", function () {
var length = 10;
var decodedUBuffer = new Array(length);
var decodedVBuffer = new Array(length);
for (var i = 0; i < length; ++i) {
decodedUBuffer[i] = Math.floor(Math.random() * maxShort);
decodedVBuffer[i] = Math.floor(Math.random() * maxShort);
}
var encoded = deltaZigZagEncode(decodedUBuffer, decodedVBuffer);
var uBuffer = new Uint16Array(encoded.buffer, 0, length);
var vBuffer = new Uint16Array(
encoded.buffer,
length * Uint16Array.BYTES_PER_ELEMENT,
length
);
AttributeCompression.zigZagDeltaDecode(uBuffer, vBuffer);
expect(uBuffer).toEqual(decodedUBuffer);
expect(vBuffer).toEqual(decodedVBuffer);
});
it("decodes delta and ZigZag encoded vertices with height", function () {
var length = 10;
var decodedUBuffer = new Array(length);
var decodedVBuffer = new Array(length);
var decodedHeightBuffer = new Array(length);
for (var i = 0; i < length; ++i) {
decodedUBuffer[i] = Math.floor(Math.random() * maxShort);
decodedVBuffer[i] = Math.floor(Math.random() * maxShort);
decodedHeightBuffer[i] = Math.floor(Math.random() * maxShort);
}
var encoded = deltaZigZagEncode(
decodedUBuffer,
decodedVBuffer,
decodedHeightBuffer
);
var uBuffer = new Uint16Array(encoded.buffer, 0, length);
var vBuffer = new Uint16Array(
encoded.buffer,
length * Uint16Array.BYTES_PER_ELEMENT,
length
);
var heightBuffer = new Uint16Array(
encoded.buffer,
2 * length * Uint16Array.BYTES_PER_ELEMENT,
length
);
AttributeCompression.zigZagDeltaDecode(uBuffer, vBuffer, heightBuffer);
expect(uBuffer).toEqual(decodedUBuffer);
expect(vBuffer).toEqual(decodedVBuffer);
expect(heightBuffer).toEqual(decodedHeightBuffer);
});
it("throws when zigZagDeltaDecode has an undefined uBuffer", function () {
expect(function () {
AttributeCompression.zigZagDeltaDecode(undefined, new Uint16Array(10));
}).toThrowDeveloperError();
});
it("throws when zigZagDeltaDecode has an undefined vBuffer", function () {
expect(function () {
AttributeCompression.zigZagDeltaDecode(new Uint16Array(10), undefined);
}).toThrowDeveloperError();
});
it("throws when zigZagDeltaDecode has unequal uBuffer and vBuffer length", function () {
expect(function () {
AttributeCompression.zigZagDeltaDecode(
new Uint16Array(10),
new Uint16Array(11)
);
}).toThrowDeveloperError();
});
it("throws when zigZagDeltaDecode has unequal uBuffer, vBuffer, and heightBuffer length", function () {
expect(function () {
AttributeCompression.zigZagDeltaDecode(
new Uint16Array(10),
new Uint16Array(10),
new Uint16Array(11)
);
}).toThrowDeveloperError();
});
});