5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25 /*
26 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
27 * Use is subject to license terms.
28 */
29
30 #pragma weak __catanl = catanl
31
32 /* INDENT OFF */
33 /*
34 * ldcomplex catanl(ldcomplex z);
35 *
36 * Atan(z) return A + Bi where,
37 * 1
38 * A = --- * atan2(2x, 1-x*x-y*y)
39 * 2
40 *
41 * 1 [ x*x + (y+1)*(y+1) ] 1 4y
42 * B = --- log [ ----------------- ] = - log (1+ -----------------)
43 * 4 [ x*x + (y-1)*(y-1) ] 4 x*x + (y-1)*(y-1)
44 *
45 * 2 16 3 y
46 * = t - 2t + -- t - ..., where t = -----------------
47 * 3 x*x + (y-1)*(y-1)
48 * Proof:
49 * Let w = atan(z=x+yi) = A + B i. Then tan(w) = z.
50 * Since sin(w) = (exp(iw)-exp(-iw))/(2i), cos(w)=(exp(iw)+exp(-iw))/(2),
51 * Let p = exp(iw), then z = tan(w) = ((p-1/p)/(p+1/p))/i, or
52 * iz = (p*p-1)/(p*p+1), or, after simplification,
82 * catan(-x, y) = (-u, v)
83 * catan( x,-y) = ( u,-v)
84 *
85 * Also, catan(x,y) = -i*catanh(-y,x), or
86 * catanh(x,y) = i*catan(-y,x)
87 * So, if catanh(y,x) = (v,u), then catan(x,y) = -i*(-v,u) = (u,v), i.e.,
88 * catan(x,y) = (u,v)
89 *
90 * EXCEPTION CASES (conform to ISO/IEC 9899:1999(E)):
91 * catan( 0 , 0 ) = (0 , 0 )
92 * catan( NaN, 0 ) = (NaN , 0 )
93 * catan( 0 , 1 ) = (0 , +inf) with divide-by-zero
94 * catan( inf, y ) = (pi/2 , 0 ) for finite +y
95 * catan( NaN, y ) = (NaN , NaN ) with invalid for finite y != 0
96 * catan( x , inf ) = (pi/2 , 0 ) for finite +x
97 * catan( inf, inf ) = (pi/2 , 0 )
98 * catan( NaN, inf ) = (NaN , 0 )
99 * catan( x , NaN ) = (NaN , NaN ) with invalid for finite x
100 * catan( inf, NaN ) = (pi/2 , +-0 )
101 */
102 /* INDENT ON */
103
104 #include "libm.h" /* atan2l/atanl/fabsl/isinfl/iszerol/log1pl/logl */
105 #include "complex_wrapper.h"
106 #include "longdouble.h"
107
108 /* INDENT OFF */
109 static const long double
110 zero = 0.0L,
111 one = 1.0L,
112 two = 2.0L,
113 half = 0.5L,
114 ln2 = 6.931471805599453094172321214581765680755e-0001L,
115 pi_2 = 1.570796326794896619231321691639751442098584699687552910487472L,
116 #if defined(__x86)
117 E = 2.910383045673370361328125000000000000000e-11L, /* 2**-35 */
118 Einv = 3.435973836800000000000000000000000000000e+10L; /* 2**+35 */
119 #else
120 E = 8.673617379884035472059622406959533691406e-19L, /* 2**-60 */
121 Einv = 1.152921504606846976000000000000000000000e18L; /* 2**+60 */
122 #endif
123 /* INDENT ON */
124
125 ldcomplex
126 catanl(ldcomplex z) {
127 ldcomplex ans;
128 long double x, y, t1, ax, ay, t;
129 int hx, hy, ix, iy;
130
131 x = LD_RE(z);
132 y = LD_IM(z);
133 ax = fabsl(x);
134 ay = fabsl(y);
135 hx = HI_XWORD(x);
136 hy = HI_XWORD(y);
137 ix = hx & 0x7fffffff;
138 iy = hy & 0x7fffffff;
139
140 /* x is inf or NaN */
141 if (ix >= 0x7fff0000) {
142 if (isinfl(x)) {
143 LD_RE(ans) = pi_2;
144 LD_IM(ans) = zero;
145 } else {
146 LD_RE(ans) = x + x;
147 if (iszerol(y) || (isinfl(y)))
148 LD_IM(ans) = zero;
149 else
150 LD_IM(ans) = (fabsl(y) - ay) / (fabsl(y) - ay);
151 }
152 } else if (iy >= 0x7fff0000) {
153 /* y is inf or NaN */
154 if (isinfl(y)) {
155 LD_RE(ans) = pi_2;
156 LD_IM(ans) = zero;
157 } else {
158 LD_RE(ans) = (fabsl(x) - ax) / (fabsl(x) - ax);
159 LD_IM(ans) = y;
160 }
161 } else if (iszerol(x)) {
162 /* INDENT OFF */
163 /*
164 * x = 0
165 * 1 1
166 * A = --- * atan2(2x, 1-x*x-y*y) = --- atan2(0,1-|y|)
167 * 2 2
168 *
169 * 1 [ (y+1)*(y+1) ] 1 2 1 2y
170 * B = - log [ ----------- ] = - log (1+ ---) or - log(1+ ----)
171 * 4 [ (y-1)*(y-1) ] 2 y-1 2 1-y
172 */
173 /* INDENT ON */
174 t = one - ay;
175 if (ay == one) {
176 /* y=1: catan(0,1)=(0,+inf) with 1/0 signal */
177 LD_IM(ans) = ay / ax;
178 LD_RE(ans) = zero;
179 } else if (ay > one) { /* y>1 */
180 LD_IM(ans) = half * log1pl(two / (-t));
181 LD_RE(ans) = pi_2;
182 } else { /* y<1 */
183 LD_IM(ans) = half * log1pl((ay + ay) / t);
184 LD_RE(ans) = zero;
185 }
186 } else if (ay < E * (one + ax)) {
187 /* INDENT OFF */
188 /*
189 * Tiny y (relative to 1+|x|)
190 * |y| < E*(1+|x|)
191 * where E=2**-29, -35, -60 for double, extended, quad precision
192 *
193 * 1 [x<=1: atan(x)
194 * A = - * atan2(2x,1-x*x-y*y) ~ [ 1 1+x
195 * 2 [x>=1: - atan2(2,(1-x)*(-----))
196 * 2 x
197 *
198 * y/x
199 * B ~ t*(1-2t), where t = ----------------- is tiny
200 * x + (y-1)*(y-1)/x
201 *
202 * y
203 * (when x < 2**-60, t = ----------- )
204 * (y-1)*(y-1)
205 */
206 /* INDENT ON */
207 if (ay == zero)
208 LD_IM(ans) = ay;
209 else {
210 t1 = ay - one;
211 if (ix < 0x3fc30000)
212 t = ay / (t1 * t1);
213 else if (ix > 0x403b0000)
214 t = (ay / ax) / ax;
215 else
216 t = ay / (ax * ax + t1 * t1);
217 LD_IM(ans) = t * (one - two * t);
218 }
219 if (ix < 0x3fff0000)
220 LD_RE(ans) = atanl(ax);
221 else
222 LD_RE(ans) = half * atan2l(two, (one - ax) * (one +
223 one / ax));
224
225 } else if (ay > Einv * (one + ax)) {
226 /* INDENT OFF */
227 /*
228 * Huge y relative to 1+|x|
229 * |y| > Einv*(1+|x|), where Einv~2**(prec/2+3),
230 * 1
231 * A ~ --- * atan2(2x, -y*y) ~ pi/2
232 * 2
233 * y
234 * B ~ t*(1-2t), where t = --------------- is tiny
235 * (y-1)*(y-1)
236 */
237 /* INDENT ON */
238 LD_RE(ans) = pi_2;
239 t = (ay / (ay - one)) / (ay - one);
240 LD_IM(ans) = t * (one - (t + t));
241 } else if (ay == one) {
242 /* INDENT OFF */
243 /*
244 * y=1
245 * 1 1
246 * A = - * atan2(2x, -x*x) = --- atan2(2,-x)
247 * 2 2
248 *
249 * 1 [ x*x+4] 1 4 [ 0.5(log2-logx) if
250 * B = - log [ -----] = - log (1+ ---) = [ |x|<E, else 0.25*
251 * 4 [ x*x ] 4 x*x [ log1p((2/x)*(2/x))
252 */
253 /* INDENT ON */
254 LD_RE(ans) = half * atan2l(two, -ax);
255 if (ax < E)
256 LD_IM(ans) = half * (ln2 - logl(ax));
257 else {
258 t = two / ax;
259 LD_IM(ans) = 0.25L * log1pl(t * t);
260 }
261 } else if (ax > Einv * Einv) {
262 /* INDENT OFF */
263 /*
264 * Huge x:
265 * when |x| > 1/E^2,
266 * 1 pi
267 * A ~ --- * atan2(2x, -x*x-y*y) ~ ---
268 * 2 2
269 * y y/x
270 * B ~ t*(1-2t), where t = --------------- = (-------------- )/x
271 * x*x+(y-1)*(y-1) 1+((y-1)/x)^2
272 */
273 /* INDENT ON */
274 LD_RE(ans) = pi_2;
275 t = ((ay / ax) / (one + ((ay - one) / ax) * ((ay - one) /
276 ax))) / ax;
277 LD_IM(ans) = t * (one - (t + t));
278 } else if (ax < E * E * E * E) {
279 /* INDENT OFF */
280 /*
281 * Tiny x:
282 * when |x| < E^4, (note that y != 1)
283 * 1 1
284 * A = --- * atan2(2x, 1-x*x-y*y) ~ --- * atan2(2x,1-y*y)
285 * 2 2
286 *
287 * 1 [ (y+1)*(y+1) ] 1 2 1 2y
288 * B = - log [ ----------- ] = - log (1+ ---) or - log(1+ ----)
289 * 4 [ (y-1)*(y-1) ] 2 y-1 2 1-y
290 */
291 /* INDENT ON */
292 LD_RE(ans) = half * atan2l(ax + ax, (one - ay) * (one + ay));
293 if (ay > one) /* y>1 */
294 LD_IM(ans) = half * log1pl(two / (ay - one));
295 else /* y<1 */
296 LD_IM(ans) = half * log1pl((ay + ay) / (one - ay));
297 } else {
298 /* INDENT OFF */
299 /*
300 * normal x,y
301 * 1
302 * A = --- * atan2(2x, 1-x*x-y*y)
303 * 2
304 *
305 * 1 [ x*x+(y+1)*(y+1) ] 1 4y
306 * B = - log [ --------------- ] = - log (1+ -----------------)
307 * 4 [ x*x+(y-1)*(y-1) ] 4 x*x + (y-1)*(y-1)
308 */
309 /* INDENT ON */
310 t = one - ay;
311 if (iy >= 0x3ffe0000 && iy < 0x40000000) {
312 /* y close to 1 */
313 LD_RE(ans) = half * (atan2l((ax + ax), (t * (one +
314 ay) - ax * ax)));
315 } else if (ix >= 0x3ffe0000 && ix < 0x40000000) {
316 /* x close to 1 */
317 LD_RE(ans) = half * atan2l((ax + ax), ((one - ax) *
318 (one + ax) - ay * ay));
319 } else
320 LD_RE(ans) = half * atan2l((ax + ax), ((one - ax *
321 ax) - ay * ay));
322 LD_IM(ans) = 0.25L * log1pl((4.0L * ay) / (ax * ax + t * t));
323 }
324 if (hx < 0)
325 LD_RE(ans) = -LD_RE(ans);
326 if (hy < 0)
327 LD_IM(ans) = -LD_IM(ans);
328 return (ans);
329 }
|
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25
26 /*
27 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
28 * Use is subject to license terms.
29 */
30
31 #pragma weak __catanl = catanl
32
33
34 /*
35 * ldcomplex catanl(ldcomplex z);
36 *
37 * Atan(z) return A + Bi where,
38 * 1
39 * A = --- * atan2(2x, 1-x*x-y*y)
40 * 2
41 *
42 * 1 [ x*x + (y+1)*(y+1) ] 1 4y
43 * B = --- log [ ----------------- ] = - log (1+ -----------------)
44 * 4 [ x*x + (y-1)*(y-1) ] 4 x*x + (y-1)*(y-1)
45 *
46 * 2 16 3 y
47 * = t - 2t + -- t - ..., where t = -----------------
48 * 3 x*x + (y-1)*(y-1)
49 * Proof:
50 * Let w = atan(z=x+yi) = A + B i. Then tan(w) = z.
51 * Since sin(w) = (exp(iw)-exp(-iw))/(2i), cos(w)=(exp(iw)+exp(-iw))/(2),
52 * Let p = exp(iw), then z = tan(w) = ((p-1/p)/(p+1/p))/i, or
53 * iz = (p*p-1)/(p*p+1), or, after simplification,
83 * catan(-x, y) = (-u, v)
84 * catan( x,-y) = ( u,-v)
85 *
86 * Also, catan(x,y) = -i*catanh(-y,x), or
87 * catanh(x,y) = i*catan(-y,x)
88 * So, if catanh(y,x) = (v,u), then catan(x,y) = -i*(-v,u) = (u,v), i.e.,
89 * catan(x,y) = (u,v)
90 *
91 * EXCEPTION CASES (conform to ISO/IEC 9899:1999(E)):
92 * catan( 0 , 0 ) = (0 , 0 )
93 * catan( NaN, 0 ) = (NaN , 0 )
94 * catan( 0 , 1 ) = (0 , +inf) with divide-by-zero
95 * catan( inf, y ) = (pi/2 , 0 ) for finite +y
96 * catan( NaN, y ) = (NaN , NaN ) with invalid for finite y != 0
97 * catan( x , inf ) = (pi/2 , 0 ) for finite +x
98 * catan( inf, inf ) = (pi/2 , 0 )
99 * catan( NaN, inf ) = (NaN , 0 )
100 * catan( x , NaN ) = (NaN , NaN ) with invalid for finite x
101 * catan( inf, NaN ) = (pi/2 , +-0 )
102 */
103
104 #include "libm.h" /* atan2l/atanl/fabsl/isinfl/iszerol/log1pl/logl */
105 #include "complex_wrapper.h"
106 #include "longdouble.h"
107
108 /* BEGIN CSTYLED */
109 static const long double zero = 0.0L,
110 one = 1.0L,
111 two = 2.0L,
112 half = 0.5L,
113 ln2 = 6.931471805599453094172321214581765680755e-0001L,
114 pi_2 = 1.570796326794896619231321691639751442098584699687552910487472L,
115 #if defined(__x86)
116 E = 2.910383045673370361328125000000000000000e-11L, /* 2**-35 */
117 Einv = 3.435973836800000000000000000000000000000e+10L; /* 2**+35 */
118 #else
119 E = 8.673617379884035472059622406959533691406e-19L, /* 2**-60 */
120 Einv = 1.152921504606846976000000000000000000000e18L; /* 2**+60 */
121 #endif
122 /* END CSTYLED */
123
124 ldcomplex
125 catanl(ldcomplex z)
126 {
127 ldcomplex ans;
128 long double x, y, t1, ax, ay, t;
129 int hx, hy, ix, iy;
130
131 x = LD_RE(z);
132 y = LD_IM(z);
133 ax = fabsl(x);
134 ay = fabsl(y);
135 hx = HI_XWORD(x);
136 hy = HI_XWORD(y);
137 ix = hx & 0x7fffffff;
138 iy = hy & 0x7fffffff;
139
140 /* x is inf or NaN */
141 if (ix >= 0x7fff0000) {
142 if (isinfl(x)) {
143 LD_RE(ans) = pi_2;
144 LD_IM(ans) = zero;
145 } else {
146 LD_RE(ans) = x + x;
147
148 if (iszerol(y) || (isinfl(y)))
149 LD_IM(ans) = zero;
150 else
151 LD_IM(ans) = (fabsl(y) - ay) / (fabsl(y) - ay);
152 }
153 } else if (iy >= 0x7fff0000) {
154 /* y is inf or NaN */
155 if (isinfl(y)) {
156 LD_RE(ans) = pi_2;
157 LD_IM(ans) = zero;
158 } else {
159 LD_RE(ans) = (fabsl(x) - ax) / (fabsl(x) - ax);
160 LD_IM(ans) = y;
161 }
162 } else if (iszerol(x)) {
163 /* BEGIN CSTYLED */
164 /*
165 * x = 0
166 * 1 1
167 * A = --- * atan2(2x, 1-x*x-y*y) = --- atan2(0,1-|y|)
168 * 2 2
169 *
170 * 1 [ (y+1)*(y+1) ] 1 2 1 2y
171 * B = - log [ ----------- ] = - log (1+ ---) or - log(1+ ----)
172 * 4 [ (y-1)*(y-1) ] 2 y-1 2 1-y
173 */
174 /* END CSTYLED */
175 t = one - ay;
176
177 if (ay == one) {
178 /* y=1: catan(0,1)=(0,+inf) with 1/0 signal */
179 LD_IM(ans) = ay / ax;
180 LD_RE(ans) = zero;
181 } else if (ay > one) { /* y>1 */
182 LD_IM(ans) = half * log1pl(two / (-t));
183 LD_RE(ans) = pi_2;
184 } else { /* y<1 */
185 LD_IM(ans) = half * log1pl((ay + ay) / t);
186 LD_RE(ans) = zero;
187 }
188 } else if (ay < E * (one + ax)) {
189 /* BEGIN CSTYLED */
190 /*
191 * Tiny y (relative to 1+|x|)
192 * |y| < E*(1+|x|)
193 * where E=2**-29, -35, -60 for double, extended, quad precision
194 *
195 * 1 [x<=1: atan(x)
196 * A = - * atan2(2x,1-x*x-y*y) ~ [ 1 1+x
197 * 2 [x>=1: - atan2(2,(1-x)*(-----))
198 * 2 x
199 *
200 * y/x
201 * B ~ t*(1-2t), where t = ----------------- is tiny
202 * x + (y-1)*(y-1)/x
203 *
204 * y
205 * (when x < 2**-60, t = ----------- )
206 * (y-1)*(y-1)
207 */
208 /* END CSTYLED */
209 if (ay == zero) {
210 LD_IM(ans) = ay;
211 } else {
212 t1 = ay - one;
213
214 if (ix < 0x3fc30000)
215 t = ay / (t1 * t1);
216 else if (ix > 0x403b0000)
217 t = (ay / ax) / ax;
218 else
219 t = ay / (ax * ax + t1 * t1);
220
221 LD_IM(ans) = t * (one - two * t);
222 }
223
224 if (ix < 0x3fff0000)
225 LD_RE(ans) = atanl(ax);
226 else
227 LD_RE(ans) = half * atan2l(two, (one - ax) * (one +
228 one / ax));
229 } else if (ay > Einv * (one + ax)) {
230 /* BEGIN CSTYLED */
231 /*
232 * Huge y relative to 1+|x|
233 * |y| > Einv*(1+|x|), where Einv~2**(prec/2+3),
234 * 1
235 * A ~ --- * atan2(2x, -y*y) ~ pi/2
236 * 2
237 * y
238 * B ~ t*(1-2t), where t = --------------- is tiny
239 * (y-1)*(y-1)
240 */
241 /* END CSTYLED */
242 LD_RE(ans) = pi_2;
243 t = (ay / (ay - one)) / (ay - one);
244 LD_IM(ans) = t * (one - (t + t));
245 } else if (ay == one) {
246 /* BEGIN CSTYLED */
247 /*
248 * y=1
249 * 1 1
250 * A = - * atan2(2x, -x*x) = --- atan2(2,-x)
251 * 2 2
252 *
253 * 1 [ x*x+4] 1 4 [ 0.5(log2-logx) if
254 * B = - log [ -----] = - log (1+ ---) = [ |x|<E, else 0.25*
255 * 4 [ x*x ] 4 x*x [ log1p((2/x)*(2/x))
256 */
257 /* END CSTYLED */
258 LD_RE(ans) = half * atan2l(two, -ax);
259
260 if (ax < E) {
261 LD_IM(ans) = half * (ln2 - logl(ax));
262 } else {
263 t = two / ax;
264 LD_IM(ans) = 0.25L * log1pl(t * t);
265 }
266 } else if (ax > Einv * Einv) {
267 /* BEGIN CSTYLED */
268 /*
269 * Huge x:
270 * when |x| > 1/E^2,
271 * 1 pi
272 * A ~ --- * atan2(2x, -x*x-y*y) ~ ---
273 * 2 2
274 * y y/x
275 * B ~ t*(1-2t), where t = --------------- = (-------------- )/x
276 * x*x+(y-1)*(y-1) 1+((y-1)/x)^2
277 */
278 /* END CSTYLED */
279 LD_RE(ans) = pi_2;
280 t = ((ay / ax) / (one + ((ay - one) / ax) * ((ay - one) /
281 ax))) / ax;
282 LD_IM(ans) = t * (one - (t + t));
283 } else if (ax < E * E * E * E) {
284 /* BEGIN CSTYLED */
285 /*
286 * Tiny x:
287 * when |x| < E^4, (note that y != 1)
288 * 1 1
289 * A = --- * atan2(2x, 1-x*x-y*y) ~ --- * atan2(2x,1-y*y)
290 * 2 2
291 *
292 * 1 [ (y+1)*(y+1) ] 1 2 1 2y
293 * B = - log [ ----------- ] = - log (1+ ---) or - log(1+ ----)
294 * 4 [ (y-1)*(y-1) ] 2 y-1 2 1-y
295 */
296 /* END CSTYLED */
297 LD_RE(ans) = half * atan2l(ax + ax, (one - ay) * (one + ay));
298
299 if (ay > one) /* y>1 */
300 LD_IM(ans) = half * log1pl(two / (ay - one));
301 else /* y<1 */
302 LD_IM(ans) = half * log1pl((ay + ay) / (one - ay));
303 } else {
304 /* BEGIN CSTYLED */
305 /*
306 * normal x,y
307 * 1
308 * A = --- * atan2(2x, 1-x*x-y*y)
309 * 2
310 *
311 * 1 [ x*x+(y+1)*(y+1) ] 1 4y
312 * B = - log [ --------------- ] = - log (1+ -----------------)
313 * 4 [ x*x+(y-1)*(y-1) ] 4 x*x + (y-1)*(y-1)
314 */
315 /* END CSTYLED */
316 t = one - ay;
317
318 if (iy >= 0x3ffe0000 && iy < 0x40000000) {
319 /* y close to 1 */
320 LD_RE(ans) = half * (atan2l((ax + ax), (t * (one + ay) -
321 ax * ax)));
322 } else if (ix >= 0x3ffe0000 && ix < 0x40000000) {
323 /* x close to 1 */
324 LD_RE(ans) = half * atan2l((ax + ax), ((one - ax) *
325 (one + ax) - ay * ay));
326 } else {
327 LD_RE(ans) = half * atan2l((ax + ax), ((one - ax * ax) -
328 ay * ay));
329 }
330
331 LD_IM(ans) = 0.25L * log1pl((4.0L * ay) / (ax * ax + t * t));
332 }
333
334 if (hx < 0)
335 LD_RE(ans) = -LD_RE(ans);
336
337 if (hy < 0)
338 LD_IM(ans) = -LD_IM(ans);
339
340 return (ans);
341 }
|