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
|
program array_indices_array_item_assignment_2
real :: Q(4), R(4), S(4), X(2,2)
logical, save :: mask(2) = [.true.,.false.]
R = [1, 4, 2, 3]
S = [3, 2, 1, 4]
Q = 5.0
X = reshape(R, shape(X))
Q(trueloc(R < S)) = Q(trueloc(R < S)) + 1.0
Q(trueloc(R >= S)) = -Q(trueloc(R >= S)) - 1.0
print *, Q
if( any(Q /= [6.0, -6.0, -6.0, 6.0]) ) error stop
X([1,2], trueloc(mask)) = X([2,1], trueloc(mask))
print *, X
if( X(1,1) /= 4.0 .or. X(2,1) /= 1.0 .or. X(1,2) /= 2.0 .or. X(2,2) /= 3.0 ) error stop
contains
function trueloc(x) result(loc)
logical, intent(in) :: x(:)
integer(4), allocatable :: loc(:)
integer :: i, j
allocate(loc(count(x)))
j = 1
do i = 1, size(x)
if( x(i) ) then
loc(j) = i
j = j + 1
end if
end do
end function trueloc
end program
|