1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
/*
* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/licenses/publicdomain/
*/
if (!this.hasOwnProperty("TypedObject"))
quit();
var PointType = new TypedObject.StructType({x: TypedObject.uint16,
y: TypedObject.uint16,
z: TypedObject.uint16});
var VecPointType = PointType.array(3);
var PairVecType = new TypedObject.StructType({fst: VecPointType,
snd: VecPointType});
function foo() {
for (var i = 0; i < 5000; i += 9) {
var p = new PairVecType({fst: [{x: i, y: i+1, z:i+2},
{x: i+3, y: i+4, z:i+5},
{x: i+6, y: i+7, z:i+8}],
snd: [{x: i+9, y:i+10, z:i+11},
{x: i+12, y:i+13, z:i+14},
{x: i+15, y:i+16, z:i+17}]
});
var sum;
sum = p.fst[0].x + p.fst[0].y + p.fst[0].z;
assertEq(sum, 3*i + 3);
sum = p.fst[1].x + p.fst[1].y + p.fst[1].z;
assertEq(sum, 3*i + 12);
sum = p.fst[2].x + p.fst[2].y + p.fst[2].z;
assertEq(sum, 3*i + 21);
sum = p.snd[0].x + p.snd[0].y + p.snd[0].z;
assertEq(sum, 3*i + 30);
sum = p.snd[1].x + p.snd[1].y + p.snd[1].z;
assertEq(sum, 3*i + 39);
sum = p.snd[2].x + p.snd[2].y + p.snd[2].z;
assertEq(sum, 3*i + 48);
}
}
foo();
|