OpenRadioss 2025.1.11
OpenRadioss project
Loading...
Searching...
No Matches
srank_revealing.F File Reference

Go to the source code of this file.

Functions/Subroutines

subroutine smumps_get_ns_options_facto (n, keep, icntl, mpg)
subroutine smumps_get_ns_options_solve (icntl, keep, nrhs, mpg, info)
subroutine smumps_rr_init_pointers (id)
subroutine smumps_rr_free_pointers (id)

Function/Subroutine Documentation

◆ smumps_get_ns_options_facto()

subroutine smumps_get_ns_options_facto ( integer n,
integer, dimension(500) keep,
integer, dimension(60) icntl,
integer mpg )

Definition at line 14 of file srank_revealing.F.

15 IMPLICIT NONE
16 INTEGER N, KEEP(500), ICNTL(60), MPG
17 keep(19)=0
18 RETURN

◆ smumps_get_ns_options_solve()

subroutine smumps_get_ns_options_solve ( integer, dimension(60), intent(in) icntl,
integer, dimension(500), intent(in) keep,
integer, intent(in) nrhs,
integer, intent(in) mpg,
integer, dimension(80), intent(inout) info )

Definition at line 20 of file srank_revealing.F.

22 IMPLICIT NONE
23 INTEGER, intent(in) :: KEEP(500), NRHS, MPG, ICNTL(60)
24 INTEGER, intent(inout):: INFO(80)
25 IF (keep(19).EQ.0.AND.keep(110).EQ.0) THEN
26 IF (keep(111).NE.0) THEN
27 info(1) = -37
28 info(2) = 56
29 IF (keep(110).EQ.0) info(2) = 24
30 IF(mpg.GT.0) THEN
31 WRITE( mpg,'(A)')
32 &'** ERROR : Null space computation requirement'
33 WRITE( mpg,'(A)')
34 &'** not consistent with factorization options'
35 ENDIF
36 GOTO 333
37 ENDIF
38 ENDIF
39 IF (icntl(9).NE.1) THEN
40 IF (keep(111).NE.0) THEN
41 info(1) = -37
42 info(2) = 9
43 IF (mpg.GT.0) THEN
44 WRITE(mpg,'(A)')
45 &'** error icntl(25) incompatible with '
46 WRITE( MPG,'(a)')
47 &'** option transposed system(icntl(9).ne.1) '
48 ENDIF
49 ENDIF
50 GOTO 333
51 ENDIF
52.EQ. IF (KEEP(19)2) THEN
53.NE..AND..EQ. IF ((KEEP(111)0)(KEEP(50)0)) THEN
54 INFO(1) = -37
55 INFO(2) = 0
56.GT. IF (MPG0) THEN
57 WRITE(MPG,'(a)')
58 &'** error icntl(25) incompatible with '
59 WRITE( MPG,'(a)')
60 &'** option rrqr(icnlt(56)=2) and unsym. matrices '
61 ENDIF
62 ENDIF
63 GOTO 333
64 ENDIF
65.eq..AND..NE. IF (KEEP(111)-1NRHSKEEP(112)+KEEP(17))THEN
66 INFO(1)=-32
67 INFO(2)=NRHS
68 GOTO 333
69 ENDIF
70.gt..AND..NE. IF (KEEP(111)0 NRHS 1) THEN
71 INFO(1)=-32
72 INFO(2)=NRHS
73 GOTO 333
74 ENDIF
75.NE..AND..NE. IF (KEEP(248) 0KEEP(111)0) THEN
76.GT. IF (MPG0) THEN
77 WRITE(MPG,'(a)')
78 & ' error: icntl(20) and icntl(30) functionalities ',
79 & ' incompatible with null space'
80 ENDIF
81 INFO(1) = -37
82.NE. IF (KEEP(237)0) THEN
83 INFO(2) = 30
84.GT. IF (MPG0) THEN
85 WRITE(MPG,'(a)')
86 & ' error: icntl(30) functionality ',
87 & ' incompatible with null space'
88 ENDIF
89 ELSE
90.GT. IF (MPG0) THEN
91 WRITE(MPG,'(a)')
92 & ' error: icntl(20) functionality ',
93 & ' incompatible with null space'
94 ENDIF
95 INFO(2) = 20
96 ENDIF
97 GOTO 333
98 ENDIF
99.LT..OR. IF (( KEEP(111) -1 )
100.GT..OR. & (KEEP(111)KEEP(112)+KEEP(17))
101.EQ..AND..EQ. & (KEEP(111) -1 KEEP(112)+KEEP(17)0))
102 & THEN
103 INFO(1)=-36
104 INFO(2)=KEEP(111)
105 GOTO 333
106 ENDIF
107.NE..AND..NE. IF (KEEP(221)0KEEP(111)0) THEN
108 INFO(1)=-37
109 INFO(2)=26
110 GOTO 333
111 ENDIF
112 333 CONTINUE
113 RETURN

◆ smumps_rr_free_pointers()

subroutine smumps_rr_free_pointers ( type (smumps_struc) id)

Definition at line 125 of file srank_revealing.F.

127 IMPLICIT NONE
128 TYPE (SMUMPS_STRUC) id
129 IF (associated(id%root%QR_TAU)) THEN
130 DEALLOCATE(id%root%QR_TAU)
131 NULLIFY(id%root%QR_TAU)
132 ENDIF
133 IF (associated(id%root%SVD_U)) THEN
134 DEALLOCATE(id%root%SVD_U)
135 NULLIFY(id%root%SVD_U)
136 ENDIF
137 IF (associated(id%root%SVD_VT)) THEN
138 DEALLOCATE(id%root%SVD_VT)
139 NULLIFY(id%root%SVD_VT)
140 ENDIF
141 IF (associated(id%root%SINGULAR_VALUES)) THEN
142 DEALLOCATE(id%root%SINGULAR_VALUES)
143 NULLIFY(id%root%SINGULAR_VALUES)
144 ENDIF
145 RETURN
initmumps id

◆ smumps_rr_init_pointers()

subroutine smumps_rr_init_pointers ( type (smumps_struc) id)

Definition at line 115 of file srank_revealing.F.

117 IMPLICIT NONE
118 TYPE (SMUMPS_STRUC) id
119 NULLIFY(id%root%QR_TAU)
120 NULLIFY(id%root%SVD_U)
121 NULLIFY(id%root%SVD_VT)
122 NULLIFY(id%root%SINGULAR_VALUES)
123 RETURN