2021-02-04 11:39:00 +01:00
|
|
|
program Interface_test
|
2021-02-06 18:59:07 +01:00
|
|
|
use Sherman_Morrison, only : MaponiA3
|
2021-02-04 11:39:00 +01:00
|
|
|
use, intrinsic :: iso_c_binding, only : c_int, c_double
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
integer i, j !! Iterators
|
|
|
|
integer(c_int) :: dim, N_updates
|
|
|
|
integer(c_int), dimension(:), allocatable :: Ar_index
|
|
|
|
integer(c_int), dimension(:,:), allocatable :: A, A0, Ar
|
|
|
|
real(c_double), dimension(:,:), allocatable :: A0_inv
|
|
|
|
|
|
|
|
dim = 3
|
|
|
|
N_updates = dim
|
|
|
|
allocate(Ar_index(dim), A(dim,dim), A0(dim,dim), Ar(dim,dim), A0_inv(dim,dim))
|
|
|
|
|
|
|
|
!! Initialize A with M=3 and fill acc. to Eq. (17) from paper
|
|
|
|
A(1,1) = 1
|
|
|
|
A(1,2) = 1
|
|
|
|
A(1,3) = -1
|
|
|
|
A(2,1) = 1
|
|
|
|
A(2,2) = 1
|
|
|
|
A(2,3) = 0
|
|
|
|
A(3,1) = -1
|
|
|
|
A(3,2) = 0
|
|
|
|
A(3,3) = -1
|
|
|
|
|
2021-02-04 13:12:34 +01:00
|
|
|
!! Prepare the diagonal matrix A0 and the update matrix Ar
|
|
|
|
do i=1,dim
|
|
|
|
Ar_index(i) = i
|
|
|
|
do j=1,dim
|
|
|
|
if (i == j) then
|
|
|
|
A0(i,j) = A(i,j)
|
|
|
|
A0_inv(i,j) = 1.0d0 / A0(i,j)
|
|
|
|
else
|
|
|
|
A0(i,j) = 0
|
|
|
|
A0_inv(i,j) = 0.0d0
|
|
|
|
end if
|
|
|
|
Ar(i,j) = A(i,j) - A0(i,j)
|
2021-02-04 11:39:00 +01:00
|
|
|
end do
|
|
|
|
end do
|
2021-02-06 18:59:07 +01:00
|
|
|
|
|
|
|
call MaponiA3(A0, A0_inv, dim, n_updates, Ar, Ar_index)
|
2021-02-04 11:39:00 +01:00
|
|
|
|
2021-02-06 18:59:07 +01:00
|
|
|
do i=1,dim
|
|
|
|
do j=1,dim
|
|
|
|
write(*,"(F3.0,3X)", advance="no") A0_inv(i,j)
|
|
|
|
end do
|
|
|
|
write(*,*)
|
|
|
|
end do
|
2021-02-04 13:12:34 +01:00
|
|
|
|
2021-02-04 11:39:00 +01:00
|
|
|
deallocate(Ar_index, A, A0, Ar, A0_inv)
|
|
|
|
end program
|