1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
|
program associate_12
implicit none
complex, target :: my_complex_one_dim(2)
complex, pointer :: my_complex_one_dim_mirror(:)
real, pointer :: my_complex_one_dim_re(:)
real, pointer :: my_complex_one_dim_im(:)
complex, target :: my_complex(2, 3)
complex, pointer :: my_complex_mirror(:, :)
real, pointer :: my_complex_re(:, :)
real, pointer :: my_complex_im(:, :)
my_complex_one_dim(1) = (2, 5)
my_complex_one_dim(2) = (-2, -5)
my_complex_one_dim_mirror => my_complex_one_dim
print *, my_complex_one_dim_mirror(1), my_complex_one_dim_mirror(2)
if (abs(my_complex_one_dim_mirror(1) - (2, 5)) > 1e-5) error stop
if (abs(my_complex_one_dim_mirror(2) - (-2, -5)) > 1e-5) error stop
my_complex_one_dim_re => my_complex_one_dim%re
print *, my_complex_one_dim_re(1), my_complex_one_dim_re(2)
if (abs(my_complex_one_dim_re(1) - 2) > 1e-5) error stop
if (abs(my_complex_one_dim_re(2) - (-2)) > 1e-5) error stop
my_complex_one_dim_im => my_complex_one_dim%im
print *, my_complex_one_dim_im(1), my_complex_one_dim_im(2)
if (abs(my_complex_one_dim_im(1) - 5) > 1e-5) error stop
if (abs(my_complex_one_dim_im(2) - (-5)) > 1e-5) error stop
my_complex = reshape([(1, 2), (3, 4), (5, 6), (7, 8), (9, 10), (11, 12)], [2, 3])
my_complex_mirror => my_complex
print *, my_complex_mirror(1, 1), my_complex_mirror(1, 2), my_complex_mirror(1, 3)
print *, my_complex_mirror(2, 1), my_complex_mirror(2, 2), my_complex_mirror(2, 3)
if (abs(my_complex_mirror(1, 1) - (1, 2)) > 1e-5) error stop
if (abs(my_complex_mirror(1, 2) - (5, 6)) > 1e-5) error stop
if (abs(my_complex_mirror(1, 3) - (9, 10)) > 1e-5) error stop
if (abs(my_complex_mirror(2, 1) - (3, 4)) > 1e-5) error stop
if (abs(my_complex_mirror(2, 2) - (7, 8)) > 1e-5) error stop
if (abs(my_complex_mirror(2, 3) - (11, 12)) > 1e-5) error stop
my_complex_re => my_complex%re
print *, my_complex_re(1, 1), my_complex_re(1, 2), my_complex_re(1, 3)
print *, my_complex_re(2, 1), my_complex_re(2, 2), my_complex_re(2, 3)
if (abs(my_complex_re(1, 1) - 1) > 1e-5) error stop
if (abs(my_complex_re(1, 2) - 5) > 1e-5) error stop
if (abs(my_complex_re(1, 3) - 9) > 1e-5) error stop
if (abs(my_complex_re(2, 1) - 3) > 1e-5) error stop
if (abs(my_complex_re(2, 2) - 7) > 1e-5) error stop
if (abs(my_complex_re(2, 3) - 11) > 1e-5) error stop
my_complex_im => my_complex%im
print *, my_complex_im(1, 1), my_complex_im(1, 2), my_complex_im(1, 3)
print *, my_complex_im(2, 1), my_complex_im(2, 2), my_complex_im(2, 3)
if (abs(my_complex_im(1, 1) - 2) > 1e-5) error stop
if (abs(my_complex_im(1, 2) - 6) > 1e-5) error stop
if (abs(my_complex_im(1, 3) - 10) > 1e-5) error stop
if (abs(my_complex_im(2, 1) - 4) > 1e-5) error stop
if (abs(my_complex_im(2, 2) - 8) > 1e-5) error stop
if (abs(my_complex_im(2, 3) - 12) > 1e-5) error stop
end program
|