1 /**************************************************************************
2 *
3 * © 2016 and later: Unicode, Inc. and others.
4 * License & terms of use: http://www.unicode.org/copyright.html#License
5 *
6 ***************************************************************************
7 ***************************************************************************
8 *
9 * Copyright (C) 2013, International Business Machines
10 * Corporation and others. All Rights Reserved.
11 *
12 ************************************************************************/
13 /**
14 * Usage:
15 * build against a configured (but not built) ICU.
16 * example: cc -O2 test_LETableReference.cpp -I. -I/xsrl/II/include -I/xsrl/E/icu/source/tools/ctestfw
17 */
18 #include "unicode/utimer.h"
19 #include "LETableReference.h"
20 #include <stdio.h>
21 #include <stdlib.h>
22
23 #define ITEM_COUNT 10000
24
25 long *items = 0;
26
27 struct OneObject {
28 long items[ITEM_COUNT];
29 };
30
31 struct Long {
32 long v;
33 };
34
35 struct CompObject {
36 Long items[ITEM_COUNT];
37 };
38
39
time_null(void *)40 void time_null(void * /*ref*/) {
41 for(int i=0;i<ITEM_COUNT;i++) {
42 if(items[i]==2) {
43 return;
44 }
45 }
46 puts("error");
47 abort();
48 }
49
time_obj(void * ref)50 void time_obj(void * ref) {
51 OneObject &obj = *((OneObject*)ref);
52 for(int i=0;i<ITEM_COUNT;i++) {
53 if(obj.items[i]==2) {
54 return;
55 }
56 }
57 puts("error");
58 abort();
59 }
time_obj2(void * ref)60 void time_obj2(void * ref) {
61 long *items2 = ((OneObject*)ref)->items;
62 for(int i=0;i<ITEM_COUNT;i++) {
63 if(items2[i]==2) {
64 return;
65 }
66 }
67 puts("error");
68 abort();
69 }
70
time_letr1(void * ref)71 void time_letr1(void * ref) {
72 OneObject &obj = *((OneObject*)ref);
73 LETableReference data((const le_uint8*)ref, sizeof(OneObject));
74 LEErrorCode success = LE_NO_ERROR;
75
76 LEReferenceTo<OneObject> stuff(data, success);
77 if(LE_FAILURE(success)) {
78 puts("failure");
79 abort();
80 }
81 long *items2 = ((OneObject*)ref)->items;
82 for(int i=0;i<ITEM_COUNT;i++) {
83 if(items[i]==2) {
84 return;
85 }
86 }
87 puts("error");
88 abort();
89 }
90
91
time_letr2(void * ref)92 void time_letr2(void * ref) {
93 OneObject &obj = *((OneObject*)ref);
94 LETableReference data((const le_uint8*)ref, sizeof(OneObject));
95 LEErrorCode success = LE_NO_ERROR;
96
97 long *items2 = ((OneObject*)ref)->items;
98 for(int i=0;i<ITEM_COUNT;i++) {
99 LEReferenceTo<OneObject> stuff(data, success);
100 if(LE_FAILURE(success)) {
101 puts("failure");
102 abort();
103 }
104 if(items[i]==2) {
105 return;
106 }
107 }
108 puts("error");
109 abort();
110 }
111
time_letr3(void * ref)112 static void time_letr3(void * ref) {
113 LETableReference data((const le_uint8*)ref, sizeof(OneObject));
114 LEErrorCode success = LE_NO_ERROR;
115 LEReferenceTo<CompObject> comp(data, success);
116 LEReferenceToArrayOf<Long> longs(comp, success, (size_t)0, ITEM_COUNT);
117 if(LE_FAILURE(success)) {
118 puts("failure");
119 abort();
120 }
121
122 for(int i=0;i<ITEM_COUNT;i++) {
123 const Long &item = longs.getObject(i, success);
124 if(LE_FAILURE(success)) {
125 puts("failure");
126 abort();
127 }
128 if(item.v==2) {
129 return;
130 }
131 }
132 puts("error");
133 abort();
134 }
135
136
main()137 int main() {
138 double runTime = 2.0;
139 printf("Test of LETableReference<> timing. %.1fs per run.\n", runTime);
140 items = new long[ITEM_COUNT];
141 OneObject *oo = new OneObject();
142 CompObject *oo2 = new CompObject();
143 for(int i=0;i<ITEM_COUNT-1;i++) {
144 items[i] = oo->items[i] = oo2->items[i].v = (i%1024)+3;
145 }
146 items[ITEM_COUNT-1] = oo->items[ITEM_COUNT-1] = oo2->items[ITEM_COUNT-1].v = 2; // last one
147
148 puts("will call once..");
149 time_letr3((void*)oo2);
150 puts("testing all..");
151
152 int32_t loopCount;
153 double time_taken;
154
155 #define showTime(x,y) printf("%s:\ttesting...\r", #x); fflush(stdout); \
156 time_taken = utimer_loopUntilDone(runTime, &loopCount, x, y); \
157 printf("%s:\t%.1fs\t#%d\t%.1f/s\n", #x, time_taken, loopCount, loopCount/(double)time_taken);
158
159 // clear out cache
160 {
161 double oldTime = runTime;
162 runTime = 0.25;
163 showTime(time_null, NULL);
164 showTime(time_null, NULL);
165 showTime(time_null, NULL);
166 showTime(time_null, NULL);
167 runTime = oldTime;
168 }
169 puts("-- ready to start --");
170
171
172 showTime(time_null, NULL);
173 showTime(time_obj, (void*)oo);
174 showTime(time_obj2, (void*)oo);
175 showTime(time_letr1, (void*)oo2);
176 showTime(time_letr2, (void*)oo2);
177 showTime(time_letr3, (void*)oo2);
178 showTime(time_null, NULL);
179
180 delete [] items;
181 delete oo;
182 delete oo2;
183 }
184