LAA: improve code in getStrideFromPointer (NFC) (#124780)
[llvm-project.git] / flang / test / Evaluate / fold-norm2.f90
blob370532bafaa13cf802b0a2e14450a7fec60eafb5
1 ! RUN: %python %S/test_folding.py %s %flang_fc1
2 ! Tests folding of NORM2(), F'2023 16.9.153
3 module m
4 ! Examples from the standard
5 logical, parameter :: test_ex1 = norm2([3.,4.]) == 5.
6 real, parameter :: ex2(2,2) = reshape([1.,3.,2.,4.],[2,2])
7 real, parameter :: ex2_norm2_1(2) = norm2(ex2, dim=1)
8 real, parameter :: ex2_1(2) = [3.162277698516845703125,4.472136020660400390625]
9 logical, parameter :: test_ex2_1 = all(ex2_norm2_1 == ex2_1)
10 real, parameter :: ex2_norm2_2(2) = norm2(ex2, dim=2)
11 real, parameter :: ex2_2(2) = [2.2360680103302001953125,5.]
12 logical, parameter :: test_ex2_2 = all(ex2_norm2_2 == ex2_2)
13 ! 0 3 6 9
14 ! 1 4 7 10
15 ! 2 5 8 11
16 integer, parameter :: dp = kind(0.d0)
17 real(dp), parameter :: a(3,4) = &
18 reshape([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11], shape(a))
19 real(dp), parameter :: nAll = norm2(a)
20 real(dp), parameter :: check_nAll = 11._dp * sqrt(sum((a/11._dp)**2))
21 logical, parameter :: test_all = nAll == check_nAll
22 real(dp), parameter :: norms1(4) = norm2(a, dim=1)
23 real(dp), parameter :: check_norms1(4) = [ &
24 2.236067977499789805051477742381393909454345703125_8, &
25 7.07106781186547550532850436866283416748046875_8, &
26 1.2206555615733702069292121450416743755340576171875e1_8, &
27 1.7378147196982769884243680280633270740509033203125e1_8 ]
28 logical, parameter :: test_norms1 = all(norms1 == check_norms1)
29 real(dp), parameter :: norms2(3) = norm2(a, dim=2)
30 real(dp), parameter :: check_norms2(3) = [ &
31 1.1224972160321822656214862945489585399627685546875e1_8, &
32 1.28840987267251261272349438513629138469696044921875e1_8, &
33 1.4628738838327791427218471653759479522705078125e1_8 ]
34 logical, parameter :: test_norms2 = all(norms2 == check_norms2)
35 logical, parameter :: test_normZ = norm2([0.,0.,0.]) == 0.
36 end