[flang] Accept polymorphic component element in storage_size
[llvm-project.git] / mlir / test / mlir-cpu-runner / math-polynomial-approx.mlir
blobdbd816639ede3ac608896ee218eb92553ecf0467
1 // RUN:   mlir-opt %s -pass-pipeline="builtin.module(func.func(test-math-polynomial-approximation,convert-arith-to-llvm),convert-vector-to-llvm,func.func(convert-math-to-llvm),convert-func-to-llvm,reconcile-unrealized-casts)" \
2 // RUN: | mlir-cpu-runner                                                      \
3 // RUN:     -e main -entry-point-result=void -O0                               \
4 // RUN:     -shared-libs=%mlir_c_runner_utils  \
5 // RUN:     -shared-libs=%mlir_runner_utils    \
6 // RUN: | FileCheck %s
8 // -------------------------------------------------------------------------- //
9 // Tanh.
10 // -------------------------------------------------------------------------- //
12 func.func @tanh_f32(%a : f32) {
13   %r = math.tanh %a : f32
14   vector.print %r : f32
15   return
18 func.func @tanh_4xf32(%a : vector<4xf32>) {
19   %r = math.tanh %a : vector<4xf32>
20   vector.print %r : vector<4xf32>
21   return
24 func.func @tanh_8xf32(%a : vector<8xf32>) {
25   %r = math.tanh %a : vector<8xf32>
26   vector.print %r : vector<8xf32>
27   return
30 func.func @tanh() {
31   // CHECK: 0.848284
32   %f0 = arith.constant 1.25 : f32
33   call @tanh_f32(%f0) : (f32) -> ()
35   // CHECK: 0.244919, 0.635149, 0.761594, 0.848284
36   %v1 = arith.constant dense<[0.25, 0.75, 1.0, 1.25]> : vector<4xf32>
37   call @tanh_4xf32(%v1) : (vector<4xf32>) -> ()
39   // CHECK: 0.099668, 0.197375, 0.291313, 0.379949, 0.462117, 0.53705, 0.604368, 0.664037
40   %v2 = arith.constant dense<[0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]> : vector<8xf32>
41   call @tanh_8xf32(%v2) : (vector<8xf32>) -> ()
43   // CHECK: nan
44   %nan = arith.constant 0x7fc00000 : f32
45   call @tanh_f32(%nan) : (f32) -> ()
47  return
50 // -------------------------------------------------------------------------- //
51 // Log.
52 // -------------------------------------------------------------------------- //
54 func.func @log_f32(%a : f32) {
55   %r = math.log %a : f32
56   vector.print %r : f32
57   return
60 func.func @log_4xf32(%a : vector<4xf32>) {
61   %r = math.log %a : vector<4xf32>
62   vector.print %r : vector<4xf32>
63   return
66 func.func @log_8xf32(%a : vector<8xf32>) {
67   %r = math.log %a : vector<8xf32>
68   vector.print %r : vector<8xf32>
69   return
72 func.func @log() {
73   // CHECK: 2.64704
74   %f1 = arith.constant 14.112233 : f32
75   call @log_f32(%f1) : (f32) -> ()
77   // CHECK: -1.38629, -0.287682, 0, 0.223144
78   %v1 = arith.constant dense<[0.25, 0.75, 1.0, 1.25]> : vector<4xf32>
79   call @log_4xf32(%v1) : (vector<4xf32>) -> ()
81   // CHECK: -2.30259, -1.60944, -1.20397, -0.916291, -0.693147, -0.510826, -0.356675, -0.223144
82   %v2 = arith.constant dense<[0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]> : vector<8xf32>
83   call @log_8xf32(%v2) : (vector<8xf32>) -> ()
85   // CHECK: -inf
86   %zero = arith.constant 0.0 : f32
87   call @log_f32(%zero) : (f32) -> ()
89   // CHECK: nan
90   %nan = arith.constant 0x7fc00000 : f32
91   call @log_f32(%nan) : (f32) -> ()
93   // CHECK: inf
94   %inf = arith.constant 0x7f800000 : f32
95   call @log_f32(%inf) : (f32) -> ()
97   // CHECK: -inf, nan, inf, 0.693147
98   %special_vec = arith.constant dense<[0.0, -1.0, 0x7f800000, 2.0]> : vector<4xf32>
99   call @log_4xf32(%special_vec) : (vector<4xf32>) -> ()
101   return
104 func.func @log2_f32(%a : f32) {
105   %r = math.log2 %a : f32
106   vector.print %r : f32
107   return
110 func.func @log2_4xf32(%a : vector<4xf32>) {
111   %r = math.log2 %a : vector<4xf32>
112   vector.print %r : vector<4xf32>
113   return
116 func.func @log2_8xf32(%a : vector<8xf32>) {
117   %r = math.log2 %a : vector<8xf32>
118   vector.print %r : vector<8xf32>
119   return
122 func.func @log2() {
123   // CHECK: 3.81887
124   %f0 = arith.constant 14.112233 : f32
125   call @log2_f32(%f0) : (f32) -> ()
127   // CHECK: -2, -0.415037, 0, 0.321928
128   %v1 = arith.constant dense<[0.25, 0.75, 1.0, 1.25]> : vector<4xf32>
129   call @log2_4xf32(%v1) : (vector<4xf32>) -> ()
131   // CHECK: -3.32193, -2.32193, -1.73697, -1.32193, -1, -0.736966, -0.514573, -0.321928
132   %v2 = arith.constant dense<[0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]> : vector<8xf32>
133   call @log2_8xf32(%v2) : (vector<8xf32>) -> ()
135   // CHECK: -inf
136   %zero = arith.constant 0.0 : f32
137   call @log2_f32(%zero) : (f32) -> ()
139   // CHECK: nan
140   %neg_one = arith.constant -1.0 : f32
141   call @log2_f32(%neg_one) : (f32) -> ()
143   // CHECK: inf
144   %inf = arith.constant 0x7f800000 : f32
145   call @log2_f32(%inf) : (f32) -> ()
147   // CHECK: -inf, nan, inf, 1.58496
148   %special_vec = arith.constant dense<[0.0, -1.0, 0x7f800000, 3.0]> : vector<4xf32>
149   call @log2_4xf32(%special_vec) : (vector<4xf32>) -> ()
151   return
154 func.func @log1p_f32(%a : f32) {
155   %r = math.log1p %a : f32
156   vector.print %r : f32
157   return
160 func.func @log1p_4xf32(%a : vector<4xf32>) {
161   %r = math.log1p %a : vector<4xf32>
162   vector.print %r : vector<4xf32>
163   return
166 func.func @log1p_8xf32(%a : vector<8xf32>) {
167   %r = math.log1p %a : vector<8xf32>
168   vector.print %r : vector<8xf32>
169   return
172 func.func @log1p() {
173   // CHECK: 0.00995033
174   %f0 = arith.constant 0.01 : f32
175   call @log1p_f32(%f0) : (f32) -> ()
178   // CHECK: -4.60517, -0.693147, 0, 1.38629
179   %v1 = arith.constant dense<[-0.99, -0.5, 0.0, 3.0]> : vector<4xf32>
180   call @log1p_4xf32(%v1) : (vector<4xf32>) -> ()
182   // CHECK: 0.0953102, 0.182322, 0.262364, 0.336472, 0.405465, 0.470004, 0.530628, 0.587787
183   %v2 = arith.constant dense<[0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8]> : vector<8xf32>
184   call @log1p_8xf32(%v2) : (vector<8xf32>) -> ()
186   // CHECK: -inf
187   %neg_one = arith.constant -1.0 : f32
188   call @log1p_f32(%neg_one) : (f32) -> ()
190   // CHECK: nan
191   %neg_two = arith.constant -2.0 : f32
192   call @log1p_f32(%neg_two) : (f32) -> ()
194   // CHECK: inf
195   %inf = arith.constant 0x7f800000 : f32
196   call @log1p_f32(%inf) : (f32) -> ()
198   // CHECK: -inf, nan, inf, 9.99995e-06
199   %special_vec = arith.constant dense<[-1.0, -1.1, 0x7f800000, 0.00001]> : vector<4xf32>
200   call @log1p_4xf32(%special_vec) : (vector<4xf32>) -> ()
202   return
205 // -------------------------------------------------------------------------- //
206 // Erf.
207 // -------------------------------------------------------------------------- //
208 func.func @erf_f32(%a : f32) {
209   %r = math.erf %a : f32
210   vector.print %r : f32
211   return
214 func.func @erf_4xf32(%a : vector<4xf32>) {
215   %r = math.erf %a : vector<4xf32>
216   vector.print %r : vector<4xf32>
217   return
220 func.func @erf() {
221   // CHECK: -0.000274406
222   %val1 = arith.constant -2.431864e-4 : f32
223   call @erf_f32(%val1) : (f32) -> ()
225   // CHECK: 0.742095
226   %val2 = arith.constant 0.79999 : f32
227   call @erf_f32(%val2) : (f32) -> ()
229   // CHECK: 0.742101
230   %val3 = arith.constant 0.8 : f32
231   call @erf_f32(%val3) : (f32) -> ()
233   // CHECK: 0.995322
234   %val4 = arith.constant 1.99999 : f32
235   call @erf_f32(%val4) : (f32) -> ()
237   // CHECK: 0.995322
238   %val5 = arith.constant 2.0 : f32
239   call @erf_f32(%val5) : (f32) -> ()
241   // CHECK: 1
242   %val6 = arith.constant 3.74999 : f32
243   call @erf_f32(%val6) : (f32) -> ()
245   // CHECK: 1
246   %val7 = arith.constant 3.75 : f32
247   call @erf_f32(%val7) : (f32) -> ()
249   // CHECK: -1
250   %negativeInf = arith.constant 0xff800000 : f32
251   call @erf_f32(%negativeInf) : (f32) -> ()
253   // CHECK: -1, -1, -0.913759, -0.731446
254   %vecVals1 = arith.constant dense<[-3.4028235e+38, -4.54318, -1.2130899, -7.8234202e-01]> : vector<4xf32>
255   call @erf_4xf32(%vecVals1) : (vector<4xf32>) -> ()
257   // CHECK: -1.3264e-38, 0, 1.3264e-38, 0.121319
258   %vecVals2 = arith.constant dense<[-1.1754944e-38, 0.0, 1.1754944e-38, 1.0793410e-01]> : vector<4xf32>
259   call @erf_4xf32(%vecVals2) : (vector<4xf32>) -> ()
261   // CHECK: 0.919477, 0.999069, 1, 1
262   %vecVals3 = arith.constant dense<[1.23578, 2.34093, 3.82342, 3.4028235e+38]> : vector<4xf32>
263   call @erf_4xf32(%vecVals3) : (vector<4xf32>) -> ()
265   // CHECK: 1
266   %inf = arith.constant 0x7f800000 : f32
267   call @erf_f32(%inf) : (f32) -> ()
269   // CHECK: nan
270   %nan = arith.constant 0x7fc00000 : f32
271   call @erf_f32(%nan) : (f32) -> ()
273   return
276 // -------------------------------------------------------------------------- //
277 // Exp.
278 // -------------------------------------------------------------------------- //
279 func.func @exp_f32(%a : f32) {
280   %r = math.exp %a : f32
281   vector.print %r : f32
282   return
285 func.func @exp_4xf32(%a : vector<4xf32>) {
286   %r = math.exp %a : vector<4xf32>
287   vector.print %r : vector<4xf32>
288   return
291 func.func @exp() {
292   // CHECK: 2.71828
293   %f0 = arith.constant 1.0 : f32
294   call @exp_f32(%f0) : (f32) -> ()
296   // CHECK: 0.778802, 2.117, 2.71828, 3.85742
297   %v1 = arith.constant dense<[-0.25, 0.75, 1.0, 1.35]> : vector<4xf32>
298   call @exp_4xf32(%v1) : (vector<4xf32>) -> ()
300   // CHECK: 1
301   %zero = arith.constant 0.0 : f32
302   call @exp_f32(%zero) : (f32) -> ()
304   // CHECK: 1.17549e-38, 1.38879e-11, 7.20049e+10, inf
305   %special_vec = arith.constant dense<[-89.0, -25.0, 25.0, 89.0]> : vector<4xf32>
306   call @exp_4xf32(%special_vec) : (vector<4xf32>) -> ()
308   // CHECK: inf
309   %inf = arith.constant 0x7f800000 : f32
310   call @exp_f32(%inf) : (f32) -> ()
312   // CHECK: 0
313   %negative_inf = arith.constant 0xff800000 : f32
314   call @exp_f32(%negative_inf) : (f32) -> ()
316   // CHECK: nan
317   %nan = arith.constant 0x7fc00000 : f32
318   call @exp_f32(%nan) : (f32) -> ()
320   return
323 func.func @expm1_f32(%a : f32) {
324   %r = math.expm1 %a : f32
325   vector.print %r : f32
326   return
329 func.func @expm1_3xf32(%a : vector<3xf32>) {
330   %r = math.expm1 %a : vector<3xf32>
331   vector.print %r : vector<3xf32>
332   return
335 func.func @expm1_4xf32(%a : vector<4xf32>) {
336   %r = math.expm1 %a : vector<4xf32>
337   vector.print %r : vector<4xf32>
338   return
341 func.func @expm1_8xf32(%a : vector<8xf32>) {
342   %r = math.expm1 %a : vector<8xf32>
343   vector.print %r : vector<8xf32>
344   return
347 func.func @expm1() {
348   // CHECK: 1e-10
349   %f0 = arith.constant 1.0e-10 : f32
350   call @expm1_f32(%f0) : (f32) -> ()
352   // CHECK: -0.00995016, 0.0100502, 0.648721, 6.38905
353   %v1 = arith.constant dense<[-0.01, 0.01, 0.5, 2.0]> : vector<4xf32>
354   call @expm1_4xf32(%v1) : (vector<4xf32>) -> ()
356   // CHECK: -0.181269, 0, 0.221403, 0.491825, 0.822119, 1.22554, 1.71828, 2.32012
357   %v2 = arith.constant dense<[-0.2, 0.0, 0.2, 0.4, 0.6, 0.8, 1.0, 1.2]> : vector<8xf32>
358   call @expm1_8xf32(%v2) : (vector<8xf32>) -> ()
360   // CHECK: -1
361   %neg_inf = arith.constant 0xff800000 : f32
362   call @expm1_f32(%neg_inf) : (f32) -> ()
364   // CHECK: inf
365   %inf = arith.constant 0x7f800000 : f32
366   call @expm1_f32(%inf) : (f32) -> ()
368   // CHECK: -1, inf, 1e-10
369   %special_vec = arith.constant dense<[0xff800000, 0x7f800000, 1.0e-10]> : vector<3xf32>
370   call @expm1_3xf32(%special_vec) : (vector<3xf32>) -> ()
372   // CHECK: nan
373   %nan = arith.constant 0x7fc00000 : f32
374   call @expm1_f32(%nan) : (f32) -> ()
376   return
378 // -------------------------------------------------------------------------- //
379 // Sin.
380 // -------------------------------------------------------------------------- //
381 func.func @sin_f32(%a : f32) {
382   %r = math.sin %a : f32
383   vector.print %r : f32
384   return
387 func.func @sin_3xf32(%a : vector<3xf32>) {
388   %r = math.sin %a : vector<3xf32>
389   vector.print %r : vector<3xf32>
390   return
393 func.func @sin() {
394   // CHECK: 0
395   %zero = arith.constant 0.0 : f32
396   call @sin_f32(%zero) : (f32) -> ()
398   // CHECK: 0.707107
399   %pi_over_4 = arith.constant 0.78539816339 : f32
400   call @sin_f32(%pi_over_4) : (f32) -> ()
402   // CHECK: 1
403   %pi_over_2 = arith.constant 1.57079632679 : f32
404   call @sin_f32(%pi_over_2) : (f32) -> ()
406   // CHECK: 0
407   %pi = arith.constant 3.14159265359 : f32
408   call @sin_f32(%pi) : (f32) -> ()
410   // CHECK: -1
411   %pi_3_over_2 = arith.constant 4.71238898038 : f32
412   call @sin_f32(%pi_3_over_2) : (f32) -> ()
414   // CHECK: 0, 0.866025, -1
415   %vec_x = arith.constant dense<[9.42477796077, 2.09439510239, -1.57079632679]> : vector<3xf32>
416   call @sin_3xf32(%vec_x) : (vector<3xf32>) -> ()
418   return
421 // -------------------------------------------------------------------------- //
422 // cos.
423 // -------------------------------------------------------------------------- //
424 func.func @cos_f32(%a : f32) {
425   %r = math.cos %a : f32
426   vector.print %r : f32
427   return
430 func.func @cos_3xf32(%a : vector<3xf32>) {
431   %r = math.cos %a : vector<3xf32>
432   vector.print %r : vector<3xf32>
433   return
436 func.func @cos() {
437   // CHECK: 1
438   %zero = arith.constant 0.0 : f32
439   call @cos_f32(%zero) : (f32) -> ()
441   // CHECK: 0.707107
442   %pi_over_4 = arith.constant 0.78539816339 : f32
443   call @cos_f32(%pi_over_4) : (f32) -> ()
445   // CHECK: 0
446   %pi_over_2 = arith.constant 1.57079632679 : f32
447   call @cos_f32(%pi_over_2) : (f32) -> ()
449   // CHECK: -1
450   %pi = arith.constant 3.14159265359 : f32
451   call @cos_f32(%pi) : (f32) -> ()
453   // CHECK: 0
454   %pi_3_over_2 = arith.constant 4.71238898038 : f32
455   call @cos_f32(%pi_3_over_2) : (f32) -> ()
457   // CHECK: -1, -0.5, 0
458   %vec_x = arith.constant dense<[9.42477796077, 2.09439510239, -1.57079632679]> : vector<3xf32>
459   call @cos_3xf32(%vec_x) : (vector<3xf32>) -> ()
461   return
464 // -------------------------------------------------------------------------- //
465 // Atan.
466 // -------------------------------------------------------------------------- //
467 func.func @atan_f32(%a : f32) {
468   %r = math.atan %a : f32
469   vector.print %r : f32
470   return
473 func.func @atan() {
474   // CHECK: -0.785184
475   %0 = arith.constant -1.0 : f32
476   call @atan_f32(%0) : (f32) -> ()
478   // CHECK: 0.785184
479   %1 = arith.constant 1.0 : f32
480   call @atan_f32(%1) : (f32) -> ()
482   // CHECK: -0.463643
483   %2 = arith.constant -0.5 : f32
484   call @atan_f32(%2) : (f32) -> ()
486   // CHECK: 0.463643
487   %3 = arith.constant 0.5 : f32
488   call @atan_f32(%3) : (f32) -> ()
490   // CHECK: 0
491   %4 = arith.constant 0.0 : f32
492   call @atan_f32(%4) : (f32) -> ()
494   // CHECK: -1.10715
495   %5 = arith.constant -2.0 : f32
496   call @atan_f32(%5) : (f32) -> ()
498   // CHECK: 1.10715
499   %6 = arith.constant 2.0 : f32
500   call @atan_f32(%6) : (f32) -> ()
502   return
506 // -------------------------------------------------------------------------- //
507 // Atan2.
508 // -------------------------------------------------------------------------- //
509 func.func @atan2_f32(%a : f32, %b : f32) {
510   %r = math.atan2 %a, %b : f32
511   vector.print %r : f32
512   return
515 func.func @atan2() {
516   %zero = arith.constant 0.0 : f32
517   %one = arith.constant 1.0 : f32
518   %two = arith.constant 2.0 : f32
519   %neg_one = arith.constant -1.0 : f32
520   %neg_two = arith.constant -2.0 : f32
522   // CHECK: 0
523   call @atan2_f32(%zero, %one) : (f32, f32) -> ()
525   // CHECK: 1.5708
526   call @atan2_f32(%one, %zero) : (f32, f32) -> ()
528   // CHECK: 3.14159
529   call @atan2_f32(%zero, %neg_one) : (f32, f32) -> ()
531   // CHECK: -1.5708
532   call @atan2_f32(%neg_one, %zero) : (f32, f32) -> ()
534   // CHECK: nan
535   call @atan2_f32(%zero, %zero) : (f32, f32) -> ()
537   // CHECK: 1.10715
538   call @atan2_f32(%two, %one) : (f32, f32) -> ()
540   // CHECK: 2.03444
541   %x6 = arith.constant -1.0 : f32
542   %y6 = arith.constant 2.0 : f32
543   call @atan2_f32(%two, %neg_one) : (f32, f32) -> ()
545   // CHECK: -2.03444
546   call @atan2_f32(%neg_two, %neg_one) : (f32, f32) -> ()
548   // CHECK: -1.10715
549   call @atan2_f32(%neg_two, %one) : (f32, f32) -> ()
551   // CHECK: 0.463643
552   call @atan2_f32(%one, %two) : (f32, f32) -> ()
554   // CHECK: 2.67795
555   %x10 = arith.constant -2.0 : f32
556   %y10 = arith.constant 1.0 : f32
557   call @atan2_f32(%one, %neg_two) : (f32, f32) -> ()
559   // CHECK: -2.67795
560   %x11 = arith.constant -2.0 : f32
561   %y11 = arith.constant -1.0 : f32
562   call @atan2_f32(%neg_one, %neg_two) : (f32, f32) -> ()
564   // CHECK: -0.463643
565   call @atan2_f32(%neg_one, %two) : (f32, f32) -> ()
567   return
571 func.func @main() {
572   call @tanh(): () -> ()
573   call @log(): () -> ()
574   call @log2(): () -> ()
575   call @log1p(): () -> ()
576   call @erf(): () -> ()
577   call @exp(): () -> ()
578   call @expm1(): () -> ()
579   call @sin(): () -> ()
580   call @cos(): () -> ()
581   call @atan() : () -> ()
582   call @atan2() : () -> ()
583   return