|         |      1 // Copyright (c) 1995-2009 Nokia Corporation and/or its subsidiary(-ies). | 
|         |      2 // All rights reserved. | 
|         |      3 // This component and the accompanying materials are made available | 
|         |      4 // under the terms of the License "Eclipse Public License v1.0" | 
|         |      5 // which accompanies this distribution, and is available | 
|         |      6 // at the URL "http://www.eclipse.org/legal/epl-v10.html". | 
|         |      7 // | 
|         |      8 // Initial Contributors: | 
|         |      9 // Nokia Corporation - initial contribution. | 
|         |     10 // | 
|         |     11 // Contributors: | 
|         |     12 // | 
|         |     13 // Description: | 
|         |     14 // e32test\math\t_math.cpp | 
|         |     15 // T_MATH.CPP - Test routines for the maths functions | 
|         |     16 // NB When considering the accuracy of the results (i.e. the tolerance used in testApprox()) it | 
|         |     17 // should be remembered that the results expected are not always given to full precision and so | 
|         |     18 // the results obtained are mostly as accurate as can be expected. | 
|         |     19 // Overview: | 
|         |     20 // Test functionality of the Math library. | 
|         |     21 // API Information: | 
|         |     22 // Math. | 
|         |     23 // Details: | 
|         |     24 // - Test math's trigonometric, powers, roots, logs, modulo, sqrt, exp, | 
|         |     25 // Int, Frac, rounding for range of input values are as expected. | 
|         |     26 // - Test the returned error values are as expected when illegal math's | 
|         |     27 // operations are done. | 
|         |     28 // - Check the return value is KErrTotalLossOfPrecision when incorrect values | 
|         |     29 // is passed to modulo function. | 
|         |     30 // - Test for success when the same variable for both operands in some  | 
|         |     31 // Math functions are used. | 
|         |     32 // Platforms/Drives/Compatibility: | 
|         |     33 // All. | 
|         |     34 // Assumptions/Requirement/Pre-requisites: | 
|         |     35 // Failures and causes: | 
|         |     36 // Base Port information: | 
|         |     37 //  | 
|         |     38 // | 
|         |     39  | 
|         |     40 #include "t_math.h" | 
|         |     41 #include "t_vals.h" | 
|         |     42  | 
|         |     43 LOCAL_D RTest test(_L("T_MATH")); | 
|         |     44  | 
|         |     45 LOCAL_D TInt64 rseed = MAKE_TINT64(123456789,987654321); | 
|         |     46  | 
|         |     47 typedef struct | 
|         |     48     { | 
|         |     49     TReal num; // input number | 
|         |     50     TReal res; // expected result | 
|         |     51     } SQRT_TEST; | 
|         |     52  | 
|         |     53 LOCAL_D SQRT_TEST testsqrt[]= | 
|         |     54     { | 
|         |     55     {0.0,0.0}, // zero | 
|         |     56 	{KNegZeroTReal64,KNegZeroTReal64}, | 
|         |     57     {1.0,1.0}, | 
|         |     58     {.64,.8}, | 
|         |     59     {.81,.9}, | 
|         |     60     {9,3}, | 
|         |     61     {25,5}, | 
|         |     62     {10000,100}, | 
|         |     63     {400,20}, | 
|         |     64     {6.25,2.5}, | 
|         |     65     {1E-98,1E-49}, | 
|         |     66     {1E-98,1E-49}, | 
|         |     67     {1E98,1E49}, | 
|         |     68     {1.0000000001,1.00000000005} | 
|         |     69     }; | 
|         |     70  | 
|         |     71 typedef struct | 
|         |     72     { | 
|         |     73     TReal num; // input number | 
|         |     74     TReal res; // expected result | 
|         |     75     } TESTLN; | 
|         |     76  | 
|         |     77 LOCAL_D TESTLN testln[]= | 
|         |     78     { | 
|         |     79     {.001,-6.9077552789821317}, | 
|         |     80     {.002,-6.2146080984221917}, | 
|         |     81     {.023,-3.7722610630529874}, | 
|         |     82     {.004,-5.5214609178622464}, | 
|         |     83     {.050,-2.9957322735539910}, | 
|         |     84     {.100,-2.3025850929940457}, | 
|         |     85     {.150,-1.8971199848858813}, | 
|         |     86     {.200,-1.6094379124341004}, | 
|         |     87     {.250,-1.3862943611198906}, | 
|         |     88     {.300,-1.2039728043259360}, | 
|         |     89     {.350,-1.0498221244986777}, | 
|         |     90     {.400,-0.9162907318741551}, | 
|         |     91     {.450,-0.7985076962177716}, | 
|         |     92     {.500,-0.6931471805599453}, | 
|         |     93     {.550,-0.5978370007556204}, | 
|         |     94     {.600,-0.5108256237659907}, | 
|         |     95     {.650,-0.4307829160924543}, | 
|         |     96     {.700,-0.3566749439387324}, | 
|         |     97     {.750,-0.2876820724517809}, | 
|         |     98     {.980,-0.0202027073175194}, | 
|         |     99     {.985,-0.0151136378100482}, | 
|         |    100     {.990,-0.0100503358535014}, | 
|         |    101     {.995,-0.0050125418235443}, | 
|         |    102     {.088,-2.4304184645039306}, | 
|         |    103     {1,0} | 
|         |    104     }; | 
|         |    105  | 
|         |    106 typedef struct | 
|         |    107     { | 
|         |    108     TReal val; // value for which the exponent is to be found | 
|         |    109     TReal result; // result | 
|         |    110     } EXP; | 
|         |    111  | 
|         |    112 LOCAL_D EXP testexp[]= | 
|         |    113     { | 
|         |    114     {4E-20,1.0},  | 
|         |    115 	{5.4E-20,1.0}, | 
|         |    116 	{0.0,1.0}, | 
|         |    117 	{5E-324,1.0}, | 
|         |    118     }; | 
|         |    119  | 
|         |    120 typedef struct | 
|         |    121     { | 
|         |    122     TReal number; // number to be raised to a power | 
|         |    123     TReal power; // power | 
|         |    124     TReal result; // result | 
|         |    125     } POWER; | 
|         |    126  | 
|         |    127 LOCAL_D POWER testpow[]= | 
|         |    128     { | 
|         |    129 	{45,3,91125.0}, | 
|         |    130 	{-2,4,16}, | 
|         |    131     {2,-3,0.125}, | 
|         |    132     {-2,3,-8}, | 
|         |    133     {16,20,1.208925819614628E+24}, | 
|         |    134     }; | 
|         |    135  | 
|         |    136 // Added by AnnW, October 1996 | 
|         |    137 LOCAL_D const POWER testpowexact[]= | 
|         |    138 	{ | 
|         |    139 	{0.0,1.0,0.0}, | 
|         |    140 	{0,7,0}, | 
|         |    141 	{0.0,16.0,0.0}, | 
|         |    142 	{0.0,3.9271E-17,0.0}, | 
|         |    143 	{-2,0,1}, | 
|         |    144     {1,0,1}, | 
|         |    145 	{1.545243,0,1}, | 
|         |    146 	{4.8,0.0,1.0}, | 
|         |    147 	{195.0,0.0,1.0}, | 
|         |    148 	{1.0E-7,0.0,1.0}, | 
|         |    149 	{1.0,2.0,1.0}, | 
|         |    150 	{1.0,1.0E-6,1.0}, | 
|         |    151 	{1.0,1.0E+10,1.0}, | 
|         |    152 	{-1.0,2.0,1.0}, | 
|         |    153 	{-1.0,1.0000000001E+10,-1.0}, | 
|         |    154 	{-1.0,1.0E+10,1.0}, | 
|         |    155 	{1.593704102953967e+3,1.0,1.593704102953967e+3}, | 
|         |    156 	{1.234567E+50,1.0,1.234567E+50}, | 
|         |    157 	{1.2345678901234567E+146,1.0,1.2345678901234567E+146}, | 
|         |    158 	{-7.6543210987654321E-53,1.0,-7.6543210987654321E-53}, | 
|         |    159 	{0.0,2.0,0.0}, | 
|         |    160 	{KNegZeroTReal64,4.0,0.0}, | 
|         |    161 	{KPosInfTReal64,-2.0,0.0}, | 
|         |    162 	{KNegInfTReal64,-2.0,0.0}, | 
|         |    163 	{2.0,KNegInfTReal64,0.0}, | 
|         |    164 	{-2.0,KNegInfTReal64,0.0}, | 
|         |    165 	{0.5,KPosInfTReal64,0.0}, | 
|         |    166 	{-0.5,KPosInfTReal64,0.0}, | 
|         |    167 	{KPosInfTReal64,-5.0,0.0}, | 
|         |    168 	{KPosInfTReal64,-6.0,0.0}, | 
|         |    169 	{KNegInfTReal64,KNegInfTReal64,0.0}, | 
|         |    170 	{KPosInfTReal64,KNegInfTReal64,0.0}, | 
|         |    171 	}; | 
|         |    172  | 
|         |    173 // Check ISO requirements on Pow() | 
|         |    174 // | 
|         |    175 typedef struct | 
|         |    176 	{ | 
|         |    177 	TReal number;	// number to be raised to a power | 
|         |    178 	TReal power;	// power | 
|         |    179 	TInt rc;		// return value from Pow() | 
|         |    180 	TReal result;	// numerical result | 
|         |    181 	} POWERISO; | 
|         |    182  | 
|         |    183 const TReal KPosZeroTReal64 = 0.0; | 
|         |    184  | 
|         |    185 LOCAL_D const POWERISO testpow_iso[] = | 
|         |    186 	{ | 
|         |    187 	// pow(+/-0, y) returns +/-INF and raises the ''divide-by-zero'' | 
|         |    188 	// floating-point exception for y an odd integer < 0 | 
|         |    189 	{ KPosZeroTReal64, -3.0, KErrOverflow, KPosInfTReal64 },	// 0 | 
|         |    190 	{ KNegZeroTReal64, -3.0, KErrOverflow, KNegInfTReal64 },	// 1 | 
|         |    191  | 
|         |    192 	// pow(+/-0, y) returns +INF and raises the ''divide-by-zero'' | 
|         |    193 	// floating-point exception for y < 0 and not an odd integer | 
|         |    194 	{ KPosZeroTReal64, -2.0, KErrOverflow, KPosInfTReal64 },	// 2 | 
|         |    195 	{ KNegZeroTReal64, -2.0, KErrOverflow, KPosInfTReal64 },	// 3 | 
|         |    196  | 
|         |    197 	// pow(+/-0, y) returns +/-0 for y an odd integer > 0 | 
|         |    198 	{ KPosZeroTReal64, 3.0, KErrNone, KPosZeroTReal64 },		// 4 | 
|         |    199 	{ KNegZeroTReal64, 3.0, KErrNone, KNegZeroTReal64 },		// 5 | 
|         |    200  | 
|         |    201 	// pow(+/-0, y) returns +0 for y > 0 and not an odd integer | 
|         |    202 	{ KPosZeroTReal64, 2.0, KErrNone, KPosZeroTReal64 },		// 6 | 
|         |    203 	{ KNegZeroTReal64, 2.0, KErrNone, KPosZeroTReal64 },		// 7 | 
|         |    204  | 
|         |    205 	// pow(-1, +/-INF) returns 1 | 
|         |    206 	{ -1.0, KPosInfTReal64, KErrNone, 1.0 },					// 8 | 
|         |    207 	{ -1.0, KNegInfTReal64, KErrNone, 1.0 },					// 9 | 
|         |    208  | 
|         |    209 	// pow(+1, y) returns 1 for any y, even a NaN | 
|         |    210 	{ 1.0, 1.0, KErrNone, 1.0 },								// 10 | 
|         |    211 	{ 1.0, 10.0, KErrNone, 1.0 },								// 11 | 
|         |    212 	{ 1.0, -1.0, KErrNone, 1.0 },								// 12 | 
|         |    213 	{ 1.0, -10.0, KErrNone, 1.0 },								// 13 | 
|         |    214 	{ 1.0, 0.5, KErrNone, 1.0 },								// 14 | 
|         |    215 	{ 1.0, -0.5, KErrNone, 1.0 },								// 15 | 
|         |    216 	{ 1.0, KPosInfTReal64, KErrNone, 1.0 },						// 16 | 
|         |    217 	{ 1.0, KNegInfTReal64, KErrNone, 1.0 },						// 17 | 
|         |    218 	{ 1.0, KNaNTReal64, KErrNone, 1.0 },						// 18 | 
|         |    219  | 
|         |    220 	// pow(x, +/-0) returns 1 for any x, even a NaN | 
|         |    221 	{  1.0, KPosZeroTReal64, KErrNone, 1.0 },					// 19 | 
|         |    222 	{  1.0, KNegZeroTReal64, KErrNone, 1.0 },					// 20 | 
|         |    223 	{  2.0, KPosZeroTReal64, KErrNone, 1.0 },					// 21 | 
|         |    224 	{  2.0, KNegZeroTReal64, KErrNone, 1.0 },					// 22 | 
|         |    225 	{  0.5, KPosZeroTReal64, KErrNone, 1.0 },					// 23 | 
|         |    226 	{  0.5, KNegZeroTReal64, KErrNone, 1.0 },					// 24 | 
|         |    227 	{ -1.0, KPosZeroTReal64, KErrNone, 1.0 },					// 25 | 
|         |    228 	{ -1.0, KNegZeroTReal64, KErrNone, 1.0 },					// 26 | 
|         |    229 	{ -2.0, KPosZeroTReal64, KErrNone, 1.0 },					// 27 | 
|         |    230 	{ -2.0, KNegZeroTReal64, KErrNone, 1.0 },					// 28 | 
|         |    231 	{ -0.5, KPosZeroTReal64, KErrNone, 1.0 },					// 29 | 
|         |    232 	{ -0.5, KNegZeroTReal64, KErrNone, 1.0 },					// 30 | 
|         |    233 	{ KPosZeroTReal64, KPosZeroTReal64, KErrNone, 1.0 },		// 31 | 
|         |    234 	{ KPosZeroTReal64, KNegZeroTReal64, KErrNone, 1.0 },		// 32 | 
|         |    235 	{ KNegZeroTReal64, KPosZeroTReal64, KErrNone, 1.0 },		// 33 | 
|         |    236 	{ KNegZeroTReal64, KNegZeroTReal64, KErrNone, 1.0 },		// 34 | 
|         |    237 	{ KPosInfTReal64, KPosZeroTReal64, KErrNone, 1.0 },			// 35 | 
|         |    238 	{ KPosInfTReal64, KNegZeroTReal64, KErrNone, 1.0 },			// 36 | 
|         |    239 	{ KNegInfTReal64, KPosZeroTReal64, KErrNone, 1.0 },			// 37 | 
|         |    240 	{ KNegInfTReal64, KNegZeroTReal64, KErrNone, 1.0 },			// 38 | 
|         |    241 	{ KNaNTReal64, KPosZeroTReal64, KErrNone, 1.0 },			// 39 | 
|         |    242 	{ KNaNTReal64, KNegZeroTReal64, KErrNone, 1.0 },			// 40 | 
|         |    243  | 
|         |    244 	// pow(x, y) returns a NaN and raises the ''invalid'' floating-point | 
|         |    245 	// exception for finite x < 0 and finite non-integer y | 
|         |    246 	{ -1.0, 1.5, KErrArgument, KNaNTReal64 },					// 41 | 
|         |    247  | 
|         |    248 	// pow(x, -INF) returns +INF for |x| < 1 | 
|         |    249 	{ 0.5, KNegInfTReal64, KErrOverflow, KPosInfTReal64 },		// 42 | 
|         |    250 	{ -0.5, KNegInfTReal64, KErrOverflow, KPosInfTReal64 },		// 43 | 
|         |    251  | 
|         |    252 	// pow(x, -INF) returns +0 for |x| > 1 | 
|         |    253 	{ 2, KNegInfTReal64, KErrNone, KPosZeroTReal64 },			// 44 | 
|         |    254 	{ -2, KNegInfTReal64, KErrNone, KPosZeroTReal64 },			// 45 | 
|         |    255 	{ 4.5, KNegInfTReal64, KErrNone, KPosZeroTReal64 },			// 46 | 
|         |    256 	{ -4.5, KNegInfTReal64, KErrNone, KPosZeroTReal64 },		// 47 | 
|         |    257  | 
|         |    258 	// pow(x, +INF) returns +0 for |x| < 1 | 
|         |    259 	{ .5, KPosInfTReal64, KErrNone, KPosZeroTReal64 },			// 48 | 
|         |    260 	{ -.5, KPosInfTReal64, KErrNone, KPosZeroTReal64 },			// 49 | 
|         |    261  | 
|         |    262 	// pow(x, +INF) returns +INF for |x| > 1 | 
|         |    263 	{ 2, KPosInfTReal64, KErrOverflow, KPosInfTReal64 },		// 50 | 
|         |    264 	{ -2, KPosInfTReal64, KErrOverflow, KPosInfTReal64 },		// 51 | 
|         |    265 	{ 4.5, KPosInfTReal64, KErrOverflow, KPosInfTReal64 },		// 52 | 
|         |    266 	{ -4.5, KPosInfTReal64, KErrOverflow, KPosInfTReal64 },		// 53 | 
|         |    267  | 
|         |    268 	// pow(-INF, y) returns -0 for y an odd integer < 0 | 
|         |    269 	{ KNegInfTReal64, -1, KErrNone, KNegZeroTReal64 },			// 54 | 
|         |    270 	{ KNegInfTReal64, -5, KErrNone, KNegZeroTReal64 },			// 55 | 
|         |    271  | 
|         |    272 	// pow(-INF, y) returns +0 for y < 0 and not an odd integer | 
|         |    273 	{ KNegInfTReal64, -2, KErrNone, KPosZeroTReal64 },			// 56 | 
|         |    274 	{ KNegInfTReal64, -5.5, KErrNone, KPosZeroTReal64 },		// 57 | 
|         |    275  | 
|         |    276 	// pow(-INF, y) returns -INF for y an odd integer > 0 | 
|         |    277 	{ KNegInfTReal64, 1, KErrOverflow, KNegInfTReal64 },		// 58 | 
|         |    278 	{ KNegInfTReal64, 5, KErrOverflow, KNegInfTReal64 },		// 59 | 
|         |    279  | 
|         |    280 	// pow(-INF, y) returns +INF for y > 0 and not an odd integer | 
|         |    281 	{ KNegInfTReal64, 2, KErrOverflow, KPosInfTReal64 },		// 60 | 
|         |    282 	{ KNegInfTReal64, 5.5, KErrOverflow, KPosInfTReal64 },		// 61 | 
|         |    283  | 
|         |    284 	// pow(+INF, y) returns +0 for y < 0 | 
|         |    285 	{ KPosInfTReal64, -1, KErrNone, KPosZeroTReal64 },			// 62 | 
|         |    286 	{ KPosInfTReal64, -2, KErrNone, KPosZeroTReal64 },			// 63 | 
|         |    287 	{ KPosInfTReal64, -5, KErrNone, KPosZeroTReal64 },			// 64 | 
|         |    288 	{ KPosInfTReal64, -5.5, KErrNone, KPosZeroTReal64 },		// 65 | 
|         |    289  | 
|         |    290 	// pow(+INF, y) returns +INF for y > 0 | 
|         |    291 	{ KPosInfTReal64, 1, KErrOverflow, KPosInfTReal64 },		// 66 | 
|         |    292 	{ KPosInfTReal64, 2, KErrOverflow, KPosInfTReal64 },		// 67 | 
|         |    293 	{ KPosInfTReal64, 5, KErrOverflow, KPosInfTReal64 },		// 68 | 
|         |    294 	{ KPosInfTReal64, 5.5, KErrOverflow, KPosInfTReal64 },		// 69 | 
|         |    295 	}; | 
|         |    296  | 
|         |    297 struct POW10_TEST | 
|         |    298     { | 
|         |    299     TInt num; // input number | 
|         |    300     TReal res; // expected result | 
|         |    301     }; | 
|         |    302  | 
|         |    303 LOCAL_D POW10_TEST pow10teste[]= | 
|         |    304 	{ | 
|         |    305 	{300,1.0E300},		 | 
|         |    306 	{-162,1.0E-162}, | 
|         |    307 	{-300,1.0E-300}, | 
|         |    308 	{-99,1.0E-99}, | 
|         |    309 //	}; | 
|         |    310  | 
|         |    311 //LOCAL_D POW10_TEST pow10testa[]= | 
|         |    312 //	{ | 
|         |    313 	{99,1.0E99}, | 
|         |    314 	{283,1.0E283}, | 
|         |    315 	{-89,1.0E-89}, | 
|         |    316 	{-200,1.0E-200}, | 
|         |    317 	{-43,1.0E-43}, | 
|         |    318 	{24,1.0E24}, | 
|         |    319  	{-310,K1EMinus310Real64}, | 
|         |    320  	{-323,K1EMinus323Real64} | 
|         |    321 	}; | 
|         |    322  | 
|         |    323 typedef struct | 
|         |    324     { | 
|         |    325     TReal num; // input number | 
|         |    326     TReal res; // expected result | 
|         |    327     } TESTSINE; | 
|         |    328  | 
|         |    329 #pragma warning ( disable : 4204 ) // non-constant aggregate initializer | 
|         |    330 LOCAL_D TESTSINE testsin[]= | 
|         |    331     { | 
|         |    332 	{0.5,0.4794255386042029},						// These were found using S3a | 
|         |    333 	{1.2,0.9320390859672263}, | 
|         |    334 	{1.6,0.9995736030415051}, | 
|         |    335 	{28.6,-0.3199399618841981}, | 
|         |    336 	{-18.3,0.5223085896267315}, | 
|         |    337 	{KPi/4,0.7071067811865474}, | 
|         |    338 	{3*KPi/4,0.7071067811865474}, | 
|         |    339 	{5*KPi/4,-0.7071067811865474}, | 
|         |    340 	{-KPi/4,-0.7071067811865474}, | 
|         |    341 	{KPi/3,0.8660254037844387}, | 
|         |    342 	{-KPi/3,-0.8660254037844387}, | 
|         |    343 	{KPi/6,0.5}, | 
|         |    344 	{-KPi/6,-0.5}, | 
|         |    345 	{150*KDegToRad,0.5}, | 
|         |    346 	{210*KDegToRad,-0.5}, | 
|         |    347 //	{KPi+1.0E-15,-7.657143961860984E-16},	// loss of significance will limit accuracy here | 
|         |    348 //	2*(KPi+1.0E-15),1.5314287923721969e-15} | 
|         |    349     }; | 
|         |    350      | 
|         |    351 typedef struct | 
|         |    352     { | 
|         |    353     TReal num; // input number | 
|         |    354     TReal res; // expected result | 
|         |    355     } TESTCOSINE; | 
|         |    356  | 
|         |    357 LOCAL_D TESTCOSINE testcos[]= | 
|         |    358 	{ | 
|         |    359 	{0.5,0.8775825618903727},			// These were found using S3a | 
|         |    360 	{1.2,0.3623577544766734}, | 
|         |    361 	{1.6,-0.0291995223012888}, | 
|         |    362 	{28.6,-0.9474378189567576}, | 
|         |    363 	{-18.3,0.8527565521308730}, | 
|         |    364 	{KPi/4,0.7071067811865474}, | 
|         |    365 	{3*KPi/4,-0.7071067811865474}, | 
|         |    366 	{5*KPi/4,-0.7071067811865474}, | 
|         |    367 	{-KPi/4,0.7071067811865474}, | 
|         |    368 	{KPi/6,0.8660254037844387}, | 
|         |    369 	{5*KPi/6,-0.8660254037844387}, | 
|         |    370 	{KPi/3,0.5}, | 
|         |    371 	{4*KPi/3,-0.5}, | 
|         |    372 	{120*KDegToRad,-0.5}, | 
|         |    373 	{300*KDegToRad,0.5}, | 
|         |    374 	{KPi+1.0E-15,-1.0}, | 
|         |    375 	{2*(KPi+1.0E-15),1.0} | 
|         |    376 	}; | 
|         |    377  | 
|         |    378 typedef struct | 
|         |    379     { | 
|         |    380     TReal angle; // angle for which the tangent is to be found | 
|         |    381     TReal result; // result | 
|         |    382     } TAN; | 
|         |    383  | 
|         |    384 LOCAL_D TAN testtan[]= | 
|         |    385     { | 
|         |    386 	{KPi/4,1.0}, | 
|         |    387 	{-KPi/4,-1.0}, | 
|         |    388 	{45*KDegToRad,1.0}, | 
|         |    389 	{KPi/3,1.732050807568877},					// Added by AnnW - Calculated on S3a | 
|         |    390 	{2*KPi/3,-1.732050807568878},				// | 
|         |    391 	{KPi/6,0.5773502691896257},					// | 
|         |    392 	{-KPi/6,-0.5773502691896257},				// | 
|         |    393 	{89*KDegToRad,57.28996163075913},			// these two should be the same! | 
|         |    394 	{91*KDegToRad,-57.28996163075955},			// | 
|         |    395     {4E-123,4E-123},								 | 
|         |    396     {-4E-123,-4E-123},	 | 
|         |    397     }; | 
|         |    398      | 
|         |    399 typedef struct | 
|         |    400     { | 
|         |    401     TReal num; // input number | 
|         |    402     TReal res; // expected result | 
|         |    403     } TESTASC; | 
|         |    404  | 
|         |    405 LOCAL_D TESTASC testas[]= | 
|         |    406     { | 
|         |    407     {.75,.848062078981}, | 
|         |    408     {.82,.961411018764}, | 
|         |    409     {.87,1.055202320549}, | 
|         |    410     {.89,1.097345169523}, | 
|         |    411     {.90,1.119769514999}, | 
|         |    412     {.92,1.168080485214}, | 
|         |    413     {.94,1.222630305522}, | 
|         |    414     {.96,1.287002217587}, | 
|         |    415     {.99,1.429256853470}, | 
|         |    416     {1.0,1.570796326795}, | 
|         |    417 	{0.0,0}, | 
|         |    418 	{-1.0, -90.0*KDegToRad}, | 
|         |    419 	{0.5,30.0*KDegToRad} | 
|         |    420     }; | 
|         |    421  | 
|         |    422 typedef struct | 
|         |    423     { | 
|         |    424     TReal num1; // Divisor | 
|         |    425     TReal num2; // Divand | 
|         |    426     TReal res; // expected result | 
|         |    427     } TESTATAN2; | 
|         |    428  | 
|         |    429 LOCAL_D TESTATAN2 testat2[]= | 
|         |    430     { | 
|         |    431     {5E-49,7E306,0.0}, // underflow, zero returned | 
|         |    432     {5E49,7E-306,KPiBy2}, // overflow, pi/2 returned | 
|         |    433     {0.45,0.5,0.732815101787}, | 
|         |    434     {0.12,0.3,0.380506377112}, | 
|         |    435     {0.3,0.0,KPiBy2}, // overflow, pi/2 returned | 
|         |    436     {-0.3,0.0,-KPiBy2}, // overflow, -pi/2 returned | 
|         |    437     {0.0,0.3,0.0}, | 
|         |    438     }; | 
|         |    439 #pragma warning ( default : 4204 ) | 
|         |    440  | 
|         |    441 typedef struct | 
|         |    442     { | 
|         |    443     TReal num; // input number | 
|         |    444     TReal res; // expected result | 
|         |    445     } INT_TEST; | 
|         |    446  | 
|         |    447 LOCAL_D INT_TEST testint1[]= | 
|         |    448     { | 
|         |    449     {1.0,1.0}, | 
|         |    450     {1.47934,1.0}, | 
|         |    451     {-72.86345,-72.0}, | 
|         |    452     {-734.9999,-734.0}, | 
|         |    453     {4855.9974,4855.0}, | 
|         |    454     {232478.35,232478.0}, | 
|         |    455     {0.029345,0.0}, | 
|         |    456     {0.9437,0.0}, | 
|         |    457     {-0.2634,0.0}, | 
|         |    458     {-0.98976,0.0}, | 
|         |    459     {32769.36946,32769.0}, | 
|         |    460     {-32774.997937,-32774.0}, | 
|         |    461     {8738465.38749,8738465.0}, | 
|         |    462     {-2348645.34965,-2348645.0}, | 
|         |    463     {2147483655.7565,2147483655.0}, | 
|         |    464     {-2147483657.89453,-2147483657.0}, | 
|         |    465     {2374843546.34E2,2374843546.34E2}, | 
|         |    466     {34780656.37643E12,34780656.37643E12}, | 
|         |    467     {-2374843546.34E2,-2374843546.34E2}, | 
|         |    468     {-34780656.37643E12,-34780656.37643E12}, | 
|         |    469     {468650.3874E47,468650.3874E47}, | 
|         |    470     {-4965.5987636E34,-4965.5987636E34}, | 
|         |    471     }; | 
|         |    472  | 
|         |    473 typedef struct | 
|         |    474     { | 
|         |    475     TReal num; // input number | 
|         |    476     TInt16 res; // expected result | 
|         |    477     } INTI_TEST; | 
|         |    478  | 
|         |    479 LOCAL_D INTI_TEST testint2[]= | 
|         |    480     { | 
|         |    481     {1.0,1}, | 
|         |    482     {1.47934,1}, | 
|         |    483     {-72.86345,-72}, | 
|         |    484     {-734.9999,-734}, | 
|         |    485     {4855.9974,4855}, | 
|         |    486     {0.029345,0}, | 
|         |    487     {0.9437,0}, | 
|         |    488     {-0.2634,0}, | 
|         |    489     {-0.98976,0}, | 
|         |    490     {3234.56,3234}, | 
|         |    491     {4698.435,4698}, | 
|         |    492     {-32767.47658,-32767}, | 
|         |    493     {32767.9830857,32767}, | 
|         |    494     {-32768.47658,-32767-1} | 
|         |    495     }; | 
|         |    496  | 
|         |    497 typedef struct | 
|         |    498     { | 
|         |    499     TReal num; // input number | 
|         |    500     TInt32 res; // expected result | 
|         |    501     } INTL_TEST; | 
|         |    502  | 
|         |    503 LOCAL_D INTL_TEST testint3[]= | 
|         |    504     { | 
|         |    505     {1.0,1l}, | 
|         |    506     {1.47934,1l}, | 
|         |    507     {-72.86345,-72l}, | 
|         |    508     {-734.9999,-734l}, | 
|         |    509     {4855.9974,4855l}, | 
|         |    510     {0.029345,0l}, | 
|         |    511     {0.9437,0l}, | 
|         |    512     {-0.2634,0l}, | 
|         |    513     {-0.98976,0l}, | 
|         |    514     {3234.56,3234l}, | 
|         |    515     {4698.435,4698l}, | 
|         |    516     {-32767.47658,-32767l}, | 
|         |    517     {32767.9830857,32767l}, | 
|         |    518     {32769.36946,32769l}, | 
|         |    519     {-32774.997937,-32774l}, | 
|         |    520     {64835903.74605,64835903l}, | 
|         |    521     {-46652024.393,-46652024l}, | 
|         |    522     {2147483647.34576,2147483647l}, | 
|         |    523     {-2147483647.9501,-2147483647l}, | 
|         |    524     {-2147483648.00,0x80000000l},  | 
|         |    525     {-2147483648.6843,0x80000000l} | 
|         |    526     }; | 
|         |    527  | 
|         |    528 typedef struct | 
|         |    529     { | 
|         |    530     TReal num; // input number | 
|         |    531     TReal res; // expected result | 
|         |    532     } FRAC_TEST; | 
|         |    533  | 
|         |    534 LOCAL_D FRAC_TEST testfrac[]= | 
|         |    535     { | 
|         |    536 	{0.0,0.0}, | 
|         |    537 	{KNegZeroTReal64,0.0}, | 
|         |    538     {1.0,0.0}, | 
|         |    539     {1.47934,.47934}, | 
|         |    540     {-72.86345,-.86345}, | 
|         |    541     {-734.9999,-.9999}, | 
|         |    542     {4855.9974,.9974}, | 
|         |    543     {232478.35,.35}, | 
|         |    544     {0.029345,.029345}, | 
|         |    545     {0.9437,0.9437}, | 
|         |    546     {-0.2634,-.2634}, | 
|         |    547     {-0.98976,-.98976}, | 
|         |    548     {32769.36946,.36946}, | 
|         |    549     {-32774.997937,-0.997937}, | 
|         |    550     {8738465.38749,0.38749}, | 
|         |    551     {-2348645.34965,-0.34965}, | 
|         |    552     {2147483655.7565,0.7565}, | 
|         |    553     {-2147483657.89453,-.89453}, | 
|         |    554     {2374843546.34E2,0.0}, | 
|         |    555     {34780656.37643E12,0.0}, | 
|         |    556     {-2374843546.34E2,0.0}, | 
|         |    557     {-34780656.37643E12,0.0}, | 
|         |    558     {468650.3874E47,0.0}, | 
|         |    559     {-4965.5987636E34,0.0} | 
|         |    560     }; | 
|         |    561  | 
|         |    562 typedef struct | 
|         |    563     { | 
|         |    564     TReal num; // input number | 
|         |    565     TReal mod; // modulo | 
|         |    566     TReal res; // expected result | 
|         |    567     } MOD_TEST; | 
|         |    568  | 
|         |    569 LOCAL_D MOD_TEST testmod[]= | 
|         |    570     { | 
|         |    571     {4.0,2.0,0.0}, | 
|         |    572     {3.0,2.0,1.0}, | 
|         |    573     {56.847,2.3,1.647}, | 
|         |    574     {-65.6478,.65,-.6478}, | 
|         |    575     {-6858.78432,-87.5323,-31.26492}, | 
|         |    576     {7665.140215,-34.98,4.520215}, | 
|         |    577     {.4645,1.0,0.4645}, | 
|         |    578     {-.246,1.0,-.246}, | 
|         |    579 	{1.0,KPosInfTReal64,1.0}, | 
|         |    580 	{1.0,KNegInfTReal64,1.0}, | 
|         |    581 	{1.0E17,8.0,0.0}, | 
|         |    582 	// | 
|         |    583 	{1.0,3.0,1.0},				//0 | 
|         |    584 	{2.0,3.0,2.0}, | 
|         |    585 	{4.0,3.0,1.0}, | 
|         |    586 	{8.0,3.0,2.0}, | 
|         |    587 	{16.0,3.0,1.0}, | 
|         |    588 	{32.0,3.0,2.0}, | 
|         |    589 	{64.0,3.0,1.0}, | 
|         |    590 	{128.0,3.0,2.0}, | 
|         |    591 	{256.0,3.0,1.0}, | 
|         |    592 	{512.0,3.0,2.0}, | 
|         |    593 	{1024.0,3.0,1.0},			//10 | 
|         |    594 	{2048.0,3.0,2.0}, | 
|         |    595 	{4096.0,3.0,1.0}, | 
|         |    596 	{8192.0,3.0,2.0}, | 
|         |    597 	{16384.0,3.0,1.0}, | 
|         |    598 	{32768.0,3.0,2.0}, | 
|         |    599 	{65536.0,3.0,1.0}, | 
|         |    600 	{131072.0,3.0,2.0}, | 
|         |    601 	{262144.0,3.0,1.0}, | 
|         |    602 	{524288.0,3.0,2.0}, | 
|         |    603 	{1048576.0,3.0,1.0},		//20 | 
|         |    604 	{2097152.0,3.0,2.0}, | 
|         |    605 	{4194304.0,3.0,1.0}, | 
|         |    606 	{8388608.0,3.0,2.0}, | 
|         |    607 	{16777216.0,3.0,1.0}, | 
|         |    608 	{33554432.0,3.0,2.0}, | 
|         |    609 	{67108864.0,3.0,1.0}, | 
|         |    610 	{134217728.0,3.0,2.0}, | 
|         |    611 	{268435456.0,3.0,1.0}, | 
|         |    612 	{536870912.0,3.0,2.0}, | 
|         |    613 	{1073741824.0,3.0,1.0},		//30 | 
|         |    614 	{2147483648.0,3.0,2.0}, | 
|         |    615 	{4294967296.0,3.0,1.0}, | 
|         |    616 	{8589934592.0,3.0,2.0}, | 
|         |    617 	{17179869184.0,3.0,1.0}, | 
|         |    618 	{34359738368.0,3.0,2.0}, | 
|         |    619 	{68719476736.0,3.0,1.0}, | 
|         |    620 	{137438953472.0,3.0,2.0}, | 
|         |    621 	{274877906944.0,3.0,1.0}, | 
|         |    622 	{549755813888.0,3.0,2.0}, | 
|         |    623 	{1099511627776.0,3.0,1.0},	//40 | 
|         |    624 	{2199023255552.0,3.0,2.0}, | 
|         |    625 	{4398046511104.0,3.0,1.0}, | 
|         |    626 	{8796093022208.0,3.0,2.0}, | 
|         |    627 	{17592186044416.0,3.0,1.0}, | 
|         |    628 	{35184372088832.0,3.0,2.0}, | 
|         |    629 	{70368744177664.0,3.0,1.0}, | 
|         |    630 	{140737488355328.0,3.0,2.0}, | 
|         |    631 	{281474976710656.0,3.0,1.0}, | 
|         |    632 	{562949953421312.0,3.0,2.0}, | 
|         |    633 	{1125899906842624.0,3.0,1.0},	//50 | 
|         |    634 	{2251799813685248.0,3.0,2.0}, | 
|         |    635 	{4503599627370496.0,3.0,1.0}, | 
|         |    636 	{9007199254740992.0,3.0,2.0}, | 
|         |    637 	{18014398509481984.0,3.0,1.0}, | 
|         |    638 	{6.626176E-34,299792458.0,6.626176E-34}, | 
|         |    639 	{-1.6022E-19,6.022045E23,-1.6022E-19}, | 
|         |    640 	{0.0,2.71828182845904524,0.0} | 
|         |    641     }; | 
|         |    642  | 
|         |    643 // expected result is unused in following - will be zero in all cases | 
|         |    644 LOCAL_D MOD_TEST testmod2[]= | 
|         |    645     { | 
|         |    646 	{1.0E17,7.9,0.0}, | 
|         |    647 	{1.0E100,4.0,0.0}, | 
|         |    648 	{KMaxTReal64,5.0,0.0}, | 
|         |    649 	{-KMaxTReal64,5.0,0.0}, | 
|         |    650 	{0.125,1.0E-17,0.0}, | 
|         |    651 	{36028797019963968.0,2.0,0.0},   // 2**55,2**1 | 
|         |    652 	// | 
|         |    653 	{36028797019963968.0,3.0,0.0},	//55 | 
|         |    654 	{72057594039927936.0,3.0,0.0}, | 
|         |    655 	{144115188079855872.0,3.0,0.0}, | 
|         |    656 	{288230376159711744.0,3.0,0.0}, | 
|         |    657 	}; | 
|         |    658  | 
|         |    659 TInt testApprox(TReal aFound,TReal aExpect,TReal aTol) | 
|         |    660 // | 
|         |    661 // Tests relative error, i.e. whether (aFound-aExpect)/aFound <= aTol | 
|         |    662 // | 
|         |    663 	{ | 
|         |    664  | 
|         |    665 	TRealX diff,check,l,r,t; | 
|         |    666 	l.Set(aFound); | 
|         |    667 	r.Set(aExpect); | 
|         |    668 	t.Set(aTol); | 
|         |    669 	if (l.Mult(check,t)==KErrUnderflow) | 
|         |    670 		{ | 
|         |    671 		l*=TRealX(1.0E20); | 
|         |    672 		r*=TRealX(1.0E20); | 
|         |    673 		} | 
|         |    674 	diff=l-r; | 
|         |    675 	if (diff.IsZero()) | 
|         |    676 		return ETrue; | 
|         |    677 	if (!l.IsZero()) | 
|         |    678 		diff.DivEq(l); | 
|         |    679 	if (Abs(TReal(diff))<=aTol) | 
|         |    680 		return ETrue; | 
|         |    681 	return EFalse; | 
|         |    682 	} | 
|         |    683  | 
|         |    684 LOCAL_C void randrng(TReal& pret,TReal& llim,TReal& ulim) | 
|         |    685 /* | 
|         |    686 Returns a random number in the range [llim,ulim] | 
|         |    687 */ | 
|         |    688     { | 
|         |    689  | 
|         |    690     pret=Math::FRand(rseed); | 
|         |    691     pret*=ulim-llim; | 
|         |    692     pret+=llim; | 
|         |    693     } | 
|         |    694  | 
|         |    695 LOCAL_C TReal taylor(TReal x,TInt k) | 
|         |    696 /* | 
|         |    697 Evaluate the Taylor series approximation to arc sine up to terms of order k | 
|         |    698 */ | 
|         |    699     //TReal x; // argument | 
|         |    700     //TInt k; // Highest order term | 
|         |    701     { | 
|         |    702  | 
|         |    703     TInt i,j; | 
|         |    704     TReal den,num,res,term,di; | 
|         |    705  | 
|         |    706     den=1; | 
|         |    707     num=1; | 
|         |    708     term=0; | 
|         |    709     for (i=1;i<=k;i+=2) | 
|         |    710 		{ | 
|         |    711 		for (j=2;j<i;j+=2) | 
|         |    712 			{ | 
|         |    713 			num*=j; | 
|         |    714 			if (j<(i-1)) | 
|         |    715 			den*=j+1; | 
|         |    716 			} | 
|         |    717 		di=(TReal)i; | 
|         |    718 		Math::Pow(res,x,di); | 
|         |    719 		term+=(res*den)/(i*num); | 
|         |    720 		num=1; | 
|         |    721 		den=1; | 
|         |    722 		} | 
|         |    723     return(term); | 
|         |    724     } | 
|         |    725  | 
|         |    726 LOCAL_C TReal tayatan(TReal val) | 
|         |    727 /*  | 
|         |    728 Finds the taylor series approximation to the arc tangent function  | 
|         |    729 */ | 
|         |    730     //TReal val; | 
|         |    731     { | 
|         |    732  | 
|         |    733     TInt i; | 
|         |    734     TReal sgn,s,d,di,term,res; | 
|         |    735      | 
|         |    736     term=0.0; | 
|         |    737     s=(-1.0); | 
|         |    738     for (i=0;i<8;i++) | 
|         |    739 		{ | 
|         |    740 		di=(TReal)i; | 
|         |    741 		d=2.0*di; | 
|         |    742 		Math::Pow(sgn,s,di); | 
|         |    743 		Math::Pow(res,val,d); | 
|         |    744 		term+=(sgn*res)/(2.0*di+1.0); | 
|         |    745 		} | 
|         |    746     return(val*term); | 
|         |    747     } | 
|         |    748  | 
|         |    749 LOCAL_C void AssortedTests() | 
|         |    750 // | 
|         |    751 // Tests the methods with just a handful of values each  | 
|         |    752 // All tests as accurate as possible - if exact answer given, tests for equality | 
|         |    753 // | 
|         |    754 	{ | 
|         |    755  | 
|         |    756 	TReal trg,src; | 
|         |    757  | 
|         |    758 	// ASin | 
|         |    759 	test.Start(_L("Math::ASin()")); | 
|         |    760 	test(Math::ASin(trg,0.0)==KErrNone); | 
|         |    761 	test(trg==0.0); | 
|         |    762  | 
|         |    763 	test(Math::ASin(trg,1.0)==KErrNone); | 
|         |    764 	test(testApprox(trg,1.5707963267949,5.0E-15)); | 
|         |    765  | 
|         |    766 	// ACos | 
|         |    767 	test.Next(_L("Math::ACos()")); | 
|         |    768 	test(Math::ACos(trg,0)==KErrNone); | 
|         |    769 	test(testApprox(trg,1.5707963267949,5.0E-15)); | 
|         |    770  | 
|         |    771 	test(Math::ACos(trg,1.0)==KErrNone); | 
|         |    772 	test(trg==0.0); | 
|         |    773  | 
|         |    774 	// ATan | 
|         |    775 	test.Next(_L("Math::ATan()")); | 
|         |    776 	test(Math::ATan(trg,0.0)==KErrNone); | 
|         |    777 	test(trg==0.0); | 
|         |    778  | 
|         |    779 	test(Math::ATan(trg,1.0)==KErrNone); | 
|         |    780 	test(testApprox(trg,0.78539816339745,5.0E-15));	 | 
|         |    781  | 
|         |    782 	test(Math::Tan(trg,KPi/4)==KErrNone); | 
|         |    783 	test(testApprox(trg,1.0,1.0E-15)); | 
|         |    784 	test(Math::ATan(trg,trg)==KErrNone); | 
|         |    785 	test(testApprox(trg,KPi/4,1e-15)); | 
|         |    786  | 
|         |    787 	// Sqrt | 
|         |    788 	test.Next(_L("Math::Sqrt()")); | 
|         |    789 	test(Math::Sqrt(trg,0.0)==KErrNone); | 
|         |    790 	test(trg==0.0); | 
|         |    791 	 | 
|         |    792 	test(Math::Sqrt(trg,-1.0)==KErrArgument); | 
|         |    793  | 
|         |    794 	test(Math::Sqrt(trg,100.0)==KErrNone); | 
|         |    795 	test(testApprox(trg,10.0,1.0E-15));	 | 
|         |    796  | 
|         |    797 	test(Math::Sqrt(trg,56.25)==KErrNone); | 
|         |    798 	test(trg==7.5); | 
|         |    799  | 
|         |    800 	// Pow10 | 
|         |    801 	test.Next(_L("Math::Pow10()")); | 
|         |    802 	test(Math::Pow10(trg,-2)==KErrNone); | 
|         |    803 	test(trg==0.01);	 | 
|         |    804  | 
|         |    805 	test(Math::Pow10(trg,-1)==KErrNone); | 
|         |    806 	test(trg==0.1); | 
|         |    807  | 
|         |    808 	test(Math::Pow10(trg,0)==KErrNone); | 
|         |    809 	test(trg==1.0); | 
|         |    810  | 
|         |    811 	test(Math::Pow10(trg,1)==KErrNone); | 
|         |    812 	test(trg==10.0); | 
|         |    813  | 
|         |    814 	test(Math::Pow10(trg,2)==KErrNone); | 
|         |    815 	test(trg==100.0); | 
|         |    816  | 
|         |    817 	// Ln | 
|         |    818 	test.Next(_L("Math::Ln()")); | 
|         |    819 	test(Math::Ln(trg,0.0)==KErrOverflow); | 
|         |    820 	 | 
|         |    821 	test(Math::Ln(trg,1.0)==KErrNone); | 
|         |    822 	test(trg==0.0); | 
|         |    823  | 
|         |    824 	test(Math::Ln(trg,2)==KErrNone); | 
|         |    825 	test(testApprox(trg,0.69314718055995,1.0E-14));	 | 
|         |    826  | 
|         |    827 	// Log | 
|         |    828 	test.Next(_L("Math::Log()")); | 
|         |    829 	test(Math::Log(trg,0)==KErrOverflow); | 
|         |    830  | 
|         |    831 	test(Math::Log(trg,1)==KErrNone); | 
|         |    832 	test(trg==0); | 
|         |    833  | 
|         |    834 	test(Math::Log(trg,10)==KErrNone); | 
|         |    835 	test(trg==1); | 
|         |    836  | 
|         |    837 	test(Math::Log(trg,100000)==KErrNone); | 
|         |    838 	test(trg==5); | 
|         |    839  | 
|         |    840 	// Sin | 
|         |    841 	test.Next(_L("Math::Sin()")); | 
|         |    842 	test(Math::Sin(trg,0)==KErrNone); | 
|         |    843 	test(trg==0);    | 
|         |    844  | 
|         |    845 	test(Math::Sin(trg,1)==KErrNone); | 
|         |    846 	test(testApprox(trg,0.84147098480790,5.0E-15));	 | 
|         |    847  | 
|         |    848 	test(Math::Sin(trg,KPi)==KErrNone); | 
|         |    849 //    test(trg==0.0); | 
|         |    850 	test(Abs(trg)<1e-15); | 
|         |    851  | 
|         |    852 	test(Math::Sin(trg,KPiBy2)==KErrNone); | 
|         |    853 	test(testApprox(trg,1.0,1.0E-15)); | 
|         |    854  | 
|         |    855 	test(Math::Sin(trg,10.0*KPi)==KErrNone); | 
|         |    856 //   test(trg==0.0); | 
|         |    857 	test(Abs(trg)<2e-15); | 
|         |    858  | 
|         |    859 	test(Math::Sin(trg,3)==KErrNone); | 
|         |    860 	test(trg==0.1411200080598672); | 
|         |    861  | 
|         |    862 	test(Math::Sin(trg,4)==KErrNone); | 
|         |    863 	test(trg==-0.7568024953079282); | 
|         |    864  | 
|         |    865 	test(Math::Sin(trg,3.1415)==KErrNone); | 
|         |    866 	test(testApprox(trg,9.26535896605E-5,2.0E-13));	 | 
|         |    867  | 
|         |    868 	test(Math::Sin(trg,3.1416)==KErrNone); | 
|         |    869 	test(testApprox(trg,-7.3464102066435914E-6,1.0E-11));	 | 
|         |    870  | 
|         |    871 	test(Math::Sin(trg,(10.0*KPi)+0.001)==KErrNone); | 
|         |    872 	test(testApprox(trg,0.000999999833333,4.0E-13));	 | 
|         |    873  | 
|         |    874 	// Cos | 
|         |    875 	test.Next(_L("Math::Cos()")); | 
|         |    876 	test(Math::Cos(trg,0.0)==KErrNone); | 
|         |    877 	test(testApprox(trg,1.0,1.0E-15));		 | 
|         |    878  | 
|         |    879 	test(Math::Cos(trg,1)==KErrNone); | 
|         |    880 	test(testApprox(trg,0.54030230586814,1.0E-15));		 | 
|         |    881  | 
|         |    882     test(Math::Cos(trg,KPiBy2)==KErrNone); | 
|         |    883 //    test(trg==0.0); | 
|         |    884 	test(Abs(trg)<1e-15); | 
|         |    885  | 
|         |    886 	test(Math::Cos(trg,KPi)==KErrNone); | 
|         |    887 	test(trg==-1.0); | 
|         |    888  | 
|         |    889     test(Math::Cos(trg,KPiBy2+KPi)==KErrNone); | 
|         |    890 //    test(trg==0.0); | 
|         |    891 	test(Abs(trg)<1e-15); | 
|         |    892 	 | 
|         |    893 	test(Math::Cos(trg,89.99999*KDegToRad)==KErrNone); | 
|         |    894 	test(testApprox(trg,1.745329252E-07,5.0E-10));		 | 
|         |    895  | 
|         |    896 	test(Math::Cos(trg,90.00001*KDegToRad)==KErrNone); | 
|         |    897 	test(testApprox(trg,-1.7453292516217e-007,5.0E-10));			 | 
|         |    898  | 
|         |    899 	// Tan | 
|         |    900 	test.Next(_L("Math::Tan()")); | 
|         |    901 	test(Math::Tan(trg,0.0)==KErrNone); | 
|         |    902     test(trg==0.0);    | 
|         |    903  | 
|         |    904 	test(Math::Tan(trg,1)==KErrNone); | 
|         |    905 	test(testApprox(trg,1.5574077246549,2.0E-15));			 | 
|         |    906  | 
|         |    907 	// Pow | 
|         |    908 	test.Next(_L("Math::Pow()")); | 
|         |    909 	src=10; | 
|         |    910 	test(Math::Pow(trg,src,-1.0)==KErrNone); | 
|         |    911 	test(testApprox(trg,0.1,1.0E-15));			 | 
|         |    912  | 
|         |    913 	test(Math::Pow(trg,src,0.0)==KErrNone); | 
|         |    914 	test(trg==1.0); | 
|         |    915  | 
|         |    916 	test(Math::Pow(trg,src,2.0)==KErrNone); | 
|         |    917 	test(testApprox(trg,100.0,1.0E-15));			 | 
|         |    918  | 
|         |    919 	src=1.0; | 
|         |    920 	test(Math::Pow(trg,src,10000000000000000.0)==KErrNone); | 
|         |    921 	test(trg==1.0); | 
|         |    922  | 
|         |    923 	test.End(); | 
|         |    924 	}        | 
|         |    925  | 
|         |    926 LOCAL_C void sqrtest1(TReal low,TReal upp) | 
|         |    927 /* | 
|         |    928 Test the identity sqrt(x*x)=x  on the range low<=x<upp | 
|         |    929 */ | 
|         |    930     { | 
|         |    931      | 
|         |    932 	TReal x,y,res; | 
|         |    933  | 
|         |    934     for (TInt j=0;j<100;j++) | 
|         |    935 		{ | 
|         |    936 		randrng(x,low,upp); | 
|         |    937 		y=x*x; | 
|         |    938 		test(Math::Sqrt(res,y)==KErrNone); | 
|         |    939 		test(testApprox(res,x,1.0E-15)); | 
|         |    940 		} | 
|         |    941     } | 
|         |    942  | 
|         |    943 LOCAL_C void sqrtest2() | 
|         |    944 /* | 
|         |    945 Tests specific numbers | 
|         |    946 */ | 
|         |    947     { | 
|         |    948      | 
|         |    949 	TReal root; | 
|         |    950  | 
|         |    951 	// test errors | 
|         |    952 	test(Math::Sqrt(root,KNaNTReal64)==KErrArgument); | 
|         |    953 	test(Math::IsNaN(root)); | 
|         |    954 	test(Math::Sqrt(root,-1)==KErrArgument); | 
|         |    955 	test(Math::IsNaN(root)); | 
|         |    956 	test(Math::Sqrt(root,KNegInfTReal64)==KErrArgument); | 
|         |    957 	test(Math::IsNaN(root)); | 
|         |    958 	test(Math::Sqrt(root,KPosInfTReal64)==KErrOverflow); | 
|         |    959 	test(root==KPosInfTReal64); | 
|         |    960  | 
|         |    961     TInt i=sizeof(testsqrt)/sizeof(SQRT_TEST); | 
|         |    962     for (TInt j=0;j<i;j++)  | 
|         |    963 		{ | 
|         |    964 		test(Math::Sqrt(root,testsqrt[j].num)==KErrNone); | 
|         |    965 		test(testApprox(root,testsqrt[j].res,1.0E-15)); | 
|         |    966 		} | 
|         |    967  | 
|         |    968 	// a couple of denormal tests | 
|         |    969 	test(Math::Sqrt(root,4E-322)==KErrNone); | 
|         |    970 	test(testApprox(root,2E-161,1.0E-3)); | 
|         |    971 	test(Math::Sqrt(root,1.6E-309)==KErrNone); | 
|         |    972 	test(testApprox(root,4E-155,1.0E-15));	 | 
|         |    973     } | 
|         |    974  | 
|         |    975 LOCAL_C void logtest() | 
|         |    976 /* | 
|         |    977 Test numbers in the range sqrt(.1) to .9, using the identity  | 
|         |    978 log(x)=log(11x/10)-log(1.1)  | 
|         |    979 */ | 
|         |    980     { | 
|         |    981  | 
|         |    982     TReal res,x; | 
|         |    983     TReal cnstlog,cnstlogx; | 
|         |    984  | 
|         |    985     TReal low=.316227766017; | 
|         |    986     TReal upp=0.9; | 
|         |    987     TReal cnst=11.0/10.0; | 
|         |    988     test(Math::Log(cnstlog,cnst)==KErrNone); | 
|         |    989     for (TInt j=0;j<10;j++) | 
|         |    990 		{ | 
|         |    991 		randrng(x,low,upp); | 
|         |    992 		test(Math::Log(res,x)==KErrNone);  | 
|         |    993 		TReal num=cnst*x; | 
|         |    994 		test(Math::Log(cnstlogx,num)==KErrNone); | 
|         |    995 		test(testApprox(res,(cnstlogx-cnstlog),1.0E-15)); | 
|         |    996 		} | 
|         |    997     } | 
|         |    998  | 
|         |    999 LOCAL_C void lntest1() | 
|         |   1000 /*  | 
|         |   1001 Test selected numbers  | 
|         |   1002 */ | 
|         |   1003     { | 
|         |   1004   | 
|         |   1005     TReal res; | 
|         |   1006  | 
|         |   1007 	// test errors | 
|         |   1008 //	test(Math::Ln(res,KNegZeroTReal64)==KErrArgument); | 
|         |   1009 	test(Math::Ln(res,KNegZeroTReal64)==KErrOverflow); | 
|         |   1010 	test(Math::IsInfinite(res)); | 
|         |   1011 	test(Math::Ln(res,-34)==KErrArgument); | 
|         |   1012 	test(Math::IsNaN(res)); | 
|         |   1013 	test(Math::Ln(res,KNaNTReal64)==KErrArgument); | 
|         |   1014 	test(Math::IsNaN(res)); | 
|         |   1015 	test(Math::Ln(res,KNegInfTReal64)==KErrArgument); | 
|         |   1016 	test(Math::IsNaN(res)); | 
|         |   1017 	test(Math::Ln(res,KPosInfTReal64)==KErrOverflow); | 
|         |   1018 	test(res==KPosInfTReal64); | 
|         |   1019 	test(Math::Ln(res,0.0)==KErrOverflow); | 
|         |   1020 	test(res==KNegInfTReal64); | 
|         |   1021 	test(Math::Ln(res,2.71828182845904524)==KErrNone); | 
|         |   1022 	test(testApprox(res,1.0,1e-15)); | 
|         |   1023 	test(Math::Ln(res,7.389056098930650227)==KErrNone); | 
|         |   1024 	test(testApprox(res,2.0,1e-15)); | 
|         |   1025  | 
|         |   1026     TInt i=sizeof(testln)/sizeof(TESTLN); | 
|         |   1027     for (TInt j=0;j<i;j++)  | 
|         |   1028 		{ | 
|         |   1029 		test(Math::Ln(res,testln[j].num)==KErrNone); | 
|         |   1030 		test(testApprox(res,testln[j].res,1.0E-14)); | 
|         |   1031 		} | 
|         |   1032  | 
|         |   1033 	// test some denormals | 
|         |   1034  	test(Math::Log(res,K1EMinus322Real64)==KErrNone); | 
|         |   1035 	test(testApprox(res,-322.0,2.0E-5)); | 
|         |   1036  	test(Math::Log(res,K1EMinus313Real64)==KErrNone); | 
|         |   1037 	test(testApprox(res,-313.0,1.0E-13));	 | 
|         |   1038     } | 
|         |   1039  | 
|         |   1040 LOCAL_C void lntest2() | 
|         |   1041 /*  | 
|         |   1042 Test numbers near to one against the Taylor series approximation  | 
|         |   1043 */ | 
|         |   1044     { | 
|         |   1045      | 
|         |   1046 	TReal x,res; | 
|         |   1047      | 
|         |   1048     TReal low=.999999989463; | 
|         |   1049     TReal upp=1.00000001054; | 
|         |   1050     for (TInt k=0;k<10;k++) | 
|         |   1051 		{ | 
|         |   1052 		randrng(x,low,upp); | 
|         |   1053 		TRealX tot=0.0; | 
|         |   1054 		TRealX xx(x-1); | 
|         |   1055 		TInt sign=-1; | 
|         |   1056 		for (TInt i=4;i>0;i--) | 
|         |   1057 			{ | 
|         |   1058 			tot+=TRealX(sign)/TRealX(i); | 
|         |   1059 			tot*=xx; | 
|         |   1060 			sign=-sign; | 
|         |   1061 			} | 
|         |   1062 		TReal tot2=(TReal)tot; | 
|         |   1063 		test(Math::Ln(res,x)==KErrNone); | 
|         |   1064 		test(testApprox(res,tot2,1.0E-15)); | 
|         |   1065 		} | 
|         |   1066     } | 
|         |   1067  | 
|         |   1068 LOCAL_C void lntest3() | 
|         |   1069 /*  | 
|         |   1070 Test numbers in the range sqrt(.5) to 15/16, using the identity  | 
|         |   1071 ln(x)=ln(17x/16)-ln(17/16)  | 
|         |   1072 */ | 
|         |   1073     { | 
|         |   1074  | 
|         |   1075     TReal x,cnstln,cnstlnx,res; | 
|         |   1076  | 
|         |   1077 	TReal low=KSqhf; | 
|         |   1078     TReal upp=15.0/16.0; | 
|         |   1079     TReal cnst=17.0/16.0; | 
|         |   1080     test(Math::Ln(cnstln,cnst)==KErrNone); | 
|         |   1081 	for (TInt j=0;j<10;j++) | 
|         |   1082 		{ | 
|         |   1083 		randrng(x,low,upp); | 
|         |   1084 		test(Math::Ln(res,x)==KErrNone); | 
|         |   1085 		TReal num=cnst*x; | 
|         |   1086 		test(Math::Ln(cnstlnx,num)==KErrNone); | 
|         |   1087 		test(testApprox(res,(cnstlnx-cnstln),1.0E-15)); | 
|         |   1088 		} | 
|         |   1089     } | 
|         |   1090  | 
|         |   1091 LOCAL_C void lntest4() | 
|         |   1092 /*  | 
|         |   1093 Test numbers in the range 16 to 240 using the identity ln(x*x)=2ln(x)  | 
|         |   1094 */ | 
|         |   1095     { | 
|         |   1096  | 
|         |   1097     TReal cnstlnx,res; | 
|         |   1098  | 
|         |   1099     TReal low=16.0; | 
|         |   1100     TReal upp=240.0; | 
|         |   1101     TReal x=16.0; | 
|         |   1102 	test(Math::Ln(res,-1)==KErrArgument); | 
|         |   1103     for (TInt j=0;j<10;j++) | 
|         |   1104 		{ | 
|         |   1105 		randrng(x,low,upp); | 
|         |   1106 		TReal num=x*x; | 
|         |   1107 		test(Math::Ln(res,num)==KErrNone); | 
|         |   1108 		test(Math::Ln(cnstlnx,x)==KErrNone); | 
|         |   1109 		test(testApprox(res,2*cnstlnx,1.0E-15)); | 
|         |   1110 		} | 
|         |   1111     } | 
|         |   1112  | 
|         |   1113 LOCAL_C void exptest1() | 
|         |   1114 /*  | 
|         |   1115 To test exponent for specific values  | 
|         |   1116 */ | 
|         |   1117     { | 
|         |   1118  | 
|         |   1119     TReal res; | 
|         |   1120  | 
|         |   1121 	// test errors | 
|         |   1122 	test(Math::Exp(res,KNaNTReal64)==KErrArgument); | 
|         |   1123 	test(Math::IsNaN(res)); | 
|         |   1124 	test(Math::Exp(res,KPosInfTReal64)==KErrOverflow); | 
|         |   1125 	test(res==KPosInfTReal64); | 
|         |   1126 	test(Math::Exp(res,709.8)==KErrOverflow); | 
|         |   1127 	test(res==KPosInfTReal64); | 
|         |   1128 	test(Math::Exp(res,KNegInfTReal64)==KErrUnderflow); | 
|         |   1129 	test(Math::IsZero(res)); | 
|         |   1130 	test(Math::Exp(res,-745.2)==KErrUnderflow); | 
|         |   1131 	test(Math::IsZero(res)); | 
|         |   1132  | 
|         |   1133     TInt i=sizeof(testexp)/sizeof(EXP); | 
|         |   1134     for (TInt j=0;j<i;j++) | 
|         |   1135 		{ | 
|         |   1136 		test(Math::Exp(res,testexp[j].val)==KErrNone); | 
|         |   1137 		test(testApprox(res,testexp[j].result,0));	// NB only tests values with results of 1 | 
|         |   1138 		} | 
|         |   1139  | 
|         |   1140 	// test some denormals | 
|         |   1141 	test(Math::Exp(res,5E-324)==KErrNone); | 
|         |   1142 	test(testApprox(res,1.0,0)); | 
|         |   1143 	test(Math::Exp(res,-6E-318)==KErrNone); | 
|         |   1144 	test(testApprox(res,1.0,0));	 | 
|         |   1145 	} | 
|         |   1146  | 
|         |   1147 LOCAL_C void exptest2(TReal cnst,TReal ll,TReal ul) | 
|         |   1148 /* | 
|         |   1149 Test the identity exp(x-cnst)=exp(x)*exp(-cnst) for x in the range [ul,ll] | 
|         |   1150 */ | 
|         |   1151     //TReal cnst; // constant used in the identity | 
|         |   1152     //TReal ll; // Lower limit of the range | 
|         |   1153     //TReal ul; // Upper limit of the range | 
|         |   1154     { | 
|         |   1155  | 
|         |   1156     TReal cnstexp,cnstexpx,x,res; | 
|         |   1157  | 
|         |   1158     test(Math::Exp(cnstexp,cnst)==KErrNone); | 
|         |   1159     for (TInt j=0;j<10;j++) | 
|         |   1160 		{ | 
|         |   1161 		randrng(x,ll,ul); | 
|         |   1162 		test(Math::Exp(res,x)==KErrNone); | 
|         |   1163 		TReal num=x+cnst; | 
|         |   1164 		test(Math::Exp(cnstexpx,num)==KErrNone); | 
|         |   1165 		test(testApprox(cnstexpx,(res*cnstexp),1.0E-15)); | 
|         |   1166 		} | 
|         |   1167     } | 
|         |   1168  | 
|         |   1169 LOCAL_C void exptest3() | 
|         |   1170 /*  | 
|         |   1171 Test for systematic error  | 
|         |   1172 */ | 
|         |   1173     { | 
|         |   1174      | 
|         |   1175 	TReal step,ul,v; | 
|         |   1176  | 
|         |   1177     TReal x=1.0123; | 
|         |   1178     TReal y=x/2; | 
|         |   1179     test(Math::Exp(v,y)==KErrNone); | 
|         |   1180     test(Math::Exp(step,x)==KErrNone); | 
|         |   1181     test(Math::Sqrt(ul,step)==KErrNone); | 
|         |   1182 	test(testApprox(ul,v,1.0E-15)); | 
|         |   1183     } | 
|         |   1184  | 
|         |   1185 LOCAL_C void powtest1() | 
|         |   1186 /* | 
|         |   1187 Test selected numbers | 
|         |   1188 */ | 
|         |   1189     { | 
|         |   1190      | 
|         |   1191 	TReal res; | 
|         |   1192 	 | 
|         |   1193 	// test errors | 
|         |   1194 	test(Math::Pow(res,10,-1E8)==KErrUnderflow); | 
|         |   1195 	test(res==0.0); | 
|         |   1196 	test(Math::Pow(res,10,-KMaxTReal64)==KErrUnderflow); | 
|         |   1197 	test(res==0.0); | 
|         |   1198 	test(Math::Pow(res,10,-5.5E307)==KErrUnderflow); | 
|         |   1199 	test(res==0.0); | 
|         |   1200 	test(Math::Pow(res,10,-5.4E307)==KErrUnderflow); | 
|         |   1201 	test(res==0.0); | 
|         |   1202 	test(Math::Pow(res,10,-1E300)==KErrUnderflow); | 
|         |   1203 	test(res==0.0); | 
|         |   1204 	test(Math::Pow(res,10,-1E10)==KErrUnderflow); | 
|         |   1205 	test(res==0.0); | 
|         |   1206 	 | 
|         |   1207 	test(Math::Pow(res,10,5.5E307)==KErrOverflow); | 
|         |   1208 	test(res==KPosInfTReal64); | 
|         |   1209 	test(Math::Pow(res,10,5.4E307)==KErrOverflow); | 
|         |   1210 	test(res==KPosInfTReal64); | 
|         |   1211 	test(Math::Pow(res,10,1E308)==KErrOverflow); | 
|         |   1212 	test(res==KPosInfTReal64); | 
|         |   1213 	test(Math::Pow(res,10,1.7E308)==KErrOverflow); | 
|         |   1214 	test(res==KPosInfTReal64); | 
|         |   1215 	test(Math::Pow(res,10,KMaxTReal64)==KErrOverflow); | 
|         |   1216 	test(res==KPosInfTReal64); | 
|         |   1217 	 | 
|         |   1218 	test(Math::Pow(res,1.0,KNaNTReal64)==KErrNone); | 
|         |   1219 	test(res==1.0); | 
|         |   1220 	test(Math::Pow(res,KNaNTReal64,1.0)==KErrArgument); | 
|         |   1221 	test(Math::IsNaN(res)); | 
|         |   1222 	test(Math::Pow(res,0.0,KNaNTReal64)==KErrArgument); | 
|         |   1223 	test(Math::IsNaN(res)); | 
|         |   1224 	test(Math::Pow(res,KNaNTReal64,0.0)==KErrNone); | 
|         |   1225 	test(res==1.0); | 
|         |   1226 	test(Math::Pow(res,KNaNTReal64,KNaNTReal64)==KErrArgument); | 
|         |   1227 	test(Math::IsNaN(res)); | 
|         |   1228 	test(Math::Pow(res,KPosInfTReal64,KPosInfTReal64)==KErrOverflow); | 
|         |   1229 	test(res==KPosInfTReal64); | 
|         |   1230 //	test(Math::Pow(res,KNegInfTReal64,KPosInfTReal64)==KErrOverflow); | 
|         |   1231 //	test(res==KPosInfTReal64); | 
|         |   1232 	test(Math::Pow(res,KNegInfTReal64,KPosInfTReal64)==KErrOverflow); | 
|         |   1233 	test(res==KPosInfTReal64); | 
|         |   1234 	test(Math::Pow(res,2.0,KPosInfTReal64)==KErrOverflow); | 
|         |   1235 	test(res==KPosInfTReal64); | 
|         |   1236 //	test(Math::Pow(res,-2.0,KPosInfTReal64)==KErrOverflow); | 
|         |   1237 //	test(res==KPosInfTReal64); | 
|         |   1238 	test(Math::Pow(res,-2.0,KPosInfTReal64)==KErrOverflow); | 
|         |   1239 	test(res==KPosInfTReal64); | 
|         |   1240 	test(Math::Pow(res,0.5,KNegInfTReal64)==KErrOverflow); | 
|         |   1241 	test(res==KPosInfTReal64); | 
|         |   1242 //	test(Math::Pow(res,-0.5,KNegInfTReal64)==KErrOverflow); | 
|         |   1243 //	test(res==KPosInfTReal64); | 
|         |   1244 	test(Math::Pow(res,-0.5,KNegInfTReal64)==KErrOverflow); | 
|         |   1245 	test(res==KPosInfTReal64); | 
|         |   1246 //	test(Math::Pow(res,1.0,KPosInfTReal64)==KErrArgument); | 
|         |   1247 //	test(Math::IsNaN(res)); | 
|         |   1248 	test(Math::Pow(res,1.0,KPosInfTReal64)==KErrNone); | 
|         |   1249 	test(res==1.0); | 
|         |   1250 	test(Math::Pow(res,-1.0,KPosInfTReal64)==KErrNone); | 
|         |   1251 	test(res==1.0); | 
|         |   1252 //	test(Math::Pow(res,1.0,KNegInfTReal64)==KErrArgument); | 
|         |   1253 //	test(Math::IsNaN(res)); | 
|         |   1254 	test(Math::Pow(res,1.0,KNegInfTReal64)==KErrNone); | 
|         |   1255 	test(res==1.0); | 
|         |   1256 	test(Math::Pow(res,-1.0,KNegInfTReal64)==KErrNone); | 
|         |   1257 	test(res==1.0); | 
|         |   1258 	test(Math::Pow(res,0.0,0.0)==KErrNone); | 
|         |   1259 	test(res==1.0); | 
|         |   1260 	test(Math::Pow(res,KNegZeroTReal64,KNegZeroTReal64)==KErrNone); | 
|         |   1261 	test(res==1.0); | 
|         |   1262 	test(Math::Pow(res,0.0,KNegZeroTReal64)==KErrNone); | 
|         |   1263 	test(res==1.0); | 
|         |   1264 	test(Math::Pow(res,KNegZeroTReal64,0.0)==KErrNone); | 
|         |   1265 	test(res==1.0); | 
|         |   1266 	test(Math::Pow(res,KPosInfTReal64,2.0)==KErrOverflow); | 
|         |   1267 	test(res==KPosInfTReal64); | 
|         |   1268 	test(Math::Pow(res,0.0,-2.0)==KErrOverflow); | 
|         |   1269 	test(res==KPosInfTReal64); | 
|         |   1270 	test(Math::Pow(res,-2.0,-2.6)==KErrArgument); | 
|         |   1271 	test(Math::IsNaN(res)); | 
|         |   1272 	test(Math::Pow(res,-2.0,4.8)==KErrArgument); | 
|         |   1273 	test(Math::IsNaN(res)); | 
|         |   1274 	test(Math::Pow(res,KNegZeroTReal64,-5)==KErrOverflow); | 
|         |   1275 	test(res==KNegInfTReal64); | 
|         |   1276 	test(Math::Pow(res,KNegZeroTReal64,-6)==KErrOverflow); | 
|         |   1277 	test(res==KPosInfTReal64); | 
|         |   1278 	test(Math::Pow(res,30,999999)==KErrOverflow);	// checking bug fixed | 
|         |   1279 	test(res==KPosInfTReal64); | 
|         |   1280 	test(Math::Pow(res,200,200)==KErrOverflow); | 
|         |   1281 	test(res==KPosInfTReal64); | 
|         |   1282 	test(Math::Pow(res,200,2000)==KErrOverflow);	// checking bug fixed | 
|         |   1283 	test(res==KPosInfTReal64); | 
|         |   1284 	test(Math::Pow(res,1000,1000)==KErrOverflow); | 
|         |   1285 	test(res==KPosInfTReal64); | 
|         |   1286 	test(Math::Pow(res,1000,100)==KErrNone); | 
|         |   1287 	test(testApprox(res,1E+300,3.0E-15)); | 
|         |   1288 	test(Math::Pow(res,1000,-1000)==KErrUnderflow); | 
|         |   1289 	test(Math::IsZero(res)); | 
|         |   1290 	test(Math::Pow(res,1000,-100)==KErrNone); | 
|         |   1291 	test(testApprox(res,1E-300,4.0E-15)); | 
|         |   1292 	 | 
|         |   1293 	TInt j; | 
|         |   1294     TInt i=sizeof(testpow)/sizeof(POWER); | 
|         |   1295     for (j=0;j<i;j++) | 
|         |   1296 		{ | 
|         |   1297 		test(Math::Pow(res,testpow[j].number,testpow[j].power)==KErrNone); | 
|         |   1298 		test(testApprox(res,testpow[j].result,1.0E-15)); | 
|         |   1299 		} | 
|         |   1300  | 
|         |   1301 	// Added by AnnW, October 1996 | 
|         |   1302 	TInt size = sizeof(testpowexact)/sizeof(POWER); | 
|         |   1303 	for (j=0; j<size; j++) | 
|         |   1304 		{ | 
|         |   1305 		test(Math::Pow(res,testpowexact[j].number,testpowexact[j].power)==KErrNone); | 
|         |   1306 		test(res==testpowexact[j].result); | 
|         |   1307 		} | 
|         |   1308  | 
|         |   1309 	// denormals (base only - do not know results for denormal power) | 
|         |   1310  	test(Math::Pow(res,K5EMinus324Real64,1.0)==KErrNone); | 
|         |   1311  	test(res==K5EMinus324Real64); | 
|         |   1312  	test(Math::Pow(res,K5EMinus324Real64,0.0)==KErrNone); | 
|         |   1313 	test(res==1.0); | 
|         |   1314 	test(Math::Pow(res,2E-160,2.0)==KErrNone); | 
|         |   1315 	test(testApprox(res,K4EMinus320Real64,1.0E-4));		 | 
|         |   1316  | 
|         |   1317 	// This test is to check that reduce() is working properly | 
|         |   1318 	// This is only a very approximate test due to loss of significance for such nos | 
|         |   1319 	TReal base,power; | 
|         |   1320 	for (TReal powerOfTwo=16.0; powerOfTwo<=54.0; powerOfTwo++) | 
|         |   1321 		{ | 
|         |   1322 		Math::Pow(power,2.0,powerOfTwo); | 
|         |   1323 		power+=0.7; | 
|         |   1324  		Math::Pow(base,2.0,1/power); | 
|         |   1325 		test(Math::Pow(res,base,power)==KErrNone); | 
|         |   1326 		test((2.0-res)<=1.0); | 
|         |   1327 		} | 
|         |   1328     } | 
|         |   1329  | 
|         |   1330 LOCAL_C void powtest2(TReal low,TReal upp) | 
|         |   1331 /* | 
|         |   1332 Test the identity (x**2)**1.5=x**3  on the range low<=x<upp | 
|         |   1333 */ | 
|         |   1334     //TReal low; // lower limit of range to test | 
|         |   1335     //TReal upp; // upper limit of range to test  | 
|         |   1336     { | 
|         |   1337      | 
|         |   1338 	TReal res,rres,x; | 
|         |   1339  | 
|         |   1340 	for (TInt j=0;j<10;j++) | 
|         |   1341 		{ | 
|         |   1342 		randrng(x,low,upp); | 
|         |   1343 		TReal y=2; | 
|         |   1344 		test(Math::Pow(res,x,y)==KErrNone); | 
|         |   1345 		TReal xr=res; | 
|         |   1346 		y=1.5; | 
|         |   1347 		test(Math::Pow(res,xr,y)==KErrNone); | 
|         |   1348 		TReal yr=3; | 
|         |   1349 		test(Math::Pow(rres,x,yr)==KErrNone);     | 
|         |   1350 		test(testApprox(rres,res,1.0E-14)); | 
|         |   1351 		} | 
|         |   1352     } | 
|         |   1353  | 
|         |   1354 LOCAL_C void powtest3() | 
|         |   1355 /*  | 
|         |   1356 Test the identity x**1=x  | 
|         |   1357 */ | 
|         |   1358     { | 
|         |   1359      | 
|         |   1360 	TReal x,res; | 
|         |   1361   | 
|         |   1362     TReal low=.5; | 
|         |   1363     TReal upp=1.0; | 
|         |   1364     for (TInt j=0;j<10;j++) | 
|         |   1365 		{ | 
|         |   1366 		randrng(x,low,upp); | 
|         |   1367 		TReal y=1.0; | 
|         |   1368 		test(Math::Pow(res,x,y)==KErrNone); | 
|         |   1369 		test(testApprox(res,x,1.0E-15)); | 
|         |   1370 		} | 
|         |   1371     } | 
|         |   1372  | 
|         |   1373 LOCAL_C void powtest4() | 
|         |   1374 /*  | 
|         |   1375 Test the identity (x**2)**(y/2)=x**y  | 
|         |   1376 */ | 
|         |   1377     { | 
|         |   1378      | 
|         |   1379 	TReal res,xr,rres,x,y; | 
|         |   1380      | 
|         |   1381     TReal low=.01; | 
|         |   1382     TReal upp=10.0; | 
|         |   1383     TReal lowy=-98; // range for y | 
|         |   1384     TReal uppy=98; | 
|         |   1385     for (TInt j=0;j<10;j++) | 
|         |   1386 		{ | 
|         |   1387 		randrng(x,low,upp); | 
|         |   1388 		randrng(y,lowy,uppy); | 
|         |   1389 		test(Math::Pow(res,x,y)==KErrNone); | 
|         |   1390 		TReal yr=2; | 
|         |   1391 		test(Math::Pow(xr,x,yr)==KErrNone); | 
|         |   1392 		y/=2; | 
|         |   1393 		test(Math::Pow(rres,xr,y)==KErrNone); | 
|         |   1394 		test(testApprox(res,rres,5.0E-14)); | 
|         |   1395 		} | 
|         |   1396     } | 
|         |   1397  | 
|         |   1398 LOCAL_C void powtest5() | 
|         |   1399 /*  | 
|         |   1400 Test the identity x**y=1/(x**(-y))  | 
|         |   1401 */ | 
|         |   1402     { | 
|         |   1403      | 
|         |   1404 	TReal x,y; | 
|         |   1405     TReal res,rres; | 
|         |   1406      | 
|         |   1407 	test(Math::Pow(res,-2,-3.765)==KErrArgument); | 
|         |   1408     TReal low=0.5; | 
|         |   1409     TReal upp=1.0; | 
|         |   1410     for (TInt j=0;j<10;j++) | 
|         |   1411 		{ | 
|         |   1412 		randrng(x,low,upp); | 
|         |   1413 		randrng(y,low,upp); | 
|         |   1414 		test(Math::Pow(res,x,y)==KErrNone); | 
|         |   1415 		y*=(-1); | 
|         |   1416 		test(Math::Pow(rres,x,y)==KErrNone); | 
|         |   1417 		rres=1/rres; | 
|         |   1418 		test(testApprox(res,rres,5.0E-15)); | 
|         |   1419 		} | 
|         |   1420     } | 
|         |   1421  | 
|         |   1422 LOCAL_C void powtest6() | 
|         |   1423 /*  | 
|         |   1424 Test specific ISO requirements on Pow() | 
|         |   1425 */ | 
|         |   1426 	{ | 
|         |   1427 	TInt i; | 
|         |   1428 	TInt n = sizeof(testpow_iso) / sizeof(POWERISO); | 
|         |   1429 	for (i = 0; i < n; i++) | 
|         |   1430 		{ | 
|         |   1431 		TReal ans; | 
|         |   1432 		TInt rc; | 
|         |   1433  | 
|         |   1434 		// If one of these tests fails, convert the "failed check xx" number | 
|         |   1435 		// to an index in testpow_iso[] by subtracting 1 and then dividing by 2. | 
|         |   1436 		// If the original number was odd, the first test (rc == xxx) failed. | 
|         |   1437 		// If the original number was even, the second test (.result) failed. | 
|         |   1438 		rc = Math::Pow(ans, testpow_iso[i].number, testpow_iso[i].power); | 
|         |   1439 		test(rc == testpow_iso[i].rc); | 
|         |   1440 		test((rc == KErrArgument) || (ans == testpow_iso[i].result)); | 
|         |   1441 		} | 
|         |   1442 	} | 
|         |   1443  | 
|         |   1444 LOCAL_C void pow10test() | 
|         |   1445 // | 
|         |   1446 // Test Pow10() for various selected values - results should indicate which string to  | 
|         |   1447 // binary conversions would NOT be expected to be exact - see t_float | 
|         |   1448 // | 
|         |   1449 	{ | 
|         |   1450  | 
|         |   1451 	TReal res; | 
|         |   1452  | 
|         |   1453 	// test errors | 
|         |   1454 	test(Math::Pow10(res,-324)==KErrUnderflow); | 
|         |   1455 	test(res==0.0); | 
|         |   1456 	test(Math::Pow10(res,-400)==KErrUnderflow); | 
|         |   1457 	test(res==0.0); | 
|         |   1458 	test(Math::Pow10(res,309)==KErrOverflow); | 
|         |   1459 	test(res==KPosInfTReal64); | 
|         |   1460 	test(Math::Pow10(res,400)==KErrOverflow); | 
|         |   1461 	test(res==KPosInfTReal64); | 
|         |   1462  | 
|         |   1463 	TInt j; | 
|         |   1464 	TInt i=sizeof(pow10teste)/sizeof(POW10_TEST); | 
|         |   1465  | 
|         |   1466 	for (j=0; j<i; j++) | 
|         |   1467 		{ | 
|         |   1468 		test(Math::Pow10(res,pow10teste[j].num)==KErrNone); | 
|         |   1469 		test(res==pow10teste[j].res); | 
|         |   1470 		} | 
|         |   1471  | 
|         |   1472 /*	i=sizeof(pow10testa)/sizeof(POW10_TEST); | 
|         |   1473 	 | 
|         |   1474 	for (j=0; j<i; j++) | 
|         |   1475 		{ | 
|         |   1476 		test(Math::Pow10(res,pow10testa[j].num)==KErrNone); | 
|         |   1477 		test(testApprox(res,pow10testa[j].res,1.0E-15)); | 
|         |   1478 		} | 
|         |   1479 */	} | 
|         |   1480  | 
|         |   1481 LOCAL_C void sintest1(TReal low,TReal upp) | 
|         |   1482 /* | 
|         |   1483 Test the identity sin(x)=sin(x/3)[3-4*(sin(x/3))**2] on the range low<=x<upp | 
|         |   1484 */ | 
|         |   1485     //TReal low; // lower limit of range to test | 
|         |   1486     //TReal upp; // upper limit of range to test  | 
|         |   1487     { | 
|         |   1488      | 
|         |   1489 	TReal x,res,rres; | 
|         |   1490  | 
|         |   1491     for (TInt j=0;j<100;j++) | 
|         |   1492 		{ | 
|         |   1493 		randrng(x,low,upp); | 
|         |   1494 		test(Math::Sin(res,x)==KErrNone); | 
|         |   1495 		x/=3; | 
|         |   1496 		test(Math::Sin(rres,x)==KErrNone); | 
|         |   1497 		TReal err=rres*rres; | 
|         |   1498 		err*=4; | 
|         |   1499 		err=3-err; | 
|         |   1500 		err*=rres; | 
|         |   1501 		test(testApprox(res,err,1.0E-12)); | 
|         |   1502 		} | 
|         |   1503     } | 
|         |   1504  | 
|         |   1505 LOCAL_C void sintest2() | 
|         |   1506 /*  | 
|         |   1507 Test selected values (which may not give exact results)  | 
|         |   1508 */ | 
|         |   1509     { | 
|         |   1510      | 
|         |   1511 	TReal res; | 
|         |   1512 	 | 
|         |   1513 	// test errors | 
|         |   1514 	test(Math::Sin(res,KNaNTReal64)==KErrArgument); | 
|         |   1515 	test(Math::IsNaN(res)); | 
|         |   1516 	test(Math::Sin(res,KPosInfTReal64)==KErrArgument); | 
|         |   1517 	test(Math::IsNaN(res)); | 
|         |   1518 	test(Math::Sin(res,KNegInfTReal64)==KErrArgument); | 
|         |   1519 	test(Math::IsNaN(res)); | 
|         |   1520 	test(Math::Sin(res,2147483648.0*KPi)==KErrArgument); | 
|         |   1521 	test(Math::IsNaN(res)); | 
|         |   1522 	test(Math::Sin(res,-1E+10)==KErrArgument); | 
|         |   1523 	test(Math::IsNaN(res)); | 
|         |   1524  | 
|         |   1525 	TInt i=sizeof(testsin)/sizeof(TESTSINE); | 
|         |   1526     TInt j; | 
|         |   1527      | 
|         |   1528 	for (j=0;j<i;j++) | 
|         |   1529 		{ | 
|         |   1530 		TReal x=testsin[j].num; | 
|         |   1531 		TReal y=testsin[j].res; | 
|         |   1532 		test(Math::Sin(res,x)==KErrNone); | 
|         |   1533    		test(testApprox(res,y,1.0E-15)); | 
|         |   1534 		} | 
|         |   1535  | 
|         |   1536 	//Added by AnnW, October 1996 | 
|         |   1537 	TInt mult=101; | 
|         |   1538 	for (j=-(mult-1); j<mult; j++) | 
|         |   1539 		{ | 
|         |   1540 		test(Math::Sin(res, (4*j+1)*KPiBy2)==KErrNone); | 
|         |   1541 		test(testApprox(res,1.0,1.0E-15)); | 
|         |   1542  | 
|         |   1543 		test(Math::Sin(res, (4*j+3)*KPiBy2)==KErrNone); | 
|         |   1544 		test(testApprox(res,-1.0,1.0E-15)); | 
|         |   1545  | 
|         |   1546 		test(Math::Sin(res, ((4*j+1)*90)*KDegToRad)==KErrNone); | 
|         |   1547 		test(testApprox(res,1.0,1.0E-15)); | 
|         |   1548  | 
|         |   1549 		test(Math::Sin(res, ((4*j+3)*90)*KDegToRad)==KErrNone); | 
|         |   1550 		test(testApprox(res,-1.0,1.0E-15)); | 
|         |   1551 		} | 
|         |   1552 	// | 
|         |   1553     } | 
|         |   1554  | 
|         |   1555 LOCAL_C void sintest3() | 
|         |   1556 /*  | 
|         |   1557 To test the identity sin(-x)=-sin(x) on the range [0,10*pi]  | 
|         |   1558 */         | 
|         |   1559     { | 
|         |   1560      | 
|         |   1561 	TReal x,res,rres; | 
|         |   1562  | 
|         |   1563     TReal low=0.0; | 
|         |   1564     TReal upp=10*KPi; | 
|         |   1565     for (TInt j=0;j<10;j++) | 
|         |   1566 		{ | 
|         |   1567 		randrng(x,low,upp); | 
|         |   1568 		test(Math::Sin(res,x)==KErrNone); | 
|         |   1569 		x*=(-1); | 
|         |   1570 		test(Math::Sin(rres,x)==KErrNone); | 
|         |   1571 		test(testApprox(rres,-res,1.0E-15)); | 
|         |   1572 		} | 
|         |   1573     } | 
|         |   1574  | 
|         |   1575 LOCAL_C void sintest4() | 
|         |   1576 /*  | 
|         |   1577 To test the identity sin(x)=x for x<<1  | 
|         |   1578 */         | 
|         |   1579     { | 
|         |   1580      | 
|         |   1581 	TReal res,x; | 
|         |   1582     TReal low=1E-90; | 
|         |   1583     TReal upp=1E-10; | 
|         |   1584  | 
|         |   1585     for (TInt j=0;j<10;j++) | 
|         |   1586 		{ | 
|         |   1587 		randrng(x,low,upp); | 
|         |   1588 		test(Math::Sin(res,x)==KErrNone); | 
|         |   1589 		test(testApprox(res,x,1.0E-15)); | 
|         |   1590 		} | 
|         |   1591  | 
|         |   1592 	// test some denormals | 
|         |   1593 	test(Math::Sin(res,5E-324)==KErrNone); | 
|         |   1594 	test(testApprox(res,5E-324,1.0E-15)); | 
|         |   1595 	test(Math::Sin(res,7E-317)==KErrNone); | 
|         |   1596 	test(testApprox(res,7E-317,1.0E-15));		 | 
|         |   1597     } | 
|         |   1598 /* | 
|         |   1599 LOCAL_C void sintest5() | 
|         |   1600 // | 
|         |   1601 // To test that exact results are given for multiples of pi and | 
|         |   1602 // values sufficiently close to them  | 
|         |   1603 // Added by AnnW, October 1996 | 
|         |   1604 // | 
|         |   1605 	{ | 
|         |   1606 	 | 
|         |   1607 	TReal res; | 
|         |   1608 	TInt j; | 
|         |   1609 	TInt mult=101; // can use up to 32768 | 
|         |   1610  | 
|         |   1611     test(Math::Sin(res,KNegZeroTReal64)==KErrNone); | 
|         |   1612 	test(res==0.0); | 
|         |   1613  | 
|         |   1614     for (j=-(mult-1); j<mult; j++) | 
|         |   1615 		{ | 
|         |   1616 		test(Math::Sin(res, j*KPi)==KErrNone); | 
|         |   1617 		test(res==0.0); | 
|         |   1618 		test(Math::Sin(res, j*(KPi+1.224E-16))==KErrNone); | 
|         |   1619 		test(res==0.0); | 
|         |   1620 		test(Math::Sin(res, (j*180)*KDegToRad)==KErrNone); | 
|         |   1621 		test(res==0.0); | 
|         |   1622 		if (j!=0) | 
|         |   1623 			{ | 
|         |   1624 			test(Math::Sin(res, j*(KPi+1.0E-14))==KErrNone); | 
|         |   1625 			test(res!=0.0); | 
|         |   1626 			}		 | 
|         |   1627 		} | 
|         |   1628 	} | 
|         |   1629 */ | 
|         |   1630 LOCAL_C void costest1() | 
|         |   1631 /*  | 
|         |   1632 To test the identity cos(x)=cos(x/3)[4*(cos(x/3)**2)-3] on the interval  | 
|         |   1633 [7*pi,7.5*pi]  | 
|         |   1634 Added by AnnW, October 1996 | 
|         |   1635 */ | 
|         |   1636     { | 
|         |   1637  | 
|         |   1638     TReal x,res,rres; | 
|         |   1639  | 
|         |   1640     TReal low=7*KPi; | 
|         |   1641     TReal upp=7.5*KPi; | 
|         |   1642     for (TInt j=0;j<100;j++) | 
|         |   1643 		{ | 
|         |   1644 		randrng(x,low,upp); | 
|         |   1645 		test(Math::Cos(res,x)==KErrNone); | 
|         |   1646 		x/=3; | 
|         |   1647 		test(Math::Cos(rres,x)==KErrNone); | 
|         |   1648 		test(testApprox(res,rres*(4*(rres*rres)-3),5.0E-13)); | 
|         |   1649 		} | 
|         |   1650     } | 
|         |   1651  | 
|         |   1652 LOCAL_C void costest2() | 
|         |   1653 /* | 
|         |   1654 Test selected values (which may not give exact results)  | 
|         |   1655 Added by AnnW, October 1996 | 
|         |   1656 */ | 
|         |   1657     { | 
|         |   1658      | 
|         |   1659 	TReal res; | 
|         |   1660  | 
|         |   1661 	// test errors | 
|         |   1662 	test(Math::Cos(res,KNaNTReal64)==KErrArgument); | 
|         |   1663 	test(Math::IsNaN(res)); | 
|         |   1664 	test(Math::Cos(res,KPosInfTReal64)==KErrArgument); | 
|         |   1665 	test(Math::IsNaN(res)); | 
|         |   1666 	test(Math::Cos(res,KNegInfTReal64)==KErrArgument); | 
|         |   1667 	test(Math::IsNaN(res)); | 
|         |   1668 	test(Math::Cos(res,(2147483648.0*KPi))==KErrArgument); | 
|         |   1669 	test(Math::IsNaN(res)); | 
|         |   1670 	test(Math::Sin(res,-1E+10)==KErrArgument); | 
|         |   1671 	test(Math::IsNaN(res)); | 
|         |   1672  | 
|         |   1673 	TInt j; | 
|         |   1674 	TInt mult=101; | 
|         |   1675 	TInt i=sizeof(testcos)/sizeof(TESTCOSINE); | 
|         |   1676  | 
|         |   1677     for (j=0; j<i; j++) | 
|         |   1678 		{ | 
|         |   1679 		test(Math::Cos(res,testcos[j].num)==KErrNone); | 
|         |   1680 		test(testApprox(res,testcos[j].res,1.0E-15));		 | 
|         |   1681 		} | 
|         |   1682  | 
|         |   1683 	test(Math::Cos(res,KNegZeroTReal64)==KErrNone); | 
|         |   1684 	test(testApprox(res,1.0,1E-15)); | 
|         |   1685  | 
|         |   1686     for (j=-(mult-1); j<mult; j++) | 
|         |   1687 		{ | 
|         |   1688 		test(Math::Cos(res, (2*j)*KPi)==KErrNone); | 
|         |   1689 		test(testApprox(res,1.0,1.0E-15));		 | 
|         |   1690  | 
|         |   1691 		test(Math::Cos(res, (2*j+1)*KPi)==KErrNone); | 
|         |   1692 		test(testApprox(res,-1.0,1.0E-15));		 | 
|         |   1693  | 
|         |   1694 		test(Math::Cos(res, (2*j)*(KPi+1.224E-16))==KErrNone); | 
|         |   1695 		test(testApprox(res,1.0,1.0E-15));		 | 
|         |   1696  | 
|         |   1697 		test(Math::Cos(res, (2*j+1)*(KPi+1.224E-16))==KErrNone); | 
|         |   1698 		test(testApprox(res,-1.0,1.0E-15));		 | 
|         |   1699  | 
|         |   1700 		test(Math::Cos(res, ((2*j)*180)*KDegToRad)==KErrNone); | 
|         |   1701 		test(testApprox(res,1.0,1.0E-15));		 | 
|         |   1702  | 
|         |   1703 		test(Math::Cos(res, ((2*j+1)*180)*KDegToRad)==KErrNone); | 
|         |   1704 		test(testApprox(res,-1.0,1.0E-15));		 | 
|         |   1705 		} | 
|         |   1706     } | 
|         |   1707  | 
|         |   1708 LOCAL_C void costest3() | 
|         |   1709 /*  | 
|         |   1710 To test the identity cos(-x)=cos(x) on the range [0,10*pi] | 
|         |   1711 Added by AnnW, October 1996  | 
|         |   1712 */         | 
|         |   1713     { | 
|         |   1714  | 
|         |   1715     TReal x,res,rres; | 
|         |   1716  | 
|         |   1717     TReal low=0.0; | 
|         |   1718     TReal upp=10*KPi; | 
|         |   1719     for (TInt j=0;j<10;j++) | 
|         |   1720 		{ | 
|         |   1721 		randrng(x,low,upp); | 
|         |   1722 		test(Math::Cos(res,x)==KErrNone); | 
|         |   1723 		x*=(-1); | 
|         |   1724 		test(Math::Cos(rres,x)==KErrNone); | 
|         |   1725 		test(testApprox(rres,res,1.0E-15));		 | 
|         |   1726 		} | 
|         |   1727     } | 
|         |   1728  | 
|         |   1729 LOCAL_C void costest4() | 
|         |   1730 /*  | 
|         |   1731 To test the identity cos(x)=1 for x<<1  | 
|         |   1732 Added by Annw, October 1996 | 
|         |   1733 */         | 
|         |   1734     { | 
|         |   1735  | 
|         |   1736     TReal res,x; | 
|         |   1737     TReal low=1E-90; | 
|         |   1738     TReal upp=1E-10; | 
|         |   1739  | 
|         |   1740     for (TInt j=0;j<10;j++) | 
|         |   1741 		{ | 
|         |   1742 		randrng(x,low,upp); | 
|         |   1743 		test(Math::Cos(res,x)==KErrNone); | 
|         |   1744 		test(testApprox(res,1.0,1.0E-15)); | 
|         |   1745 		} | 
|         |   1746  | 
|         |   1747 	// test some denormals | 
|         |   1748 	test(Math::Cos(res,5E-324)==KErrNone); | 
|         |   1749 	test(testApprox(res,1.0,1.0E-15)); | 
|         |   1750 	test(Math::Cos(res,1.34E-315)==KErrNone); | 
|         |   1751 	test(testApprox(res,1.0,1.0E-15));			 | 
|         |   1752     } | 
|         |   1753 /* | 
|         |   1754 LOCAL_C void costest5() | 
|         |   1755 // | 
|         |   1756 // To test that exact results are given for multiples of KPi and | 
|         |   1757 // values sufficiently close to them  | 
|         |   1758 // Added by AnnW, October 1996 | 
|         |   1759 // | 
|         |   1760 	{ | 
|         |   1761  | 
|         |   1762 	TReal res; | 
|         |   1763 	TInt mult=101;	// can use up to 32768 | 
|         |   1764 	TInt j; | 
|         |   1765      | 
|         |   1766     for (j=-(mult-1); j<mult; j++) | 
|         |   1767 		{ | 
|         |   1768 		test(Math::Cos(res, (2*j+1)*KPiBy2)==KErrNone); | 
|         |   1769 		test(res==0.0); | 
|         |   1770 		test(Math::Cos(res, (2*j+1)*KPiBy2+(j+1)*1.224E-16)==KErrNone); | 
|         |   1771 		test(res==0.0); | 
|         |   1772 		test(Math::Cos(res, (2*j+1)*90*KDegToRad)==KErrNone); | 
|         |   1773 		test(res==0.0); | 
|         |   1774 		if (j!=0) | 
|         |   1775 			{ | 
|         |   1776 			test(Math::Sin(res, (2*j+1)*(KPiBy2+1.0E-14))==KErrNone); | 
|         |   1777 			test(res!=0.0); | 
|         |   1778 			} | 
|         |   1779 		} | 
|         |   1780 	} | 
|         |   1781 */ | 
|         |   1782 LOCAL_C void tantest1(TReal low,TReal upp) | 
|         |   1783 /* | 
|         |   1784 Test the identity tan(x)=(2*tan(x/2))/(1-tan(x/2)**2) on the range low<=x<upp | 
|         |   1785 */ | 
|         |   1786     //TReal low; // lower limit of range to test | 
|         |   1787     //TReal upp; // upper limit of range to test  | 
|         |   1788     { | 
|         |   1789  | 
|         |   1790     TReal x,res,rres; | 
|         |   1791  | 
|         |   1792     for (TInt j=0;j<100;j++) | 
|         |   1793 		{ | 
|         |   1794 		if (j==90) | 
|         |   1795 			{ | 
|         |   1796 			test(1); | 
|         |   1797 			} | 
|         |   1798 		randrng(x,low,upp); | 
|         |   1799 		test(Math::Tan(res,x)==KErrNone); | 
|         |   1800 		x/=2; | 
|         |   1801 		test(Math::Tan(rres,x)==KErrNone); | 
|         |   1802 		TReal ex=(2*rres)/(1-rres*rres); | 
|         |   1803 		test(testApprox(res,ex,1.0E-15));		 | 
|         |   1804 		} | 
|         |   1805     } | 
|         |   1806  | 
|         |   1807 LOCAL_C void tantest2() | 
|         |   1808 /*  | 
|         |   1809 To test tangent for specific  arguments  | 
|         |   1810 */ | 
|         |   1811     { | 
|         |   1812  | 
|         |   1813     TReal res; | 
|         |   1814  | 
|         |   1815 	// test errors | 
|         |   1816 	test(Math::Tan(res,KNaNTReal64)==KErrArgument); | 
|         |   1817 	test(Math::IsNaN(res)); | 
|         |   1818 	test(Math::Tan(res,KPosInfTReal64)==KErrArgument); | 
|         |   1819 	test(Math::IsNaN(res)); | 
|         |   1820 	test(Math::Tan(res,KNegInfTReal64)==KErrArgument); | 
|         |   1821 	test(Math::IsNaN(res)); | 
|         |   1822 	test(Math::Tan(res, 1073741824.0*KPi)==KErrArgument); | 
|         |   1823 	test(Math::IsNaN(res)); | 
|         |   1824 	test(Math::Tan(res, 4.0E+102)==KErrArgument); | 
|         |   1825 	test(Math::IsNaN(res)); | 
|         |   1826 	test(Math::Tan(res, -4.0E+102)==KErrArgument); | 
|         |   1827 	test(Math::IsNaN(res)); | 
|         |   1828      | 
|         |   1829 	TInt j; | 
|         |   1830 	TInt mult=101;	// can use up to 32768 | 
|         |   1831     TInt i=sizeof(testtan)/sizeof(TAN); | 
|         |   1832     for (j=0;j<i;j++) | 
|         |   1833 		{ | 
|         |   1834 		test(Math::Tan(res,testtan[j].angle)==KErrNone); | 
|         |   1835 		test(testApprox(res,testtan[j].result,1.0E-15));		 | 
|         |   1836 		} | 
|         |   1837  | 
|         |   1838 	//Added by AnnW, October 1996 | 
|         |   1839 	for (j=-(mult-1); j<mult; j++) | 
|         |   1840 		{ | 
|         |   1841 //		test(Math::Tan(res, (2*j+1)*KPiBy2)==KErrOverflow); | 
|         |   1842 //		test(Math::IsInfinite(res));	// this test is no longer valid | 
|         |   1843 		test(Math::Tan(res, (2*j+1)*(KPiBy2+1.0E-15))!=KErrOverflow); | 
|         |   1844 		test(Math::IsFinite(res)); | 
|         |   1845 		} | 
|         |   1846 	 | 
|         |   1847 	// Check that signs are correct | 
|         |   1848 	test(Math::Tan(res,KPiBy2+5E-16)==KErrNone); | 
|         |   1849 	test(res<0); | 
|         |   1850 	test(Math::Tan(res,KPiBy2-5E-16)==KErrNone); | 
|         |   1851 	test(res>0); | 
|         |   1852 	} | 
|         |   1853  | 
|         |   1854 LOCAL_C void tantest3() | 
|         |   1855 /*  | 
|         |   1856 To test the identity tan(-x)=-tan(x) on the range [-1.5,1.5]  | 
|         |   1857 */         | 
|         |   1858     { | 
|         |   1859  | 
|         |   1860     TReal x,res,rres; | 
|         |   1861  | 
|         |   1862     TReal low=(-1.5); | 
|         |   1863     TReal upp=1.5; | 
|         |   1864     for (TInt j=0;j<10;j++) | 
|         |   1865 		{ | 
|         |   1866 		randrng(x,low,upp); | 
|         |   1867 		test(Math::Tan(res,x)==KErrNone); | 
|         |   1868 		x*=(-1); | 
|         |   1869 		test(Math::Tan(rres,x)==KErrNone); | 
|         |   1870 		test(testApprox(rres,-res,1.0E-15));		 | 
|         |   1871 		} | 
|         |   1872     } | 
|         |   1873  | 
|         |   1874 LOCAL_C void tantest4() | 
|         |   1875 /*  | 
|         |   1876 To test the identity tan(x)=x for x<<1  | 
|         |   1877 */         | 
|         |   1878     { | 
|         |   1879  | 
|         |   1880     TReal x,res; | 
|         |   1881  | 
|         |   1882     TReal low=1E-90; | 
|         |   1883     TReal upp=1E-10; | 
|         |   1884     for (TInt j=0;j<10;j++) | 
|         |   1885 		{ | 
|         |   1886 		randrng(x,low,upp); | 
|         |   1887 		test(Math::Tan(res,x)==KErrNone); | 
|         |   1888 		test(testApprox(res,x,1.0E-15));		 | 
|         |   1889 		} | 
|         |   1890  | 
|         |   1891 	// Check some denormals | 
|         |   1892 	test(Math::Tan(res,5E-324)==KErrNone); | 
|         |   1893 	test(res==5E-324); | 
|         |   1894 	test(Math::Tan(res,-1.234567891234E-315)==KErrNone); | 
|         |   1895 	test(res==-1.234567891234E-315);	 | 
|         |   1896     } | 
|         |   1897 /* | 
|         |   1898 LOCAL_C void tantest5() | 
|         |   1899  | 
|         |   1900 // To test that exact results are given for multiples of KPi | 
|         |   1901 // Added by AnnW, October 1996 | 
|         |   1902  | 
|         |   1903 	{ | 
|         |   1904  | 
|         |   1905     TReal res; | 
|         |   1906 	TInt j; | 
|         |   1907 	TInt mult=101;	// can use up to 32768 | 
|         |   1908  | 
|         |   1909 	test(Math::Tan(res,KNegZeroTReal64)==KErrNone); | 
|         |   1910 	test(res==KNegZeroTReal64); | 
|         |   1911      | 
|         |   1912     for (j=-(mult-1); j<mult; j++) | 
|         |   1913 		{ | 
|         |   1914 		test(Math::Tan(res, j*KPi)==KErrNone); | 
|         |   1915 		test(res==0.0); | 
|         |   1916 		test(Math::Tan(res, j*(KPi+1.224E-16))==KErrNone); | 
|         |   1917 		test(res==0.0); | 
|         |   1918 		test(Math::Tan(res, (j*180)*KDegToRad)==KErrNone); | 
|         |   1919 		test(res==0.0); | 
|         |   1920 		if (j!=0) | 
|         |   1921 			{ | 
|         |   1922 			test(Math::Sin(res, j*(KPi+1.0E-14))==KErrNone); | 
|         |   1923 			test(res!=0.0); | 
|         |   1924 			} | 
|         |   1925 		} | 
|         |   1926 	} | 
|         |   1927 */ | 
|         |   1928 LOCAL_C void astest1(TReal low,TReal upp,TInt k,TInt cosflg) | 
|         |   1929 /* | 
|         |   1930 Tests random numbers in the range [low,upp] using the Taylor approximation  | 
|         |   1931 */ | 
|         |   1932     //TReal low; // lower limit of range to test | 
|         |   1933     //TReal upp; // upper limit of range to test  | 
|         |   1934     //TInt k; // Highest order term to be used in the taylor approximation | 
|         |   1935     //TInt cosflg; // Flag for arc cos | 
|         |   1936     { | 
|         |   1937  | 
|         |   1938     TReal res,x; | 
|         |   1939  | 
|         |   1940     for (TInt j=0;j<100;j++) | 
|         |   1941 		{ | 
|         |   1942 		randrng(x,low,upp); | 
|         |   1943 		if (cosflg) | 
|         |   1944 			test(Math::ACos(res,x)==KErrNone); | 
|         |   1945 		else | 
|         |   1946 			test(Math::ASin(res,x)==KErrNone); | 
|         |   1947 		TReal tres=taylor(x,k); | 
|         |   1948 		if (cosflg) | 
|         |   1949 			tres=KPiBy2-tres; | 
|         |   1950 		test(testApprox(tres,res,5.0E-15));		 | 
|         |   1951 		} | 
|         |   1952     } | 
|         |   1953  | 
|         |   1954 LOCAL_C void astest2() | 
|         |   1955 /*  | 
|         |   1956 To test the identity arc sin(x)=x for x<<1  | 
|         |   1957 */         | 
|         |   1958     { | 
|         |   1959  | 
|         |   1960     TReal x,res; | 
|         |   1961  | 
|         |   1962     TReal low=1E-90; | 
|         |   1963     TReal upp=1E-10; | 
|         |   1964     for (TInt j=0;j<100;j++) | 
|         |   1965 		{ | 
|         |   1966 		randrng(x,low,upp); | 
|         |   1967 		test(Math::ASin(res,x)==KErrNone); | 
|         |   1968 		test(testApprox(res,x,1.0E-15));		 | 
|         |   1969 		} | 
|         |   1970  | 
|         |   1971 	// Check some denormals | 
|         |   1972 	test(Math::ASin(res,5E-324)==KErrNone); | 
|         |   1973 	test(res==5E-324);		 | 
|         |   1974 	test(Math::ASin(res,-8.912345678E-318)==KErrNone); | 
|         |   1975 	test(res==-8.912345678E-318);		 | 
|         |   1976     } | 
|         |   1977  | 
|         |   1978 LOCAL_C void astest3() | 
|         |   1979 /*  | 
|         |   1980 To test the identity arc sin(-x)=-arc sin(x)  | 
|         |   1981 */         | 
|         |   1982     { | 
|         |   1983  | 
|         |   1984     TReal res,rres,x; | 
|         |   1985  | 
|         |   1986     TReal low=0.0; | 
|         |   1987     TReal upp=1.0; | 
|         |   1988     for (TInt j=0;j<100;j++) | 
|         |   1989 		{ | 
|         |   1990 		randrng(x,low,upp); | 
|         |   1991 		test(Math::ASin(res,x)==KErrNone); | 
|         |   1992 		TReal y=(-x); | 
|         |   1993 		test(Math::ASin(rres,y)==KErrNone); | 
|         |   1994 		test(testApprox(rres,-res,1.0E-15));		 | 
|         |   1995 		} | 
|         |   1996     } | 
|         |   1997  | 
|         |   1998 LOCAL_C void astest4(TInt k,TInt sgn) | 
|         |   1999 /*  | 
|         |   2000 Test selected numbers  | 
|         |   2001 */ | 
|         |   2002     //TInt k; // arc cosine flag | 
|         |   2003     //TInt sgn; // sign flag for range     | 
|         |   2004     { | 
|         |   2005  | 
|         |   2006     TReal res; | 
|         |   2007  | 
|         |   2008 	// test errors | 
|         |   2009 	test(Math::ASin(res,KNaNTReal64)==KErrArgument); | 
|         |   2010 	test(Math::IsNaN(res)); | 
|         |   2011 	test(Math::ASin(res,KPosInfTReal64)==KErrArgument); | 
|         |   2012 	test(Math::IsNaN(res)); | 
|         |   2013 	test(Math::ASin(res,KNegInfTReal64)==KErrArgument); | 
|         |   2014 	test(Math::IsNaN(res)); | 
|         |   2015 	test(Math::ASin(res,1.0000000000001)==KErrArgument); | 
|         |   2016 	test(Math::IsNaN(res)); | 
|         |   2017 	test(Math::ASin(res,-1.0000000000001)==KErrArgument); | 
|         |   2018 	test(Math::IsNaN(res)); | 
|         |   2019 	test(Math::ACos(res,KNaNTReal64)==KErrArgument); | 
|         |   2020 	test(Math::IsNaN(res)); | 
|         |   2021 	test(Math::ACos(res,KPosInfTReal64)==KErrArgument); | 
|         |   2022 	test(Math::IsNaN(res)); | 
|         |   2023 	test(Math::ACos(res,KNegInfTReal64)==KErrArgument); | 
|         |   2024 	test(Math::IsNaN(res)); | 
|         |   2025 	test(Math::ACos(res,1.0000000000001)==KErrArgument); | 
|         |   2026 	test(Math::IsNaN(res)); | 
|         |   2027 	test(Math::ACos(res,-1.0000000000001)==KErrArgument); | 
|         |   2028 	test(Math::IsNaN(res)); | 
|         |   2029  | 
|         |   2030 	test(Math::ASin(res,0.0)==KErrNone); | 
|         |   2031 	test(res==0.0); | 
|         |   2032 	test(Math::ASin(res,KNegZeroTReal64)==KErrNone); | 
|         |   2033 	test(res==0.0); | 
|         |   2034  | 
|         |   2035     TInt i=sizeof(testas)/sizeof(TESTASC); | 
|         |   2036     for (TInt j=0;j<i;j++)  | 
|         |   2037 		{ | 
|         |   2038 		// NB Results for comparison only given to 12 or 13 decimal places, so can't expect  | 
|         |   2039 		// better accuracy | 
|         |   2040 		if (k) | 
|         |   2041 			{ | 
|         |   2042 			testas[j].num*=sgn; | 
|         |   2043 			testas[j].res*=sgn; | 
|         |   2044 			test(Math::ACos(res,testas[j].num)==KErrNone); | 
|         |   2045 			test(testApprox(res,(KPiBy2-testas[j].res),1.0E-11));	 | 
|         |   2046 			} | 
|         |   2047 		else | 
|         |   2048 			{ | 
|         |   2049 			test(Math::ASin(res,testas[j].num)==KErrNone); | 
|         |   2050 			test(testApprox(res,testas[j].res,1.0E-12));	 | 
|         |   2051 			} | 
|         |   2052 		} | 
|         |   2053  | 
|         |   2054 	// Check some denormals for ACos() | 
|         |   2055 	test(Math::ACos(res,5E-324)==KErrNone); | 
|         |   2056 	test(res==KPiBy2);	 | 
|         |   2057 	test(Math::ACos(res,-9.87654E-320)==KErrNone); | 
|         |   2058 	test(res==KPiBy2);						 | 
|         |   2059     } | 
|         |   2060  | 
|         |   2061 LOCAL_C void attest1() | 
|         |   2062 /*  | 
|         |   2063 Random argument tests for x in the primary range, comparing the result with a  | 
|         |   2064 Taylor series approximation | 
|         |   2065 */ | 
|         |   2066     { | 
|         |   2067  | 
|         |   2068     TReal res,x; | 
|         |   2069  | 
|         |   2070     TReal low=(-0.0625); | 
|         |   2071     TReal upp=0.0625; | 
|         |   2072     for (TInt i=0;i<10;i++) | 
|         |   2073 		{ | 
|         |   2074 		randrng(x,low,upp); | 
|         |   2075 		test(Math::ATan(res,x)==KErrNone); | 
|         |   2076 		TReal tres=tayatan(x); | 
|         |   2077 		test(testApprox(res,tres,1.0E-15));		 | 
|         |   2078 		} | 
|         |   2079     } | 
|         |   2080  | 
|         |   2081 LOCAL_C void attest2() | 
|         |   2082 /*  | 
|         |   2083 Random argument tests for x outside the primary range, using the identity | 
|         |   2084 arctan(u)=arctan(v)+arctan[(u-v)/(1+uv)] | 
|         |   2085 */ | 
|         |   2086     { | 
|         |   2087  | 
|         |   2088     TReal x,res,rres,atcnst; | 
|         |   2089  | 
|         |   2090     TReal low=0.0625; | 
|         |   2091     TReal upp=2.0-KSqt3; | 
|         |   2092     TReal cnst=0.0625; | 
|         |   2093     test(Math::ATan(atcnst,cnst)==KErrNone); | 
|         |   2094     for (TInt i=0;i<10;i++) | 
|         |   2095 		{ | 
|         |   2096 		randrng(x,low,upp); | 
|         |   2097 		test(Math::ATan(res,x)==KErrNone); | 
|         |   2098 		TReal y=(x-cnst)/(1+x*cnst); | 
|         |   2099 		test(Math::ATan(rres,y)==KErrNone); | 
|         |   2100 		test(testApprox(res,(atcnst+rres),1.0E-15));		 | 
|         |   2101 		} | 
|         |   2102     }                    | 
|         |   2103  | 
|         |   2104 LOCAL_C void attest3() | 
|         |   2105 /* | 
|         |   2106 Check that the identity arctan(-x)=-arctan(x) holds | 
|         |   2107 */ | 
|         |   2108     { | 
|         |   2109  | 
|         |   2110     TReal res,rres,x; | 
|         |   2111     TReal low=0.0; | 
|         |   2112     TReal upp=1.0; | 
|         |   2113     for (TInt i=0;i<10;i++) | 
|         |   2114 		{ | 
|         |   2115 		randrng(x,upp,low); | 
|         |   2116 		test(Math::ATan(res,x)==KErrNone); | 
|         |   2117 		x=(-x); | 
|         |   2118 		test(Math::ATan(rres,x)==KErrNone); | 
|         |   2119 		test(testApprox(res,-rres,1.0E-15));		 | 
|         |   2120 		} | 
|         |   2121     }            | 
|         |   2122  | 
|         |   2123 LOCAL_C void attest4() | 
|         |   2124 /*  | 
|         |   2125 Check that the identity arctan(x)=x for Abs(x)<1 holds | 
|         |   2126 */ | 
|         |   2127     { | 
|         |   2128  | 
|         |   2129     TReal x,res; | 
|         |   2130  | 
|         |   2131     TReal low=1E-90; | 
|         |   2132     TReal upp=1E-20; | 
|         |   2133     for (TInt i=0;i<10;i++) | 
|         |   2134 		{ | 
|         |   2135 		randrng(x,low,upp); | 
|         |   2136 		test(Math::ATan(res,x)==KErrNone); | 
|         |   2137 		test(testApprox(res,x,1.0E-15));		 | 
|         |   2138 		} | 
|         |   2139  | 
|         |   2140 	// Check some denormals | 
|         |   2141 	test(Math::ATan(res,-5E-324)==KErrNone); | 
|         |   2142 	test(res==-5E-324);		 | 
|         |   2143 	test(Math::ATan(res,7.123E-322)==KErrNone); | 
|         |   2144 	test(res==7.123E-322);			 | 
|         |   2145     } | 
|         |   2146  | 
|         |   2147 LOCAL_C void attest5() | 
|         |   2148 /* | 
|         |   2149 Tests selected values | 
|         |   2150 */ | 
|         |   2151     { | 
|         |   2152  | 
|         |   2153     TReal res; | 
|         |   2154  | 
|         |   2155 	// test errors, special cases | 
|         |   2156 	test(Math::ATan(res,KNaNTReal64)==KErrArgument); | 
|         |   2157 	test(Math::IsNaN(res)); | 
|         |   2158 	test(Math::ATan(res,0.0)==KErrNone); | 
|         |   2159 	test(res==0.0); | 
|         |   2160 	test(Math::ATan(res,KNegZeroTReal64)==KErrNone); | 
|         |   2161 	test(res==0.0); | 
|         |   2162 	test(Math::ATan(res,KPosInfTReal64)==KErrNone); | 
|         |   2163 	test(res==KPiBy2); | 
|         |   2164 	test(Math::ATan(res,KNegInfTReal64)==KErrNone); | 
|         |   2165 	test(res==-KPiBy2); | 
|         |   2166  | 
|         |   2167 	test(Math::ATan(res,KNaNTReal64,1.0)==KErrArgument); | 
|         |   2168 	test(Math::IsNaN(res)); | 
|         |   2169 	test(Math::ATan(res,1.0,KNaNTReal64)==KErrArgument); | 
|         |   2170 	test(Math::IsNaN(res)); | 
|         |   2171 	test(Math::ATan(res,KNaNTReal64,KNaNTReal64)==KErrArgument); | 
|         |   2172 	test(Math::IsNaN(res)); | 
|         |   2173 	test(Math::ATan(res,0.0,KNegZeroTReal64)==KErrArgument); | 
|         |   2174 	test(Math::IsNaN(res)); | 
|         |   2175 	test(Math::ATan(res,KNegZeroTReal64,KNegZeroTReal64)==KErrArgument); | 
|         |   2176 	test(Math::IsNaN(res));	 | 
|         |   2177 	test(Math::ATan(res,0.0,0.0)==KErrArgument); | 
|         |   2178 	test(Math::IsNaN(res));	 | 
|         |   2179 	test(Math::ATan(res,KNegZeroTReal64,KNegZeroTReal64)==KErrArgument); | 
|         |   2180 	test(Math::IsNaN(res));	 | 
|         |   2181 	test(Math::ATan(res,KPosInfTReal64,KNegInfTReal64)==KErrNone); | 
|         |   2182 	test(res==3.0*(KPiBy2/2.0)); | 
|         |   2183 	test(Math::ATan(res,KPosInfTReal64,KPosInfTReal64)==KErrNone); | 
|         |   2184 	test(res==KPiBy2/2.0); | 
|         |   2185 	test(Math::ATan(res,KNegInfTReal64,KPosInfTReal64)==KErrNone); | 
|         |   2186 	test(res==-(KPiBy2/2.0)); | 
|         |   2187 	test(Math::ATan(res,KNegInfTReal64,KNegInfTReal64)==KErrNone); | 
|         |   2188 	test(res==-3.0*(KPiBy2/2.0)); | 
|         |   2189 	test(Math::ATan(res,KNegZeroTReal64,1.0)==KErrNone); | 
|         |   2190 	test(res==0.0); | 
|         |   2191 	test(Math::ATan(res,0.0,1.0)==KErrNone); | 
|         |   2192 	test(res==0.0);	 | 
|         |   2193 	test(Math::ATan(res,0.0,-1.0)==KErrNone); | 
|         |   2194 	test(res==KPi);	 | 
|         |   2195 	test(Math::ATan(res,1.0,KPosInfTReal64)==KErrNone); | 
|         |   2196 	test(res==0.0); | 
|         |   2197 	test(Math::ATan(res,1.0,KNegInfTReal64)==KErrNone); | 
|         |   2198 	test(res==KPi); | 
|         |   2199 	test(Math::ATan(res,0.0,KPosInfTReal64)==KErrNone);	 | 
|         |   2200 	test(res==0.0); | 
|         |   2201 	test(Math::ATan(res,KPosInfTReal64,1.0)==KErrNone);	 | 
|         |   2202 	test(res==KPiBy2); | 
|         |   2203 	test(Math::ATan(res,KNegInfTReal64,1.0)==KErrNone);	 | 
|         |   2204 	test(res==-KPiBy2); | 
|         |   2205 	test(Math::ATan(res,1.0,0.0)==KErrNone);	 | 
|         |   2206 	test(res==KPiBy2); | 
|         |   2207 	test(Math::ATan(res,1.0,KNegZeroTReal64)==KErrNone);	 | 
|         |   2208 	test(res==KPiBy2); | 
|         |   2209 	test(Math::ATan(res,KPosInfTReal64,-1.0)==KErrNone);	 | 
|         |   2210 	test(res==KPiBy2); | 
|         |   2211 	test(Math::ATan(res,KNegInfTReal64,-1.0)==KErrNone);	 | 
|         |   2212 	test(res==-KPiBy2); | 
|         |   2213 	test(Math::ATan(res,-1.0,0.0)==KErrNone);	 | 
|         |   2214 	test(res==-KPiBy2); | 
|         |   2215 	test(Math::ATan(res,-1.0,KNegZeroTReal64)==KErrNone);	 | 
|         |   2216 	test(res==-KPiBy2); | 
|         |   2217 	test(Math::ATan(res,5E-324,10)==KErrNone);	 | 
|         |   2218 	test(res==0.0); | 
|         |   2219 	test(Math::ATan(res,1E+308,0.1)==KErrNone);	 | 
|         |   2220 	test(res==KPiBy2); | 
|         |   2221  | 
|         |   2222     TInt i=sizeof(testat2)/sizeof(TESTATAN2); | 
|         |   2223     for (TInt j=0;j<i;j++)  | 
|         |   2224 		{ | 
|         |   2225 		// NB Some results only given to 12 dp so cannot expect better accuracy | 
|         |   2226 		test(Math::ATan(res,testat2[j].num1,testat2[j].num2)==KErrNone); | 
|         |   2227 		test(testApprox(res,testat2[j].res,1.0E-12));		 | 
|         |   2228 		}	 | 
|         |   2229     } | 
|         |   2230  | 
|         |   2231 LOCAL_C void inttest1() | 
|         |   2232 /* | 
|         |   2233 Tests specific numbers | 
|         |   2234 */ | 
|         |   2235     { | 
|         |   2236  | 
|         |   2237     TReal res; | 
|         |   2238  | 
|         |   2239 	// Specials | 
|         |   2240 	test(Math::Int(res,KNaNTReal64)==KErrArgument); | 
|         |   2241 	test(Math::IsNaN(res)); | 
|         |   2242 	test(Math::Int(res,KPosInfTReal64)==KErrOverflow); | 
|         |   2243 	test(res==KPosInfTReal64); | 
|         |   2244 	test(Math::Int(res,KNegInfTReal64)==KErrOverflow); | 
|         |   2245 	test(res==KNegInfTReal64); | 
|         |   2246  | 
|         |   2247     TInt i=sizeof(testint1)/sizeof(INT_TEST); | 
|         |   2248     for (TInt j=0;j<i;j++)  | 
|         |   2249 		{ | 
|         |   2250 		test(Math::Int(res,testint1[j].num)==KErrNone); | 
|         |   2251 		test(res==testint1[j].res); | 
|         |   2252 		} | 
|         |   2253  | 
|         |   2254 	// Check some denormals | 
|         |   2255 	test(Math::Int(res,5E-324)==KErrNone); | 
|         |   2256 	test(res==0.0); | 
|         |   2257 	test(Math::Int(res,1.45E-309)==KErrNone); | 
|         |   2258 	test(res==0.0); | 
|         |   2259     } | 
|         |   2260  | 
|         |   2261 LOCAL_C void inttest2() | 
|         |   2262 /* | 
|         |   2263 Tests specific numbers | 
|         |   2264 */ | 
|         |   2265     { | 
|         |   2266  | 
|         |   2267     TInt16 res; | 
|         |   2268  | 
|         |   2269 	// test errors | 
|         |   2270 	test(Math::Int(res,KNaNTReal64)==KErrArgument); | 
|         |   2271 	test(res==0); | 
|         |   2272 	test(Math::Int(res,KPosInfTReal64)==KErrOverflow); | 
|         |   2273 	test(res==TInt16(KMaxTInt16));	 | 
|         |   2274 	test(Math::Int(res,32768.9830857)==KErrOverflow); | 
|         |   2275 	test(res==TInt16(KMaxTInt16)); | 
|         |   2276 	test(Math::Int(res,32769.36946)==KErrOverflow); | 
|         |   2277 	test(res==TInt16(KMaxTInt16)); | 
|         |   2278 	test(Math::Int(res,KNegInfTReal64)==KErrUnderflow); | 
|         |   2279     test(res==TInt16(KMinTInt16)); | 
|         |   2280 	test(Math::Int(res,-32774.997937)==KErrUnderflow); | 
|         |   2281     test(res==TInt16(KMinTInt16)); | 
|         |   2282  | 
|         |   2283     TInt i=sizeof(testint2)/sizeof(INTI_TEST); | 
|         |   2284     for (TInt j=0;j<i;j++)  | 
|         |   2285 		{ | 
|         |   2286 		test(Math::Int(res,testint2[j].num)==KErrNone); | 
|         |   2287 		test(res==testint2[j].res);		 | 
|         |   2288 		} | 
|         |   2289  | 
|         |   2290 	// Check some denormals | 
|         |   2291 	test(Math::Int(res,5E-324)==KErrNone); | 
|         |   2292 	test(res==0.0); | 
|         |   2293 	test(Math::Int(res,1.45E-309)==KErrNone); | 
|         |   2294 	test(res==0.0); | 
|         |   2295 	} | 
|         |   2296  | 
|         |   2297 LOCAL_C void inttest3() | 
|         |   2298 /* | 
|         |   2299 Tests specific numbers | 
|         |   2300 */ | 
|         |   2301     { | 
|         |   2302  | 
|         |   2303     TInt32 res; | 
|         |   2304  | 
|         |   2305     // test errors | 
|         |   2306 	test(Math::Int(res,KNaNTReal64)==KErrArgument); | 
|         |   2307 	test(res==0); | 
|         |   2308 	test(Math::Int(res,KPosInfTReal64)==KErrOverflow); | 
|         |   2309 	test(res==KMaxTInt32); | 
|         |   2310 	test(Math::Int(res,2147483648.34576)==KErrOverflow); | 
|         |   2311 	test(res==KMaxTInt32); | 
|         |   2312     test(Math::Int(res,2147553576.8794365)==KErrOverflow); | 
|         |   2313 	test(res==KMaxTInt32); | 
|         |   2314     test(Math::Int(res,KNegInfTReal64)==KErrUnderflow); | 
|         |   2315 	test(res==KMinTInt32); | 
|         |   2316 	test(Math::Int(res,-2147496757.583)==KErrUnderflow); | 
|         |   2317 	test(res==KMinTInt32); | 
|         |   2318      | 
|         |   2319 	TInt i=sizeof(testint3)/sizeof(INTL_TEST); | 
|         |   2320     for (TInt j=0;j<i;j++)  | 
|         |   2321 		{ | 
|         |   2322 		test(Math::Int(res,testint3[j].num)==KErrNone); | 
|         |   2323 		test(res==testint3[j].res); | 
|         |   2324 		} | 
|         |   2325  | 
|         |   2326 	// Check some denormals | 
|         |   2327 	test(Math::Int(res,5E-324)==KErrNone); | 
|         |   2328 	test(res==0.0); | 
|         |   2329 	test(Math::Int(res,1.45E-309)==KErrNone); | 
|         |   2330 	test(res==0.0); | 
|         |   2331 	} | 
|         |   2332  | 
|         |   2333 LOCAL_C void inttest4() | 
|         |   2334 	{ | 
|         |   2335 	// tests Int() | 
|         |   2336 	TInt16 tint16; | 
|         |   2337 	TInt32 tint32; | 
|         |   2338 	TReal trg,src=100.0; | 
|         |   2339  | 
|         |   2340 	test.Start(_L("Math::Int()")); | 
|         |   2341 	src=0.0; | 
|         |   2342 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2343 	test(trg==0.0); | 
|         |   2344 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2345 	test(tint16==0); | 
|         |   2346 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2347 	test(tint32==0); | 
|         |   2348  | 
|         |   2349     src=0.1233456789; | 
|         |   2350 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2351 	test(trg==0.0); | 
|         |   2352 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2353 	test(tint16==0); | 
|         |   2354 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2355 	test(tint32==0); | 
|         |   2356  | 
|         |   2357 	src=-0.5; | 
|         |   2358 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2359 	test(trg==0.0); | 
|         |   2360 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2361 	test(tint16==0); | 
|         |   2362 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2363 	test(tint32==0); | 
|         |   2364  | 
|         |   2365 	src=1.123456789; | 
|         |   2366 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2367 	test(trg==1.0); | 
|         |   2368 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2369 	test(tint16==1); | 
|         |   2370 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2371 	test(tint32==1); | 
|         |   2372  | 
|         |   2373 	src=-1.12345678; | 
|         |   2374 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2375 	test(trg==-1.0); | 
|         |   2376 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2377 	test(tint16==-1); | 
|         |   2378 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2379 	test(tint32==-1); | 
|         |   2380  | 
|         |   2381 	src=KMaxTInt16-0.1;  | 
|         |   2382 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2383 	test(trg==KMaxTInt16-1); | 
|         |   2384 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2385 	test(tint16==KMaxTInt16-1); | 
|         |   2386 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2387 	test(tint32==KMaxTInt16-1); | 
|         |   2388  | 
|         |   2389 	src=KMaxTInt16+0.5;  | 
|         |   2390 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2391 	test(trg==KMaxTInt16); | 
|         |   2392 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2393 	test(tint16==KMaxTInt16); | 
|         |   2394 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2395 	test(tint32==KMaxTInt16); | 
|         |   2396  | 
|         |   2397 	src=KMaxTInt16+1;  | 
|         |   2398 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2399 	test(trg==KMaxTInt16+1); | 
|         |   2400 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2401 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2402 	test(tint32==KMaxTInt16+1); | 
|         |   2403  | 
|         |   2404 	src=KMinTInt16-0.1;  | 
|         |   2405 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2406 	test(trg==KMinTInt16); | 
|         |   2407 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2408 	test(tint16==KMinTInt16); | 
|         |   2409 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2410 	test(tint32==KMinTInt16); | 
|         |   2411  | 
|         |   2412 	src=KMinTInt16;  | 
|         |   2413 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2414 	test(trg==KMinTInt16); | 
|         |   2415 	test(Math::Int(tint16,src)==KErrNone); | 
|         |   2416 	test(tint16==KMinTInt16); | 
|         |   2417 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2418 	test(tint32==KMinTInt16); | 
|         |   2419  | 
|         |   2420 	src=KMinTInt16-1;  | 
|         |   2421 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2422 	test(trg==KMinTInt16-1); | 
|         |   2423 	test(Math::Int(tint16,src)==KErrUnderflow); | 
|         |   2424 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2425 	test(tint32==KMinTInt16-1); | 
|         |   2426  | 
|         |   2427 	src=KMaxTInt32-0.1;  | 
|         |   2428 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2429 	test(trg==KMaxTInt32-1); | 
|         |   2430 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2431 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2432 	test(tint32==KMaxTInt32-1); | 
|         |   2433  | 
|         |   2434 	src=KMaxTInt32+0.5;  | 
|         |   2435 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2436 	test(trg==KMaxTInt32); | 
|         |   2437 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2438 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2439 	test(tint32==KMaxTInt32); | 
|         |   2440  | 
|         |   2441 	src=KMaxTInt32;  | 
|         |   2442 	src+=1; | 
|         |   2443 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2444 	test(trg==(TUint32)KMaxTInt32+1); | 
|         |   2445 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2446 	test(Math::Int(tint32,src)==KErrOverflow); | 
|         |   2447  | 
|         |   2448 	src=KMinTInt32+0.1;  | 
|         |   2449 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2450 	test(trg==KMinTInt32+1); | 
|         |   2451 	test(Math::Int(tint16,src)==KErrUnderflow); | 
|         |   2452 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2453 	test(tint32==KMinTInt32+1); | 
|         |   2454  | 
|         |   2455 	src=KMinTInt32;  | 
|         |   2456 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2457 	test(trg==KMinTInt32); | 
|         |   2458 	test(Math::Int(tint16,src)==KErrUnderflow); | 
|         |   2459 	test(Math::Int(tint32,src)==KErrNone); | 
|         |   2460 	test(tint32==KMinTInt32); | 
|         |   2461  | 
|         |   2462 	src=KMinTInt32; | 
|         |   2463 	src-=1;  | 
|         |   2464 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2465 	test((trg+1)==KMinTInt32); | 
|         |   2466 	test(Math::Int(tint16,src)==KErrUnderflow); | 
|         |   2467 	test(Math::Int(tint32,src)==KErrUnderflow); | 
|         |   2468  | 
|         |   2469 	src=KMaxTUint32-0.1; | 
|         |   2470 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2471 	test(trg==KMaxTUint32-1); | 
|         |   2472 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2473 	test(Math::Int(tint32,src)==KErrOverflow); | 
|         |   2474  | 
|         |   2475 	src=KMaxTUint32; | 
|         |   2476 	test(Math::Int(trg,src)==KErrNone);   | 
|         |   2477 	test(trg==KMaxTUint32); | 
|         |   2478 	test(Math::Int(tint16,src)==KErrOverflow); | 
|         |   2479 	test(Math::Int(tint32,src)==KErrOverflow); | 
|         |   2480  | 
|         |   2481 	test.End(); | 
|         |   2482 	} | 
|         |   2483  | 
|         |   2484 LOCAL_C void fractest1() | 
|         |   2485 /* | 
|         |   2486 Tests specific numbers | 
|         |   2487 */ | 
|         |   2488     { | 
|         |   2489  | 
|         |   2490     TReal res; | 
|         |   2491  | 
|         |   2492 	// test errors | 
|         |   2493 	test(Math::Frac(res,KNaNTReal64)==KErrArgument); | 
|         |   2494 	test(Math::IsNaN(res)); | 
|         |   2495 	test(Math::Frac(res,KPosInfTReal64)==KErrOverflow); | 
|         |   2496 	test(res==0.0); | 
|         |   2497 	test(Math::Frac(res,KNegInfTReal64)==KErrOverflow); | 
|         |   2498 	test(res==0.0); | 
|         |   2499  | 
|         |   2500     TInt i=sizeof(testfrac)/sizeof(FRAC_TEST); | 
|         |   2501     for (TInt j=0;j<i;j++)  | 
|         |   2502 		{ | 
|         |   2503 		test(Math::Frac(res,testfrac[j].num)==KErrNone); | 
|         |   2504 		TReal err=(res-testfrac[j].res); | 
|         |   2505 		if (res) | 
|         |   2506 			err/=testfrac[j].num;	// NB num not res | 
|         |   2507 		test(Abs(err)<1.0E-15); | 
|         |   2508 		} | 
|         |   2509  | 
|         |   2510 	// Check some denormals | 
|         |   2511 	test(Math::Frac(res,5E-324)==KErrNone); | 
|         |   2512 	test(res==5E-324); | 
|         |   2513 	test(Math::Frac(res,1.23456789E-314)==KErrNone); | 
|         |   2514 	test(res==1.23456789E-314); | 
|         |   2515     } | 
|         |   2516  | 
|         |   2517 LOCAL_C void fractest2() | 
|         |   2518 	{ | 
|         |   2519 	// tests Frac()  | 
|         |   2520 	test.Start(_L("Math::Frac()")); | 
|         |   2521 	TReal trg,src; | 
|         |   2522  | 
|         |   2523 	src=0.0; | 
|         |   2524 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2525 	test(trg==0.0); | 
|         |   2526  | 
|         |   2527 	src=0.1; | 
|         |   2528 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2529 	test(trg==0.1); | 
|         |   2530  | 
|         |   2531 	src=-0.1; | 
|         |   2532 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2533 	test(trg==-0.1); | 
|         |   2534  | 
|         |   2535 	src=7.5; | 
|         |   2536 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2537 	test(trg==0.5); | 
|         |   2538  | 
|         |   2539 	src=-7.5; | 
|         |   2540 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2541 	test(trg==-0.5); | 
|         |   2542  | 
|         |   2543 	src=5.998046875; | 
|         |   2544 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2545 	test(trg==0.998046875); | 
|         |   2546  | 
|         |   2547 	src=-5.998046875; | 
|         |   2548 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2549 	test(trg==-0.998046875); | 
|         |   2550  | 
|         |   2551 	src=-0.00000000001; | 
|         |   2552 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2553 	test(trg==-0.00000000001); | 
|         |   2554  | 
|         |   2555 	src=1000000000000.5; | 
|         |   2556 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2557 	test(trg==0.5); | 
|         |   2558  | 
|         |   2559 	src=1099511627776.0; | 
|         |   2560 	src+=0.000244140625; | 
|         |   2561 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2562 	test(trg==0.000244140625); | 
|         |   2563  | 
|         |   2564 	src=-KMaxTInt32; | 
|         |   2565 	src+=0.5; | 
|         |   2566 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2567 	test(trg==-0.5); | 
|         |   2568  | 
|         |   2569 	src=KMaxTUint32; | 
|         |   2570 	src+=0.5; | 
|         |   2571 	test(Math::Frac(trg,src)==KErrNone); | 
|         |   2572 	test(trg==0.5); | 
|         |   2573  | 
|         |   2574 	test.End(); | 
|         |   2575 	} | 
|         |   2576  | 
|         |   2577 LOCAL_C void modtest1() | 
|         |   2578 /* | 
|         |   2579 Test modulo function using specified values | 
|         |   2580 */ | 
|         |   2581     { | 
|         |   2582  | 
|         |   2583     TReal res; | 
|         |   2584  | 
|         |   2585 	// test errors | 
|         |   2586 	test(Math::Mod(res,KNaNTReal64,1.0)==KErrArgument); | 
|         |   2587 	test(Math::IsNaN(res)); | 
|         |   2588 	test(Math::Mod(res,1.0,KNaNTReal64)==KErrArgument); | 
|         |   2589 	test(Math::IsNaN(res)); | 
|         |   2590 	test(Math::Mod(res,KNaNTReal64,KNaNTReal64)==KErrArgument); | 
|         |   2591 	test(Math::IsNaN(res)); | 
|         |   2592 	test(Math::Mod(res,KPosInfTReal64,2.0)==KErrArgument); | 
|         |   2593 	test(Math::IsNaN(res)); | 
|         |   2594 	test(Math::Mod(res,KNegInfTReal64,2.0)==KErrArgument); | 
|         |   2595 	test(Math::IsNaN(res)); | 
|         |   2596 	test(Math::Mod(res,2.0,KNegZeroTReal64)==KErrArgument); | 
|         |   2597 	test(Math::IsNaN(res)); | 
|         |   2598 	test(Math::Mod(res,1.0,0.0)==KErrArgument); | 
|         |   2599 	test(Math::IsNaN(res)); | 
|         |   2600  | 
|         |   2601     TInt i=sizeof(testmod)/sizeof(MOD_TEST); | 
|         |   2602     for (TInt j=0;j<i;j++)  | 
|         |   2603 		{ | 
|         |   2604 		test(Math::Mod(res,testmod[j].num,testmod[j].mod)==KErrNone); | 
|         |   2605 		test(testApprox(res,testmod[j].res,5.0E-13));		 | 
|         |   2606 		} | 
|         |   2607  | 
|         |   2608 	// Check some denormals | 
|         |   2609  	test(Math::Mod(res,K1Point2EMinus320Real64,K5EMinus321Real64)==KErrNone); | 
|         |   2610  	test(res==K2EMinus321Real64);		 | 
|         |   2611  	test(Math::Mod(res,K1Point234EMinus316Real64,K1Point234EMinus316Real64)==KErrNone); | 
|         |   2612 	test(res==0.0);		 | 
|         |   2613     } | 
|         |   2614  | 
|         |   2615 LOCAL_C void modtest2() | 
|         |   2616 /* | 
|         |   2617 Test modulo function for values which will be incorrect so return KErrTotalLossOfPrecision | 
|         |   2618 */ | 
|         |   2619     { | 
|         |   2620  | 
|         |   2621     TReal res; | 
|         |   2622  | 
|         |   2623 	TInt i=sizeof(testmod2)/sizeof(MOD_TEST); | 
|         |   2624     for (TInt j=0;j<i;j++)  | 
|         |   2625 		{ | 
|         |   2626 		test(Math::Mod(res,testmod2[j].num,testmod2[j].mod)==KErrTotalLossOfPrecision); | 
|         |   2627 		test(Math::IsZero(res)); | 
|         |   2628 		} | 
|         |   2629 	} | 
|         |   2630  | 
|         |   2631 LOCAL_C void DuplicateTest() | 
|         |   2632 // | 
|         |   2633 // Tests that you can use the same variable for both operands in some Math functions | 
|         |   2634 // NB results only given to 12 or 13 significant figures so cannot expect better accuracy | 
|         |   2635 // | 
|         |   2636 	{ | 
|         |   2637  | 
|         |   2638 	TReal inOut; | 
|         |   2639 	test.Start(_L("ACos")); | 
|         |   2640 	inOut=-0.5; | 
|         |   2641 	test(Math::ACos(inOut,inOut)==KErrNone); | 
|         |   2642 	test(testApprox(inOut,2.094395102393,1.0E-13));			 | 
|         |   2643  | 
|         |   2644 	test.Next(_L("ASin")); | 
|         |   2645 	inOut=-0.5; | 
|         |   2646 	test(Math::ASin(inOut,inOut)==KErrNone); | 
|         |   2647 	test(testApprox(inOut,-0.523598775598,6.0E-13));			 | 
|         |   2648  | 
|         |   2649 	test.Next(_L("ATan")); | 
|         |   2650 	inOut=0.5; | 
|         |   2651 	test(Math::ATan(inOut,inOut)==KErrNone); | 
|         |   2652 	test(testApprox(inOut,0.463647609001,5.0E-13));			 | 
|         |   2653 	inOut=-0.25; | 
|         |   2654 	TReal another=-0.5; | 
|         |   2655 	test(Math::ATan(inOut,inOut,another)==KErrNone); | 
|         |   2656 	test(testApprox(inOut,-2.677945044589,5.0E-15));			 | 
|         |   2657 	inOut=-0.5; | 
|         |   2658 	another=0.25; | 
|         |   2659 	test(Math::ATan(inOut,another,inOut)==KErrNone); | 
|         |   2660 	test(testApprox(inOut,2.677945044589,5.0E-15));			 | 
|         |   2661  | 
|         |   2662 	test.Next(_L("Cos")); | 
|         |   2663 	inOut=1; | 
|         |   2664 	test(Math::Cos(inOut,inOut)==KErrNone); | 
|         |   2665 	test(testApprox(inOut,0.540302305868,3.0E-13));			 | 
|         |   2666  | 
|         |   2667 	test.Next(_L("Exp")); | 
|         |   2668 	inOut=0.5; | 
|         |   2669 	test(Math::Exp(inOut,inOut)==KErrNone); | 
|         |   2670 	test(testApprox(inOut,1.648721270700,1.0E-13));			 | 
|         |   2671  | 
|         |   2672 	test.Next(_L("Frac")); | 
|         |   2673 	inOut=56.123456789; | 
|         |   2674 	test(Math::Frac(inOut,inOut)==KErrNone); | 
|         |   2675 	test(testApprox(inOut,0.123456789,2.0E-14)); | 
|         |   2676  | 
|         |   2677 	test.Next(_L("Int")); | 
|         |   2678 	inOut=56.123456789; | 
|         |   2679 	test(Math::Int(inOut,inOut)==KErrNone); | 
|         |   2680 	test(inOut==56); | 
|         |   2681 	 | 
|         |   2682 	test.Next(_L("Log")); | 
|         |   2683 	inOut=0.5; | 
|         |   2684 	test(Math::Log(inOut,inOut)==KErrNone); | 
|         |   2685 	test(testApprox(inOut,-0.301029995664,7.0E-14));				 | 
|         |   2686  | 
|         |   2687 	test.Next(_L("Ln")); | 
|         |   2688 	inOut=0.5; | 
|         |   2689 	test(Math::Ln(inOut,inOut)==KErrNone); | 
|         |   2690 	test(testApprox(inOut,-0.693147180560,8.0E-14));				 | 
|         |   2691  | 
|         |   2692 	test.Next(_L("Mod")); | 
|         |   2693 	inOut=53; | 
|         |   2694 	another=17; | 
|         |   2695 	test(Math::Mod(inOut,inOut,another)==KErrNone); | 
|         |   2696 	test(inOut==2); | 
|         |   2697 	inOut=17; | 
|         |   2698 	another=53; | 
|         |   2699 	test(Math::Mod(inOut,another,inOut)==KErrNone); | 
|         |   2700 	test(inOut==2); | 
|         |   2701  | 
|         |   2702 	test.Next(_L("Pow")); | 
|         |   2703 	inOut=-5; | 
|         |   2704 	another=3; | 
|         |   2705 	test(Math::Pow(inOut,inOut,another)==KErrNone); | 
|         |   2706 	test(inOut==-125.0); | 
|         |   2707 	another=-5; | 
|         |   2708 	inOut=3; | 
|         |   2709 	test(Math::Pow(inOut,another,inOut)==KErrNone); | 
|         |   2710 	test(inOut==-125.0); | 
|         |   2711  | 
|         |   2712 	test.Next(_L("Sin")); | 
|         |   2713 	inOut=1; | 
|         |   2714 	test(Math::Sin(inOut,inOut)==KErrNone); | 
|         |   2715 	test(testApprox(inOut,0.84147098480790,5.0E-15));				 | 
|         |   2716  | 
|         |   2717 	test.Next(_L("Round")); | 
|         |   2718 	inOut=123.4567; | 
|         |   2719 	test(Math::Round(inOut,inOut,2)==KErrNone); | 
|         |   2720 	test(testApprox(inOut,123.46,1.0E-15));				 | 
|         |   2721  | 
|         |   2722 	test.Next(_L("Sqrt")); | 
|         |   2723 	inOut=53; | 
|         |   2724 	test(Math::Sqrt(inOut,inOut)==KErrNone); | 
|         |   2725 	test(testApprox(inOut,7.280109889281,7.0E-14));				 | 
|         |   2726  | 
|         |   2727 	test.Next(_L("Tan")); | 
|         |   2728 	inOut=1; | 
|         |   2729 	test(Math::Tan(inOut,inOut)==KErrNone); | 
|         |   2730 	test(testApprox(inOut,1.557407724655,7.0E-14));				 | 
|         |   2731  | 
|         |   2732 	test.End(); | 
|         |   2733 	} | 
|         |   2734  | 
|         |   2735 LOCAL_C void specialtest() | 
|         |   2736 // | 
|         |   2737 // Tests functions which test for specials | 
|         |   2738 //  | 
|         |   2739 	{ | 
|         |   2740  | 
|         |   2741 	test(Math::IsZero(0.0)); | 
|         |   2742 	test(Math::IsZero(KNegZeroTReal64)); | 
|         |   2743 	test(Math::IsZero(0.0)); | 
|         |   2744 	test(!Math::IsZero(1.0)); | 
|         |   2745 	test(!Math::IsZero(KPosInfTReal64)); | 
|         |   2746 	test(!Math::IsZero(KNaNTReal64)); | 
|         |   2747  	test(!Math::IsZero(K5EMinus324Real64)); | 
|         |   2748  | 
|         |   2749 	test(Math::IsNaN(KNaNTReal64)); | 
|         |   2750 	test(!Math::IsNaN(KPosInfTReal64)); | 
|         |   2751 	test(!Math::IsNaN(KNegInfTReal64)); | 
|         |   2752 	test(!Math::IsNaN(0.0)); | 
|         |   2753 	test(!Math::IsNaN(1.0)); | 
|         |   2754  | 
|         |   2755 	test(Math::IsInfinite(KPosInfTReal64)); | 
|         |   2756 	test(Math::IsInfinite(KNegInfTReal64)); | 
|         |   2757 	test(!Math::IsInfinite(KNaNTReal64)); | 
|         |   2758 	test(!Math::IsInfinite(0.0)); | 
|         |   2759 	test(!Math::IsInfinite(KMaxTReal64)); | 
|         |   2760  | 
|         |   2761 	test(!Math::IsFinite(KPosInfTReal64)); | 
|         |   2762 	test(!Math::IsFinite(KNegInfTReal64)); | 
|         |   2763 	test(!Math::IsFinite(KNaNTReal64)); | 
|         |   2764 	test(Math::IsFinite(0.0)); | 
|         |   2765 	test(Math::IsFinite(KMaxTReal64)); | 
|         |   2766 	test(Math::IsFinite(5E-324));	 | 
|         |   2767 	test(Math::IsFinite(1.0)); | 
|         |   2768 	} | 
|         |   2769  | 
|         |   2770 void _matherr(TExcType aType) | 
|         |   2771 // | 
|         |   2772 // Dummy function to handle exceptions | 
|         |   2773 // | 
|         |   2774 	{ | 
|         |   2775  | 
|         |   2776 	test.Printf(_L("_matherr: Exception type %u handled\n"),TUint(aType)); | 
|         |   2777 	} | 
|         |   2778  | 
|         |   2779 #ifdef __GCC32__ | 
|         |   2780 #define FSTCW(x) asm("mov eax, %0\nfstcw [eax]": : "i"(&x)) | 
|         |   2781 #define FLDCW(x) asm("mov eax, %0\nfldcw [eax]": : "i"(&x)) | 
|         |   2782 #else | 
|         |   2783 #define FSTCW(x) _asm fstcw x | 
|         |   2784 #define FLDCW(x) _asm fldcw x | 
|         |   2785 #endif | 
|         |   2786 TInt16 cw=0; // must be global or GCC/GAS can't get the address! | 
|         |   2787  | 
|         |   2788 GLDEF_C TInt E32Main() | 
|         |   2789     {      | 
|         |   2790  | 
|         |   2791 #if defined (__X86__) | 
|         |   2792 	FSTCW(cw); | 
|         |   2793 	test.Printf(_L("control word = 0x%x\n"),cw); | 
|         |   2794 	cw=0x27f;	// WINS value | 
|         |   2795 	FLDCW(cw); | 
|         |   2796 #endif | 
|         |   2797  | 
|         |   2798 	test.Title(); | 
|         |   2799  | 
|         |   2800 	test.Start(_L("Assorted tests")); | 
|         |   2801 	AssortedTests(); | 
|         |   2802  | 
|         |   2803 	test.Next(_L("sqrtest1(KSqhf,1.0)")); | 
|         |   2804     sqrtest1(KSqhf,1.0); | 
|         |   2805 	test.Next(_L("sqrtest1(1.0,1.41421356238)")); | 
|         |   2806     sqrtest1(1.0,1.41421356238); | 
|         |   2807 	test.Next(_L("sqrtest2")); | 
|         |   2808     sqrtest2();                   | 
|         |   2809  | 
|         |   2810 	test.Next(_L("logtest")); | 
|         |   2811     logtest(); | 
|         |   2812 	test.Next(_L("lntest1")); | 
|         |   2813     lntest1(); | 
|         |   2814 	test.Next(_L("lntest2")); | 
|         |   2815     lntest2(); | 
|         |   2816 	test.Next(_L("lntest3")); | 
|         |   2817     lntest3(); | 
|         |   2818 	test.Next(_L("lntest4")); | 
|         |   2819     lntest4(); | 
|         |   2820  | 
|         |   2821 	test.Next(_L("exptest1")); | 
|         |   2822     exptest1(); | 
|         |   2823 	test.Next(_L("exptest2(-0.0625,-.9375,1.0625)")); | 
|         |   2824     exptest2(-0.0625,-0.9375,1.0625); | 
|         |   2825 	test.Next(_L("exptest2(-29.0/16.0),1.0,88.0)")); | 
|         |   2826     exptest2((-29.0/16.0),1.0,88.0); | 
|         |   2827 	test.Next(_L("exptest2(-29.0/16.0),-1.0,-88.0)")); | 
|         |   2828     exptest2((-29.0/16.0),-1.0,-88.0); | 
|         |   2829 	test.Next(_L("exptest3")); | 
|         |   2830     exptest3(); | 
|         |   2831  | 
|         |   2832 	test.Next(_L("powtest1")); | 
|         |   2833     powtest1(); | 
|         |   2834 	test.Next(_L("powtest2(.5,1.0)")); | 
|         |   2835     powtest2(.5,1.0); | 
|         |   2836 	test.Next(_L("powtest2(1.0,1.0E33)")); | 
|         |   2837     powtest2(1.0,1.0E33); | 
|         |   2838 	test.Next(_L("powtest3")); | 
|         |   2839     powtest3(); | 
|         |   2840 	test.Next(_L("powtest4")); | 
|         |   2841     powtest4(); | 
|         |   2842 	test.Next(_L("powtest5")); | 
|         |   2843     powtest5(); | 
|         |   2844 	test.Next(_L("powtest6")); | 
|         |   2845     powtest6(); | 
|         |   2846 	 | 
|         |   2847 	test.Next(_L("pow10test")); | 
|         |   2848 	pow10test(); | 
|         |   2849 														 | 
|         |   2850 	test.Next(_L("sintest1(3*KPi,3.5*KPi)")); | 
|         |   2851     sintest1(3*KPi,3.5*KPi); | 
|         |   2852 	test.Next(_L("sintest1(3*KPi,3.5*KPi)")); | 
|         |   2853     sintest1(6*KPi,6.5*KPi); | 
|         |   2854 	test.Next(_L("sintest2")); | 
|         |   2855     sintest2(); | 
|         |   2856 	test.Next(_L("sintest3"));     | 
|         |   2857 	sintest3(); | 
|         |   2858 	test.Next(_L("sintest4")); | 
|         |   2859     sintest4(); | 
|         |   2860 //	test.Next(_L("sintest5"));		// this test is no longer valid | 
|         |   2861 //	sintest5(); | 
|         |   2862  | 
|         |   2863 	test.Next(_L("costest1")); | 
|         |   2864 	costest1(); | 
|         |   2865 	test.Next(_L("costest2")); | 
|         |   2866 	costest2(); | 
|         |   2867 	test.Next(_L("costest3")); | 
|         |   2868 	costest3(); | 
|         |   2869 	test.Next(_L("costest4")); | 
|         |   2870 	costest4(); | 
|         |   2871 //	test.Next(_L("costest5"));		// this test is no longer valid | 
|         |   2872 //	costest5(); | 
|         |   2873  | 
|         |   2874 	test.Next(_L("tantest1(-.25*KPi,.25*KPi)"));                                             | 
|         |   2875     tantest1(-.25*KPi,.25*KPi); | 
|         |   2876 	test.Next(_L("tantest1(.875*KPi,1.125*KPi)")); | 
|         |   2877     tantest1(.875*KPi,1.125*KPi); | 
|         |   2878 	test.Next(_L("tantest1(6*KPi,6.25*KPi)")); | 
|         |   2879     tantest1(6*KPi,6.25*KPi); | 
|         |   2880 	test.Next(_L("tantest2")); | 
|         |   2881     tantest2();    | 
|         |   2882 	test.Next(_L("tantest3")); | 
|         |   2883     tantest3(); | 
|         |   2884 	test.Next(_L("tantest4")); | 
|         |   2885     tantest4(); | 
|         |   2886 //	test.Next(_L("tantest5"));		// this test is no longer valid | 
|         |   2887 //	tantest5(); | 
|         |   2888  | 
|         |   2889 	test.Next(_L("astest1(-.125,0.125,15,0)")); | 
|         |   2890     astest1(-.125,0.125,15,0); | 
|         |   2891 	test.Next(_L("astest1(-.125,0.125,15,1)")); | 
|         |   2892     astest1(-.125,0.125,15,1); | 
|         |   2893 	test.Next(_L("astest2")); | 
|         |   2894     astest2(); | 
|         |   2895 	test.Next(_L("astest3")); | 
|         |   2896     astest3(); | 
|         |   2897 	test.Next(_L("astest4(0,1)")); | 
|         |   2898     astest4(0,1); | 
|         |   2899 	test.Next(_L("astest4(1,1)")); | 
|         |   2900     astest4(1,1); | 
|         |   2901 	test.Next(_L("astest4(1,-1)")); | 
|         |   2902     astest4(1,-1); | 
|         |   2903 		   | 
|         |   2904 	test.Next(_L("attest1")); | 
|         |   2905     attest1(); | 
|         |   2906 	test.Next(_L("attest2")); | 
|         |   2907     attest2(); | 
|         |   2908 	test.Next(_L("attest3")); | 
|         |   2909     attest3(); | 
|         |   2910 	test.Next(_L("attest4")); | 
|         |   2911     attest4(); | 
|         |   2912 	test.Next(_L("attest5")); | 
|         |   2913     attest5(); | 
|         |   2914  | 
|         |   2915     test.Next(_L("inttest1")); | 
|         |   2916     inttest1();	 | 
|         |   2917 	test.Next(_L("intitest2")); | 
|         |   2918     inttest2();	 | 
|         |   2919 	test.Next(_L("inttest3")); | 
|         |   2920     inttest3();	 | 
|         |   2921 	test.Next(_L("inttest4")); | 
|         |   2922 	inttest4();	 | 
|         |   2923  | 
|         |   2924 	test.Next(_L("fractest1")); | 
|         |   2925     fractest1();	 | 
|         |   2926 	test.Next(_L("fractest2")); | 
|         |   2927 	fractest2(); | 
|         |   2928  | 
|         |   2929 	test.Next(_L("modtest1")); | 
|         |   2930     modtest1(); | 
|         |   2931 	test.Next(_L("modtest2")); | 
|         |   2932     modtest2(); | 
|         |   2933  | 
|         |   2934 	test.Next(_L("Test duplicate parameters")); | 
|         |   2935 	DuplicateTest(); | 
|         |   2936  | 
|         |   2937 	test.Next(_L("Test Math::Is...() functions")); | 
|         |   2938 	specialtest(); | 
|         |   2939  | 
|         |   2940 	test.End(); | 
|         |   2941 	return(KErrNone); | 
|         |   2942     } | 
|         |   2943  |