103 integer,
parameter :: IDX_I_ITER = 1
104 integer,
parameter :: IDX_I_METHOD = 2
105 integer,
parameter :: IDX_I_PRECOND = 3
106 integer,
parameter :: IDX_I_NSET = 4
107 integer,
parameter :: IDX_I_ITERPREMAX = 5
108 integer,
parameter :: IDX_I_NREST = 6
109 integer,
parameter :: IDX_I_NBFGS = 60
110 integer,
parameter :: IDX_I_SCALING = 7
111 integer,
parameter :: IDX_I_PENALIZED = 11
112 integer,
parameter :: IDX_I_PENALIZED_B = 12
113 integer,
parameter :: IDX_I_MPC_METHOD = 13
114 integer,
parameter :: IDX_I_ESTCOND = 14
115 integer,
parameter :: IDX_I_CONTACT_ELIM = 15
116 integer,
parameter :: IDX_I_ITERLOG = 21
117 integer,
parameter :: IDX_I_TIMELOG = 22
118 integer,
parameter :: IDX_I_DUMP = 31
119 integer,
parameter :: IDX_I_DUMP_EXIT = 32
120 integer,
parameter :: IDX_I_USEJAD = 33
121 integer,
parameter :: IDX_I_NCOLOR_IN = 34
122 integer,
parameter :: IDX_I_MAXRECYCLE_PRECOND = 35
123 integer,
parameter :: IDX_I_NRECYCLE_PRECOND = 96
124 integer,
parameter :: IDX_I_FLAG_NUMFACT = 97
125 integer,
parameter :: IDX_I_FLAG_SYMBFACT = 98
126 integer,
parameter :: IDX_I_SOLVER_TYPE = 99
128 integer,
parameter :: IDX_I_METHOD2 = 8
129 integer,
parameter :: IDX_I_FLAG_CONVERGED = 81
130 integer,
parameter :: IDX_I_FLAG_DIVERGED = 82
131 integer,
parameter :: IDX_I_FLAG_MPCMATVEC = 83
133 integer,
parameter :: IDX_I_SOLVER_OPT_S = 41
134 integer,
parameter :: IDX_I_SOLVER_OPT_E = 50
136 integer,
parameter :: IDX_R_RESID = 1
137 integer,
parameter :: IDX_R_SIGMA_DIAG = 2
138 integer,
parameter :: IDX_R_SIGMA = 3
139 integer,
parameter :: IDX_R_THRESH = 4
140 integer,
parameter :: IDX_R_FILTER = 5
141 integer,
parameter :: IDX_R_PENALTY = 11
142 integer,
parameter :: IDX_R_PENALTY_ALPHA = 12
207 if (
associated(hecmat%D))
deallocate(hecmat%D)
208 if (
associated(hecmat%B))
deallocate(hecmat%B)
209 if (
associated(hecmat%X))
deallocate(hecmat%X)
210 if (
associated(hecmat%AL))
deallocate(hecmat%AL)
211 if (
associated(hecmat%AU))
deallocate(hecmat%AU)
212 if (
associated(hecmat%indexL))
deallocate(hecmat%indexL)
213 if (
associated(hecmat%indexU))
deallocate(hecmat%indexU)
214 if (
associated(hecmat%itemL))
deallocate(hecmat%itemL)
215 if (
associated(hecmat%itemU))
deallocate(hecmat%itemU)
221 hecmat%N = hecmatorg%N
222 hecmat%NP = hecmatorg%NP
223 hecmat%NDOF = hecmatorg%NDOF
224 hecmat%NPL = hecmatorg%NPL
225 hecmat%NPU = hecmatorg%NPU
226 allocate(hecmat%indexL(0:
size(hecmatorg%indexL)-1))
227 allocate(hecmat%indexU(0:
size(hecmatorg%indexU)-1))
228 allocate(hecmat%itemL (
size(hecmatorg%itemL )))
229 allocate(hecmat%itemU (
size(hecmatorg%itemU )))
230 allocate(hecmat%D (
size(hecmatorg%D )))
231 allocate(hecmat%AL(
size(hecmatorg%AL)))
232 allocate(hecmat%AU(
size(hecmatorg%AU)))
233 allocate(hecmat%B (
size(hecmatorg%B )))
234 allocate(hecmat%X (
size(hecmatorg%X )))
235 hecmat%indexL = hecmatorg%indexL
236 hecmat%indexU = hecmatorg%indexU
237 hecmat%itemL = hecmatorg%itemL
238 hecmat%itemU = hecmatorg%itemU
249 integer(kind=kint) :: ierr
250 integer(kind=kint) :: i
252 if (hecmat%N /= hecmatorg%N) ierr = 1
253 if (hecmat%NP /= hecmatorg%NP) ierr = 1
254 if (hecmat%NDOF /= hecmatorg%NDOF) ierr = 1
255 if (hecmat%NPL /= hecmatorg%NPL) ierr = 1
256 if (hecmat%NPU /= hecmatorg%NPU) ierr = 1
258 write(0,*)
'ERROR: hecmw_mat_copy_val: different profile'
261 do i = 1,
size(hecmat%D)
262 hecmat%D(i) = hecmatorg%D(i)
264 do i = 1,
size(hecmat%AL)
265 hecmat%AL(i) = hecmatorg%AL(i)
267 do i = 1,
size(hecmat%AU)
268 hecmat%AU(i) = hecmatorg%AU(i)
274 integer(kind=kint) :: iter
276 hecmat%Iarray(idx_i_iter) = iter
288 integer(kind=kint) :: method
290 hecmat%Iarray(idx_i_method) = method
302 integer(kind=kint) :: method2
304 hecmat%Iarray(idx_i_method2) = method2
316 integer(kind=kint) :: precond
318 hecmat%Iarray(idx_i_precond) = precond
330 integer(kind=kint) :: nset
332 hecmat%Iarray(idx_i_nset) = nset
344 integer(kind=kint) :: iterpremax
346 if (iterpremax.lt.0) iterpremax= 0
347 if (iterpremax.gt.4) iterpremax= 4
349 hecmat%Iarray(idx_i_iterpremax) = iterpremax
361 integer(kind=kint) :: nrest
363 hecmat%Iarray(idx_i_nrest) = nrest
375 integer(kind=kint) :: nbfgs
377 hecmat%Iarray(idx_i_nbfgs) = nbfgs
389 integer(kind=kint) :: scaling
391 hecmat%Iarray(idx_i_scaling) = scaling
403 integer(kind=kint) :: penalized
405 hecmat%Iarray(idx_i_penalized) = penalized
417 integer(kind=kint) :: penalized_b
419 hecmat%Iarray(idx_i_penalized_b) = penalized_b
431 integer(kind=kint) :: mpc_method
433 hecmat%Iarray(idx_i_mpc_method) = mpc_method
451 integer(kind=kint) :: estcond
452 hecmat%Iarray(idx_i_estcond) = estcond
463 integer(kind=kint) :: contact_elim
464 hecmat%Iarray(idx_i_contact_elim) = contact_elim
469 integer(kind=kint) :: iterlog
471 hecmat%Iarray(idx_i_iterlog) = iterlog
483 integer(kind=kint) :: timelog
485 hecmat%Iarray(idx_i_timelog) = timelog
503 integer(kind=kint) :: dump_type
504 hecmat%Iarray(idx_i_dump) = dump_type
515 integer(kind=kint) :: dump_exit
516 hecmat%Iarray(idx_i_dump_exit) = dump_exit
527 integer(kind=kint) :: usejad
528 hecmat%Iarray(idx_i_usejad) = usejad
539 integer(kind=kint) :: ncolor_in
540 hecmat%Iarray(idx_i_ncolor_in) = ncolor_in
551 integer(kind=kint) :: maxrecycle_precond
552 if (maxrecycle_precond > 100) maxrecycle_precond = 100
553 hecmat%Iarray(idx_i_maxrecycle_precond) = maxrecycle_precond
564 hecmat%Iarray(idx_i_nrecycle_precond) = 0
569 hecmat%Iarray(idx_i_nrecycle_precond) = hecmat%Iarray(idx_i_nrecycle_precond) + 1
580 integer(kind=kint) :: flag_numfact
581 hecmat%Iarray(idx_i_flag_numfact) = flag_numfact
592 integer(kind=kint) :: flag_symbfact
593 hecmat%Iarray(idx_i_flag_symbfact) = flag_symbfact
598 hecmat%Iarray(idx_i_flag_symbfact) = 0
609 integer(kind=kint) :: solver_type
610 hecmat%Iarray(idx_i_solver_type) = solver_type
615 integer(kind=kint) :: flag_converged
616 hecmat%Iarray(idx_i_flag_converged) = flag_converged
627 integer(kind=kint) :: flag_diverged
628 hecmat%Iarray(idx_i_flag_diverged) = flag_diverged
639 integer(kind=kint) :: flag_mpcmatvec
640 hecmat%Iarray(idx_i_flag_mpcmatvec) = flag_mpcmatvec
651 integer(kind=kint) :: solver_opt(:)
652 integer(kind=kint) :: nopt
653 nopt = idx_i_solver_opt_e - idx_i_solver_opt_s + 1
654 hecmat%Iarray(idx_i_solver_opt_s:idx_i_solver_opt_e) = solver_opt(1:nopt)
659 integer(kind=kint) :: solver_opt(:)
660 integer(kind=kint) :: nopt
661 nopt = idx_i_solver_opt_e - idx_i_solver_opt_s + 1
662 solver_opt(1:nopt) = hecmat%Iarray(idx_i_solver_opt_s:idx_i_solver_opt_e)
667 real(kind=
kreal) :: resid
669 hecmat%Rarray(idx_r_resid) = resid
681 real(kind=
kreal) :: sigma_diag
683 if( sigma_diag < 0.d0 )
then
684 hecmat%Rarray(idx_r_sigma_diag) = -1.d0
685 elseif( sigma_diag < 1.d0 )
then
686 hecmat%Rarray(idx_r_sigma_diag) = 1.d0
687 elseif( sigma_diag > 2.d0 )
then
688 hecmat%Rarray(idx_r_sigma_diag) = 2.d0
690 hecmat%Rarray(idx_r_sigma_diag) = sigma_diag
703 real(kind=
kreal) :: sigma
705 if (sigma < 0.d0)
then
706 hecmat%Rarray(idx_r_sigma) = 0.d0
707 elseif (sigma > 1.d0)
then
708 hecmat%Rarray(idx_r_sigma) = 1.d0
710 hecmat%Rarray(idx_r_sigma) = sigma
723 real(kind=
kreal) :: thresh
725 hecmat%Rarray(idx_r_thresh) = thresh
737 real(kind=
kreal) :: filter
739 hecmat%Rarray(idx_r_filter) = filter
751 real(kind=
kreal) :: penalty
753 hecmat%Rarray(idx_r_penalty) = penalty
765 real(kind=
kreal) :: alpha
767 hecmat%Rarray(idx_r_penalty_alpha) = alpha
781 integer(kind=kint) :: ndiag, i
784 ndiag = hecmat%NDOF**2 * hecmat%NP
796 real(kind=
kreal),
pointer :: diag(:)
797 integer(kind=kint) :: i, k, idx, ndof, np
801 allocate(diag(ndof * np))
805 idx = ndof * ndof * (i - 1) + (k-1) * ndof + k
806 diag(ndof * (i - 1) + k) = hecmat%D(idx)
813 integer(kind=kint) :: nrecycle, maxrecycle
814 if (hecmat%Iarray(idx_i_flag_symbfact) >= 1)
then
815 hecmat%Iarray(idx_i_flag_numfact)=1
817 elseif (hecmat%Iarray(idx_i_flag_numfact) > 1)
then
819 hecmat%Iarray(idx_i_flag_numfact) = 1
820 elseif (hecmat%Iarray(idx_i_flag_numfact) == 1)
then
823 if ( nrecycle < maxrecycle )
then
824 hecmat%Iarray(idx_i_flag_numfact) = 0
840 if (
associated(src%D)) dest%D => src%D
841 if (
associated(src%B)) dest%B => src%B
842 if (
associated(src%X)) dest%X => src%X
843 if (
associated(src%AL)) dest%AL => src%AL
844 if (
associated(src%AU)) dest%AU => src%AU
845 if (
associated(src%indexL)) dest%indexL => src%indexL
846 if (
associated(src%indexU)) dest%indexU => src%indexU
847 if (
associated(src%itemL)) dest%itemL => src%itemL
848 if (
associated(src%itemU)) dest%itemU => src%itemU
849 dest%Iarray(:) = src%Iarray(:)
850 dest%Rarray(:) = src%Rarray(:)
868 integer(kind=kint) :: i, j, k, nn, pre, pp, js, je
870 nn = hecmat%NDOF * hecmat%NDOF
871 allocate (hecmat%indexA(0:hecmat%NP))
872 allocate (hecmat%itemA(hecmat%NPA))
879 indexa(i) = i + hecmat%indexL(i) + hecmat%indexU(i)
881 pre = i - 1 + hecmat%indexU(i - 1)
882 js= hecmat%indexL(i - 1) + 1
883 je= hecmat%indexL(i )
886 hecmat%itemA(pp) = hecmat%itemL(j)
888 hecmat%A(nn * pp + k) = hecmat%AL(nn * j + k)
892 pp = i + hecmat%indexU(i - 1) + hecmat%indexL(i)
895 hecmat%A(nn * pp + k) = hecmat%D(nn * i + k)
898 pre = i + hecmat%indexL(i)
899 js= hecmat%indexU(i - 1) + 1
900 je= hecmat%indexU(i )
903 hecmat%itemA(pp) = hecmat%itemU(j)
905 hecmat%A(nn * pp + k) = hecmat%AU(nn * j + k)
integer(kind=kint) function, public hecmw_mat_get_solver_type(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_flag_mpcmatvec(hecMAT)
subroutine, public hecmw_mat_set_usejad(hecMAT, usejad)
real(kind=kreal) function, dimension(:), pointer, public hecmw_mat_diag(hecMAT)
Extract diagonal components from matrix D into a 1D vector Returns: diag(i) = D(ndof*ndof*(node-1) + ...
subroutine, public hecmw_mat_set_ncolor_in(hecMAT, ncolor_in)
integer(kind=kint) function, public hecmw_mat_get_flag_diverged(hecMAT)
subroutine, public hecmw_mat_integrate(hecMAT)
Integrate matrix components into a single array for efficient access.
subroutine, public hecmw_mat_clear_flag_symbfact(hecMAT)
real(kind=kreal) function, public hecmw_mat_get_sigma_diag(hecMAT)
real(kind=kreal) function, public hecmw_mat_diag_max(hecMAT, hecMESH)
integer(kind=kint) function, public hecmw_mat_get_iterpremax(hecMAT)
subroutine, public hecmw_mat_set_sigma(hecMAT, sigma)
subroutine, public hecmw_mat_set_contact_elim(hecMAT, contact_elim)
integer(kind=kint) function, public hecmw_mat_get_dump_exit(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_nrest(hecMAT)
subroutine, public hecmw_mat_init(hecMAT)
subroutine, public hecmw_mat_set_iter(hecMAT, iter)
subroutine, public hecmw_mat_set_iterlog(hecMAT, iterlog)
subroutine, public hecmw_mat_finalize(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_nrecycle_precond(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_penalized(hecMAT)
subroutine, public hecmw_mat_copy_val(hecMATorg, hecMAT)
subroutine, public hecmw_mat_set_flag_diverged(hecMAT, flag_diverged)
subroutine, public hecmw_mat_set_penalized_b(hecMAT, penalized_b)
real(kind=kreal) function, public hecmw_mat_get_resid(hecMAT)
subroutine, public hecmw_mat_set_estcond(hecMAT, estcond)
integer(kind=kint) function, public hecmw_mat_get_maxrecycle_precond(hecMAT)
subroutine, public hecmw_mat_set_thresh(hecMAT, thresh)
subroutine, public hecmw_mat_set_flag_converged(hecMAT, flag_converged)
integer(kind=kint) function, public hecmw_mat_get_flag_converged(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_penalized_b(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_dump(hecMAT)
real(kind=kreal) function, public hecmw_mat_get_penalty_alpha(hecMAT)
subroutine, public hecmw_mat_get_solver_opt(hecMAT, solver_opt)
integer(kind=kint) function, public hecmw_mat_get_nbfgs(hecMAT)
subroutine, public hecmw_mat_substitute(dest, src)
real(kind=kreal) function, public hecmw_mat_get_penalty(hecMAT)
subroutine, public hecmw_mat_recycle_precond_setting(hecMAT)
subroutine, public hecmw_mat_incr_nrecycle_precond(hecMAT)
subroutine, public hecmw_mat_set_sigma_diag(hecMAT, sigma_diag)
subroutine, public hecmw_mat_set_penalty_alpha(hecMAT, alpha)
subroutine, public hecmw_mat_clear_b(hecMAT)
subroutine, public hecmw_mat_set_dump_exit(hecMAT, dump_exit)
integer(kind=kint) function, public hecmw_mat_get_iterlog(hecMAT)
subroutine, public hecmw_mat_set_flag_symbfact(hecMAT, flag_symbfact)
integer(kind=kint) function, public hecmw_mat_get_timelog(hecMAT)
subroutine, public hecmw_mat_set_nset(hecMAT, nset)
subroutine, public hecmw_mat_set_flag_numfact(hecMAT, flag_numfact)
subroutine, public hecmw_mat_copy_profile(hecMATorg, hecMAT)
subroutine, public hecmw_mat_set_method(hecMAT, method)
subroutine, public hecmw_mat_set_filter(hecMAT, filter)
integer(kind=kint) function, public hecmw_mat_get_method2(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_flag_numfact(hecMAT)
subroutine, public hecmw_mat_set_penalized(hecMAT, penalized)
subroutine, public hecmw_mat_set_penalty(hecMAT, penalty)
subroutine, public hecmw_mat_set_maxrecycle_precond(hecMAT, maxrecycle_precond)
subroutine, public hecmw_mat_clear(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_contact_elim(hecMAT)
subroutine, public hecmw_mat_set_timelog(hecMAT, timelog)
subroutine, public hecmw_mat_set_resid(hecMAT, resid)
real(kind=kreal) function, public hecmw_mat_get_thresh(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_flag_symbfact(hecMAT)
subroutine, public hecmw_mat_set_flag_mpcmatvec(hecMAT, flag_mpcmatvec)
integer(kind=kint) function, public hecmw_mat_get_method(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_precond(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_nset(hecMAT)
subroutine, public hecmw_mat_set_iterpremax(hecMAT, iterpremax)
real(kind=kreal) function, public hecmw_mat_get_filter(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_estcond(hecMAT)
subroutine, public hecmw_mat_set_nrest(hecMAT, nrest)
integer(kind=kint) function, public hecmw_mat_get_usejad(hecMAT)
subroutine, public hecmw_mat_set_solver_type(hecMAT, solver_type)
subroutine, public hecmw_mat_set_method2(hecMAT, method2)
integer(kind=kint) function, public hecmw_mat_get_mpc_method(hecMAT)
integer(kind=kint) function, public hecmw_mat_get_ncolor_in(hecMAT)
real(kind=kreal) function, public hecmw_mat_get_sigma(hecMAT)
subroutine, public hecmw_mat_set_nbfgs(hecMAT, nbfgs)
integer(kind=kint) function, public hecmw_mat_get_iter(hecMAT)
subroutine, public hecmw_mat_set_precond(hecMAT, precond)
subroutine, public hecmw_mat_set_solver_opt(hecMAT, solver_opt)
integer(kind=kint) function, public hecmw_mat_get_scaling(hecMAT)
subroutine, public hecmw_mat_reset_nrecycle_precond(hecMAT)
subroutine, public hecmw_mat_set_scaling(hecMAT, scaling)
subroutine, public hecmw_mat_set_mpc_method(hecMAT, mpc_method)
subroutine, public hecmw_mat_set_dump(hecMAT, dump_type)
integer(kind=kint), parameter hecmw_max
integer(kind=4), parameter kreal
subroutine hecmw_nullify_matrix(P)
subroutine hecmw_allreduce_r1(hecMESH, s, ntag)