Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||
3 | SLEPc - Scalable Library for Eigenvalue Problem Computations | ||
4 | Copyright (c) 2002-, Universitat Politecnica de Valencia, Spain | ||
5 | |||
6 | This file is part of SLEPc. | ||
7 | SLEPc is distributed under a 2-clause BSD license (see LICENSE). | ||
8 | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - | ||
9 | */ | ||
10 | /* | ||
11 | SLEPc nonlinear eigensolver: "nleigs" | ||
12 | |||
13 | Method: NLEIGS | ||
14 | |||
15 | Algorithm: | ||
16 | |||
17 | Fully rational Krylov method for nonlinear eigenvalue problems. | ||
18 | |||
19 | References: | ||
20 | |||
21 | [1] S. Guttel et al., "NLEIGS: A class of robust fully rational Krylov | ||
22 | method for nonlinear eigenvalue problems", SIAM J. Sci. Comput. | ||
23 | 36(6):A2842-A2864, 2014. | ||
24 | */ | ||
25 | |||
26 | #include <slepc/private/nepimpl.h> /*I "slepcnep.h" I*/ | ||
27 | #include <slepcblaslapack.h> | ||
28 | #include "nleigs.h" | ||
29 | |||
30 | 155397 | PetscErrorCode NEPNLEIGSBackTransform(PetscObject ob,PetscInt n,PetscScalar *valr,PetscScalar *vali) | |
31 | { | ||
32 | 155397 | NEP nep; | |
33 | 155397 | PetscInt j; | |
34 | #if !defined(PETSC_USE_COMPLEX) | ||
35 | 60461 | PetscScalar t; | |
36 | #endif | ||
37 | |||
38 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
155397 | PetscFunctionBegin; |
39 | 155397 | nep = (NEP)ob; | |
40 | #if !defined(PETSC_USE_COMPLEX) | ||
41 |
2/2✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
|
187583 | for (j=0;j<n;j++) { |
42 |
2/2✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
|
127122 | if (vali[j] == 0) valr[j] = 1.0 / valr[j] + nep->target; |
43 | else { | ||
44 | 27654 | t = valr[j] * valr[j] + vali[j] * vali[j]; | |
45 | 27654 | valr[j] = valr[j] / t + nep->target; | |
46 | 27654 | vali[j] = - vali[j] / t; | |
47 | } | ||
48 | } | ||
49 | #else | ||
50 |
2/2✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
|
291185 | for (j=0;j<n;j++) { |
51 | 196249 | valr[j] = 1.0 / valr[j] + nep->target; | |
52 | } | ||
53 | #endif | ||
54 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
155397 | PetscFunctionReturn(PETSC_SUCCESS); |
55 | } | ||
56 | |||
57 | /* Computes the roots of a polynomial */ | ||
58 | 30 | static PetscErrorCode NEPNLEIGSAuxiliarPRootFinder(PetscInt deg,PetscScalar *polcoeffs,PetscScalar *wr,PetscScalar *wi,PetscBool *avail) | |
59 | { | ||
60 | 30 | PetscScalar *C; | |
61 | 30 | PetscBLASInt n_,lwork; | |
62 | 30 | PetscInt i; | |
63 | #if defined(PETSC_USE_COMPLEX) | ||
64 | 15 | PetscReal *rwork=NULL; | |
65 | #endif | ||
66 | 30 | PetscScalar *work; | |
67 | 30 | PetscBLASInt info; | |
68 | |||
69 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
70 | 30 | *avail = PETSC_TRUE; | |
71 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | if (deg>0) { |
72 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscCalloc1(deg*deg,&C)); |
73 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscBLASIntCast(deg,&n_)); |
74 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
30 | for (i=0;i<deg-1;i++) { |
75 | ✗ | C[(deg+1)*i+1] = 1.0; | |
76 | ✗ | C[(deg-1)*deg+i] = -polcoeffs[deg-i]/polcoeffs[0]; | |
77 | } | ||
78 | 30 | C[deg*deg+-1] = -polcoeffs[1]/polcoeffs[0]; | |
79 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscBLASIntCast(3*deg,&lwork)); |
80 | |||
81 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscFPTrapPush(PETSC_FP_TRAP_OFF)); |
82 | #if !defined(PETSC_USE_COMPLEX) | ||
83 |
4/6✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
|
15 | PetscCall(PetscMalloc1(lwork,&work)); |
84 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
15 | PetscCallBLAS("LAPACKgeev",LAPACKgeev_("N","N",&n_,C,&n_,wr,wi,NULL,&n_,NULL,&n_,work,&lwork,&info)); |
85 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 5 times.
|
15 | if (info) *avail = PETSC_FALSE; |
86 |
5/8✓ Branch 0 taken 5 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 1 times.
✓ Branch 3 taken 4 times.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
|
15 | PetscCall(PetscFree(work)); |
87 | #else | ||
88 |
4/6✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
|
15 | PetscCall(PetscMalloc2(2*deg,&rwork,lwork,&work)); |
89 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
15 | PetscCallBLAS("LAPACKgeev",LAPACKgeev_("N","N",&n_,C,&n_,wr,NULL,&n_,NULL,&n_,work,&lwork,rwork,&info)); |
90 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 5 times.
|
15 | if (info) *avail = PETSC_FALSE; |
91 |
4/6✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
|
15 | PetscCall(PetscFree2(rwork,work)); |
92 | #endif | ||
93 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscFPTrapPop()); |
94 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
30 | PetscCall(PetscFree(C)); |
95 | } | ||
96 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
6 | PetscFunctionReturn(PETSC_SUCCESS); |
97 | } | ||
98 | |||
99 | 136 | static PetscErrorCode NEPNLEIGSAuxiliarRmDuplicates(PetscInt nin,PetscScalar *pin,PetscInt *nout,PetscScalar *pout,PetscInt max) | |
100 | { | ||
101 | 136 | PetscInt i,j; | |
102 | |||
103 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
136 | PetscFunctionBegin; |
104 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
333 | for (i=0;i<nin;i++) { |
105 |
3/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
|
197 | if (max && *nout>=max) break; |
106 | 197 | pout[(*nout)++] = pin[i]; | |
107 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
498 | for (j=0;j<*nout-1;j++) |
108 |
2/2✓ Branch 0 taken 3 times.
✓ Branch 1 taken 8 times.
|
308 | if (PetscAbsScalar(pin[i]-pout[j])<PETSC_MACHINE_EPSILON*100) { |
109 | 7 | (*nout)--; | |
110 | 7 | break; | |
111 | } | ||
112 | } | ||
113 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
136 | PetscFunctionReturn(PETSC_SUCCESS); |
114 | } | ||
115 | |||
116 | 110 | static PetscErrorCode NEPNLEIGSFNSingularities(FN f,PetscInt *nisol,PetscScalar **isol,PetscBool *rational) | |
117 | { | ||
118 | 110 | FNCombineType ctype; | |
119 | 110 | FN f1,f2; | |
120 | 110 | PetscInt i,nq,nisol1,nisol2; | |
121 | 110 | PetscScalar *qcoeff,*wr,*wi,*isol1,*isol2; | |
122 | 110 | PetscBool flg,avail,rat1,rat2; | |
123 | |||
124 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
110 | PetscFunctionBegin; |
125 | 110 | *rational = PETSC_FALSE; | |
126 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
110 | PetscCall(PetscObjectTypeCompare((PetscObject)f,FNRATIONAL,&flg)); |
127 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
110 | if (flg) { |
128 | 100 | *rational = PETSC_TRUE; | |
129 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
100 | PetscCall(FNRationalGetDenominator(f,&nq,&qcoeff)); |
130 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
100 | if (nq>1) { |
131 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscMalloc2(nq-1,&wr,nq-1,&wi)); |
132 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPNLEIGSAuxiliarPRootFinder(nq-1,qcoeff,wr,wi,&avail)); |
133 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | if (avail) { |
134 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscCalloc1(nq-1,isol)); |
135 | 30 | *nisol = 0; | |
136 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
60 | for (i=0;i<nq-1;i++) |
137 | #if !defined(PETSC_USE_COMPLEX) | ||
138 |
1/2✓ Branch 0 taken 5 times.
✗ Branch 1 not taken.
|
15 | if (wi[i]==0) |
139 | #endif | ||
140 | 30 | (*isol)[(*nisol)++] = wr[i]; | |
141 | 30 | nq = *nisol; *nisol = 0; | |
142 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
60 | for (i=0;i<nq;i++) wr[i] = (*isol)[i]; |
143 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPNLEIGSAuxiliarRmDuplicates(nq,wr,nisol,*isol,0)); |
144 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscFree2(wr,wi)); |
145 | ✗ | } else { *nisol=0; *isol = NULL; } | |
146 | 70 | } else { *nisol = 0; *isol = NULL; } | |
147 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
100 | PetscCall(PetscFree(qcoeff)); |
148 | } | ||
149 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
110 | PetscCall(PetscObjectTypeCompare((PetscObject)f,FNCOMBINE,&flg)); |
150 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
110 | if (flg) { |
151 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(FNCombineGetChildren(f,&ctype,&f1,&f2)); |
152 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (ctype != FN_COMBINE_COMPOSE && ctype != FN_COMBINE_DIVIDE) { |
153 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(NEPNLEIGSFNSingularities(f1,&nisol1,&isol1,&rat1)); |
154 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(NEPNLEIGSFNSingularities(f2,&nisol2,&isol2,&rat2)); |
155 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (nisol1+nisol2>0) { |
156 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscCalloc1(nisol1+nisol2,isol)); |
157 | 10 | *nisol = 0; | |
158 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(NEPNLEIGSAuxiliarRmDuplicates(nisol1,isol1,nisol,*isol,0)); |
159 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(NEPNLEIGSAuxiliarRmDuplicates(nisol2,isol2,nisol,*isol,0)); |
160 | } | ||
161 |
2/4✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
|
10 | *rational = (rat1&&rat2)?PETSC_TRUE:PETSC_FALSE; |
162 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
10 | PetscCall(PetscFree(isol1)); |
163 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
10 | PetscCall(PetscFree(isol2)); |
164 | } | ||
165 | } | ||
166 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
22 | PetscFunctionReturn(PETSC_SUCCESS); |
167 | } | ||
168 | |||
169 | 30 | static PetscErrorCode NEPNLEIGSRationalSingularities(NEP nep,PetscInt *ndptx,PetscScalar *dxi,PetscBool *rational) | |
170 | { | ||
171 | 30 | PetscInt nt,i,nisol; | |
172 | 30 | FN f; | |
173 | 30 | PetscScalar *isol; | |
174 | 30 | PetscBool rat; | |
175 | |||
176 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
177 | 30 | *rational = PETSC_TRUE; | |
178 | 30 | *ndptx = 0; | |
179 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPGetSplitOperatorInfo(nep,&nt,NULL)); |
180 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
120 | for (i=0;i<nt;i++) { |
181 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
90 | PetscCall(NEPGetSplitOperatorTerm(nep,i,NULL,&f)); |
182 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
90 | PetscCall(NEPNLEIGSFNSingularities(f,&nisol,&isol,&rat)); |
183 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
90 | if (nisol) { |
184 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPNLEIGSAuxiliarRmDuplicates(nisol,isol,ndptx,dxi,0)); |
185 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
30 | PetscCall(PetscFree(isol)); |
186 | } | ||
187 |
2/4✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
|
90 | *rational = ((*rational)&&rat)?PETSC_TRUE:PETSC_FALSE; |
188 | } | ||
189 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
6 | PetscFunctionReturn(PETSC_SUCCESS); |
190 | } | ||
191 | |||
192 | #if defined(SLEPC_MISSING_LAPACK_GGEV3) | ||
193 | #define LAPGEEV "ggev" | ||
194 | #else | ||
195 | #define LAPGEEV "ggev3" | ||
196 | #endif | ||
197 | |||
198 | /* Adaptive Anderson-Antoulas algorithm */ | ||
199 | 233 | static PetscErrorCode NEPNLEIGSAAAComputation(NEP nep,PetscInt ndpt,PetscScalar *ds,PetscScalar *F,PetscInt *ndptx,PetscScalar *dxi) | |
200 | { | ||
201 | 233 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
202 | 233 | PetscScalar mean=0.0,*z,*f,*C,*A,*VT,*work,*ww,szero=0.0,sone=1.0; | |
203 | 233 | PetscScalar *N,*D; | |
204 | 233 | PetscReal *S,norm,err,*R; | |
205 | 233 | PetscInt i,k,j,idx=0,cont; | |
206 | 233 | PetscBLASInt n_,m_,lda_,lwork,info,one=1; | |
207 | #if defined(PETSC_USE_COMPLEX) | ||
208 | 121 | PetscReal *rwork; | |
209 | #endif | ||
210 | |||
211 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
233 | PetscFunctionBegin; |
212 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscBLASIntCast(8*ndpt,&lwork)); |
213 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscMalloc5(ndpt,&R,ndpt,&z,ndpt,&f,ndpt*ndpt,&C,ndpt,&ww)); |
214 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscMalloc6(ndpt*ndpt,&A,ndpt,&S,ndpt*ndpt,&VT,lwork,&work,ndpt,&D,ndpt,&N)); |
215 | #if defined(PETSC_USE_COMPLEX) | ||
216 |
4/6✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
|
121 | PetscCall(PetscMalloc1(8*ndpt,&rwork)); |
217 | #endif | ||
218 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscFPTrapPush(PETSC_FP_TRAP_OFF)); |
219 | norm = 0.0; | ||
220 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
23533 | for (i=0;i<ndpt;i++) { |
221 | 23300 | mean += F[i]; | |
222 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
35152 | norm = PetscMax(PetscAbsScalar(F[i]),norm); |
223 | } | ||
224 | 233 | mean /= ndpt; | |
225 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscBLASIntCast(ndpt,&lda_)); |
226 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
23533 | for (i=0;i<ndpt;i++) R[i] = PetscAbsScalar(F[i]-mean); |
227 | /* next support point */ | ||
228 | err = 0.0; | ||
229 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
23533 | for (i=0;i<ndpt;i++) if (R[i]>=err) {idx = i; err = R[i];} |
230 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
529 | for (k=0;k<ndpt-1;k++) { |
231 | 529 | z[k] = ds[idx]; f[k] = F[idx]; R[idx] = -1.0; | |
232 | /* next column of Cauchy matrix */ | ||
233 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
53429 | for (i=0;i<ndpt;i++) { |
234 | 52900 | C[i+k*ndpt] = 1.0/(ds[i]-ds[idx]); | |
235 | } | ||
236 | |||
237 |
4/6✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
529 | PetscCall(PetscArrayzero(A,ndpt*ndpt)); |
238 | cont = 0; | ||
239 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
53429 | for (i=0;i<ndpt;i++) { |
240 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
52900 | if (R[i]!=-1.0) { |
241 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
152348 | for (j=0;j<=k;j++)A[cont+j*ndpt] = C[i+j*ndpt]*F[i]-C[i+j*ndpt]*f[j]; |
242 | 51866 | cont++; | |
243 | } | ||
244 | } | ||
245 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
529 | PetscCall(PetscBLASIntCast(cont,&m_)); |
246 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
529 | PetscCall(PetscBLASIntCast(k+1,&n_)); |
247 | #if defined(PETSC_USE_COMPLEX) | ||
248 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
290 | PetscCallBLAS("LAPACKgesvd",LAPACKgesvd_("N","A",&m_,&n_,A,&lda_,S,NULL,&lda_,VT,&lda_,work,&lwork,rwork,&info)); |
249 | #else | ||
250 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
239 | PetscCallBLAS("LAPACKgesvd",LAPACKgesvd_("N","A",&m_,&n_,A,&lda_,S,NULL,&lda_,VT,&lda_,work,&lwork,&info)); |
251 | #endif | ||
252 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
529 | SlepcCheckLapackInfo("gesvd",info); |
253 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1563 | for (i=0;i<=k;i++) { |
254 | 1034 | ww[i] = PetscConj(VT[i*ndpt+k]); | |
255 | 1034 | D[i] = ww[i]*f[i]; | |
256 | } | ||
257 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
529 | PetscCallBLAS("BLASgemv",BLASgemv_("N",&lda_,&n_,&sone,C,&lda_,D,&one,&szero,N,&one)); |
258 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
529 | PetscCallBLAS("BLASgemv",BLASgemv_("N",&lda_,&n_,&sone,C,&lda_,ww,&one,&szero,D,&one)); |
259 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
53429 | for (i=0;i<ndpt;i++) if (R[i]>=0) R[i] = PetscAbsScalar(F[i]-N[i]/D[i]); |
260 | /* next support point */ | ||
261 | err = 0.0; | ||
262 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
53429 | for (i=0;i<ndpt;i++) if (R[i]>=err) {idx = i; err = R[i];} |
263 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
529 | if (err <= ctx->ddtol*norm) break; |
264 | } | ||
265 | |||
266 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
233 | PetscCheck(k<ndpt-1,PetscObjectComm((PetscObject)nep),PETSC_ERR_CONV_FAILED,"Failed to determine singularities automatically in general problem"); |
267 | /* poles */ | ||
268 |
4/6✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscArrayzero(C,ndpt*ndpt)); |
269 |
4/6✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscArrayzero(A,ndpt*ndpt)); |
270 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
762 | for (i=0;i<=k;i++) { |
271 | 529 | C[i+ndpt*i] = 1.0; | |
272 | 529 | A[(i+1)*ndpt] = ww[i]; | |
273 | 529 | A[i+1] = 1.0; | |
274 | 529 | A[i+1+(i+1)*ndpt] = z[i]; | |
275 | } | ||
276 | 233 | C[0] = 0.0; C[k+1+(k+1)*ndpt] = 1.0; | |
277 | 233 | n_++; | |
278 | #if defined(PETSC_USE_COMPLEX) | ||
279 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
121 | PetscCallBLAS("LAPACK" LAPGEEV,LAPACKggevalt_("N","N",&n_,A,&lda_,C,&lda_,D,N,NULL,&lda_,NULL,&lda_,work,&lwork,rwork,&info)); |
280 | #else | ||
281 |
10/20✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 1 times.
✓ Branch 12 taken 1 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 1 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
112 | PetscCallBLAS("LAPACK" LAPGEEV,LAPACKggevalt_("N","N",&n_,A,&lda_,C,&lda_,D,VT,N,NULL,&lda_,NULL,&lda_,work,&lwork,&info)); |
282 | #endif | ||
283 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
233 | SlepcCheckLapackInfo(LAPGEEV,info); |
284 | cont = 0.0; | ||
285 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
995 | for (i=0;i<n_;i++) if (N[i]!=0.0) { |
286 | 237 | dxi[cont++] = D[i]/N[i]; | |
287 | } | ||
288 | 233 | *ndptx = cont; | |
289 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscFPTrapPop()); |
290 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscFree5(R,z,f,C,ww)); |
291 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
233 | PetscCall(PetscFree6(A,S,VT,work,D,N)); |
292 | #if defined(PETSC_USE_COMPLEX) | ||
293 |
5/8✓ Branch 0 taken 5 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 1 times.
✓ Branch 3 taken 4 times.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 1 times.
|
121 | PetscCall(PetscFree(rwork)); |
294 | #endif | ||
295 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
47 | PetscFunctionReturn(PETSC_SUCCESS); |
296 | } | ||
297 | |||
298 | /* Singularities using Adaptive Anderson-Antoulas algorithm */ | ||
299 | 124 | static PetscErrorCode NEPNLEIGSAAASingularities(NEP nep,PetscInt ndpt,PetscScalar *ds,PetscInt *ndptx,PetscScalar *dxi) | |
300 | { | ||
301 | 124 | Vec u,v,w; | |
302 | 124 | PetscRandom rand=NULL; | |
303 | 124 | PetscScalar *F,*isol; | |
304 | 124 | PetscInt i,k,nisol,nt; | |
305 | 124 | Mat T; | |
306 | 124 | FN f; | |
307 | |||
308 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
124 | PetscFunctionBegin; |
309 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
124 | PetscCall(PetscMalloc1(ndpt,&F)); |
310 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
124 | if (nep->fui==NEP_USER_INTERFACE_SPLIT) { |
311 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
53 | PetscCall(PetscMalloc1(ndpt,&isol)); |
312 | 53 | *ndptx = 0; | |
313 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
53 | PetscCall(NEPGetSplitOperatorInfo(nep,&nt,NULL)); |
314 | 53 | nisol = *ndptx; | |
315 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
215 | for (k=0;k<nt;k++) { |
316 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
162 | PetscCall(NEPGetSplitOperatorTerm(nep,k,NULL,&f)); |
317 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
16362 | for (i=0;i<ndpt;i++) PetscCall(FNEvaluateFunction(f,ds[i],&F[i])); |
318 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
162 | PetscCall(NEPNLEIGSAAAComputation(nep,ndpt,ds,F,&nisol,isol)); |
319 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
162 | if (nisol) PetscCall(NEPNLEIGSAuxiliarRmDuplicates(nisol,isol,ndptx,dxi,ndpt)); |
320 | } | ||
321 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
53 | PetscCall(PetscFree(isol)); |
322 | } else { | ||
323 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(MatCreateVecs(nep->function,&u,NULL)); |
324 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecDuplicate(u,&v)); |
325 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecDuplicate(u,&w)); |
326 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
71 | if (nep->V) PetscCall(BVGetRandomContext(nep->V,&rand)); |
327 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecSetRandom(u,rand)); |
328 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecNormalize(u,NULL)); |
329 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecSetRandom(v,rand)); |
330 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecNormalize(v,NULL)); |
331 | 71 | T = nep->function; | |
332 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
7171 | for (i=0;i<ndpt;i++) { |
333 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
7100 | PetscCall(NEPComputeFunction(nep,ds[i],T,T)); |
334 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
7100 | PetscCall(MatMult(T,v,w)); |
335 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
7100 | PetscCall(VecDot(w,u,&F[i])); |
336 | } | ||
337 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(NEPNLEIGSAAAComputation(nep,ndpt,ds,F,ndptx,dxi)); |
338 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecDestroy(&u)); |
339 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecDestroy(&v)); |
340 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
71 | PetscCall(VecDestroy(&w)); |
341 | } | ||
342 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
124 | PetscCall(PetscFree(F)); |
343 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
24 | PetscFunctionReturn(PETSC_SUCCESS); |
344 | } | ||
345 | |||
346 | 294 | static PetscErrorCode NEPNLEIGSLejaBagbyPoints(NEP nep) | |
347 | { | ||
348 | 294 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
349 | 294 | PetscInt i,k,ndpt=NDPOINTS,ndptx=NDPOINTS; | |
350 | 294 | PetscScalar *ds,*dsi,*dxi,*nrs,*nrxi,*s=ctx->s,*xi=ctx->xi,*beta=ctx->beta; | |
351 | 294 | PetscReal maxnrs,minnrxi; | |
352 | 294 | PetscBool rational; | |
353 | #if !defined(PETSC_USE_COMPLEX) | ||
354 | 145 | PetscReal a,b,h; | |
355 | #endif | ||
356 | |||
357 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
294 | PetscFunctionBegin; |
358 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
294 | if (!ctx->computesingularities && nep->problem_type!=NEP_RATIONAL) ndpt = ndptx = LBPOINTS; |
359 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(PetscMalloc5(ndpt+1,&ds,ndpt+1,&dsi,ndpt,&dxi,ndpt+1,&nrs,ndpt,&nrxi)); |
360 | |||
361 | /* Discretize the target region boundary */ | ||
362 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(RGComputeContour(nep->rg,ndpt,ds,dsi)); |
363 | #if !defined(PETSC_USE_COMPLEX) | ||
364 |
4/4✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
✓ Branch 2 taken 5 times.
✓ Branch 3 taken 5 times.
|
736345 | for (i=0;i<ndpt;i++) if (dsi[i]!=0.0) break; |
365 |
2/2✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
|
145 | if (i<ndpt) { |
366 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 5 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
10 | PetscCheck(nep->problem_type==NEP_RATIONAL,PetscObjectComm((PetscObject)nep),PETSC_ERR_SUP,"NLEIGS with real arithmetic requires the target set to be included in the real axis"); |
367 | /* Select a segment in the real axis */ | ||
368 |
4/6✓ Branch 0 taken 1 times.
✓ Branch 1 taken 4 times.
✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 1 times.
|
10 | PetscCall(RGComputeBoundingBox(nep->rg,&a,&b,NULL,NULL)); |
369 |
2/6✓ Branch 0 taken 5 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 5 times.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
|
10 | PetscCheck(a>-PETSC_MAX_REAL && b<PETSC_MAX_REAL,PetscObjectComm((PetscObject)nep),PETSC_ERR_USER_INPUT,"NLEIGS requires a bounded target set"); |
370 | 10 | h = (b-a)/ndpt; | |
371 |
2/2✓ Branch 0 taken 5 times.
✓ Branch 1 taken 5 times.
|
100010 | for (i=0;i<ndpt;i++) {ds[i] = a+h*i; dsi[i] = 0.0;} |
372 | } | ||
373 | #endif | ||
374 | /* Discretize the singularity region */ | ||
375 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
294 | if (ctx->computesingularities) PetscCall(ctx->computesingularities(nep,&ndptx,dxi,ctx->singularitiesctx)); |
376 | else { | ||
377 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
154 | if (nep->problem_type==NEP_RATIONAL) { |
378 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPNLEIGSRationalSingularities(nep,&ndptx,dxi,&rational)); |
379 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
30 | PetscCheck(rational,PetscObjectComm((PetscObject)nep),PETSC_ERR_CONV_FAILED,"Failed to determine singularities automatically in rational problem; consider solving the problem as general"); |
380 | } else { | ||
381 | /* AAA algorithm */ | ||
382 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
124 | PetscCall(NEPNLEIGSAAASingularities(nep,ndpt,ds,&ndptx,dxi)); |
383 | } | ||
384 | } | ||
385 | /* Look for Leja-Bagby points in the discretization sets */ | ||
386 | 294 | s[0] = ds[0]; | |
387 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 1 times.
|
294 | xi[0] = (ndptx>0)?dxi[0]:PETSC_INFINITY; |
388 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
294 | PetscCheck(PetscAbsScalar(xi[0])>=10*PETSC_MACHINE_EPSILON,PetscObjectComm((PetscObject)nep),PETSC_ERR_USER_INPUT,"Singularity point 0 is nearly zero: %g; consider removing the singularity or shifting the problem",(double)PetscAbsScalar(xi[0])); |
389 | 294 | beta[0] = 1.0; /* scaling factors are also computed here */ | |
390 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1712694 | for (i=0;i<ndpt;i++) { |
391 | 1712400 | nrs[i] = 1.0; | |
392 | 1712400 | nrxi[i] = 1.0; | |
393 | } | ||
394 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
25530 | for (k=1;k<ctx->ddmaxit;k++) { |
395 | maxnrs = 0.0; | ||
396 | 139267836 | minnrxi = PETSC_MAX_REAL; | |
397 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
139267836 | for (i=0;i<ndpt;i++) { |
398 | 139242600 | nrs[i] *= ((ds[i]-s[k-1])/(1.0-ds[i]/xi[k-1]))/beta[k-1]; | |
399 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
139242600 | if (PetscAbsScalar(nrs[i])>maxnrs) {maxnrs = PetscAbsScalar(nrs[i]); s[k] = ds[i];} |
400 | } | ||
401 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
25236 | if (ndptx>k) { |
402 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
108400682 | for (i=1;i<ndptx;i++) { |
403 | 108389735 | nrxi[i] *= ((dxi[i]-s[k-1])/(1.0-dxi[i]/xi[k-1]))/beta[k-1]; | |
404 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
108389735 | if (PetscAbsScalar(nrxi[i])<minnrxi) {minnrxi = PetscAbsScalar(nrxi[i]); xi[k] = dxi[i];} |
405 | } | ||
406 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
10947 | PetscCheck(PetscAbsScalar(xi[k])>=10*PETSC_MACHINE_EPSILON,PetscObjectComm((PetscObject)nep),PETSC_ERR_USER_INPUT,"Singularity point %" PetscInt_FMT " is nearly zero: %g; consider removing the singularity or shifting the problem",k,(double)PetscAbsScalar(xi[k])); |
407 | 14289 | } else xi[k] = PETSC_INFINITY; | |
408 | 25236 | beta[k] = maxnrs; | |
409 | } | ||
410 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(PetscFree5(ds,dsi,dxi,nrs,nrxi)); |
411 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
54 | PetscFunctionReturn(PETSC_SUCCESS); |
412 | } | ||
413 | |||
414 | 12923 | PetscErrorCode NEPNLEIGSEvalNRTFunct(NEP nep,PetscInt k,PetscScalar sigma,PetscScalar *b) | |
415 | { | ||
416 | 12923 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
417 | 12923 | PetscInt i; | |
418 | 12923 | PetscScalar *beta=ctx->beta,*s=ctx->s,*xi=ctx->xi; | |
419 | |||
420 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
12923 | PetscFunctionBegin; |
421 | 12923 | b[0] = 1.0/beta[0]; | |
422 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
129654 | for (i=0;i<k;i++) { |
423 | 116731 | b[i+1] = ((sigma-s[i])*b[i])/(beta[i+1]*(1.0-sigma/xi[i])); | |
424 | } | ||
425 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
12923 | PetscFunctionReturn(PETSC_SUCCESS); |
426 | } | ||
427 | |||
428 | 182219 | static PetscErrorCode MatMult_Fun(Mat A,Vec x,Vec y) | |
429 | { | ||
430 | 182219 | NEP_NLEIGS_MATSHELL *ctx; | |
431 | 182219 | PetscInt i; | |
432 | |||
433 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
182219 | PetscFunctionBeginUser; |
434 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
182219 | PetscCall(MatShellGetContext(A,&ctx)); |
435 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
182219 | PetscCall(MatMult(ctx->A[0],x,y)); |
436 |
5/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
|
182219 | if (ctx->coeff[0]!=1.0) PetscCall(VecScale(y,ctx->coeff[0])); |
437 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
2148774 | for (i=1;i<ctx->nmat;i++) { |
438 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1966555 | PetscCall(MatMult(ctx->A[i],x,ctx->t)); |
439 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1966555 | PetscCall(VecAXPY(y,ctx->coeff[i],ctx->t)); |
440 | } | ||
441 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
36146 | PetscFunctionReturn(PETSC_SUCCESS); |
442 | } | ||
443 | |||
444 | 163179 | static PetscErrorCode MatMultTranspose_Fun(Mat A,Vec x,Vec y) | |
445 | { | ||
446 | 163179 | NEP_NLEIGS_MATSHELL *ctx; | |
447 | 163179 | PetscInt i; | |
448 | |||
449 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
163179 | PetscFunctionBeginUser; |
450 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163179 | PetscCall(MatShellGetContext(A,&ctx)); |
451 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163179 | PetscCall(MatMultTranspose(ctx->A[0],x,y)); |
452 |
5/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
|
163179 | if (ctx->coeff[0]!=1.0) PetscCall(VecScale(y,ctx->coeff[0])); |
453 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1946748 | for (i=1;i<ctx->nmat;i++) { |
454 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1783569 | PetscCall(MatMultTranspose(ctx->A[i],x,ctx->t)); |
455 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1783569 | PetscCall(VecAXPY(y,ctx->coeff[i],ctx->t)); |
456 | } | ||
457 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
32657 | PetscFunctionReturn(PETSC_SUCCESS); |
458 | } | ||
459 | |||
460 | 60 | static PetscErrorCode MatGetDiagonal_Fun(Mat A,Vec diag) | |
461 | { | ||
462 | 60 | NEP_NLEIGS_MATSHELL *ctx; | |
463 | 60 | PetscInt i; | |
464 | |||
465 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBeginUser; |
466 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
60 | PetscCall(MatShellGetContext(A,&ctx)); |
467 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
60 | PetscCall(MatGetDiagonal(ctx->A[0],diag)); |
468 |
5/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
|
60 | if (ctx->coeff[0]!=1.0) PetscCall(VecScale(diag,ctx->coeff[0])); |
469 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
735 | for (i=1;i<ctx->nmat;i++) { |
470 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
675 | PetscCall(MatGetDiagonal(ctx->A[i],ctx->t)); |
471 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
675 | PetscCall(VecAXPY(diag,ctx->coeff[i],ctx->t)); |
472 | } | ||
473 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
12 | PetscFunctionReturn(PETSC_SUCCESS); |
474 | } | ||
475 | |||
476 | 36 | static PetscErrorCode MatDuplicate_Fun(Mat A,MatDuplicateOption op,Mat *B) | |
477 | { | ||
478 | 36 | PetscInt m,n,M,N,i; | |
479 | 36 | NEP_NLEIGS_MATSHELL *ctxnew,*ctx; | |
480 | 36 | PetscErrorCodeFn *fun; | |
481 | |||
482 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
36 | PetscFunctionBeginUser; |
483 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetContext(A,&ctx)); |
484 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(PetscNew(&ctxnew)); |
485 | 36 | ctxnew->nmat = ctx->nmat; | |
486 | 36 | ctxnew->maxnmat = ctx->maxnmat; | |
487 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(PetscMalloc2(ctxnew->maxnmat,&ctxnew->A,ctxnew->maxnmat,&ctxnew->coeff)); |
488 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
72 | for (i=0;i<ctx->nmat;i++) { |
489 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(PetscObjectReference((PetscObject)ctx->A[i])); |
490 | 36 | ctxnew->A[i] = ctx->A[i]; | |
491 | 36 | ctxnew->coeff[i] = ctx->coeff[i]; | |
492 | } | ||
493 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatGetSize(ctx->A[0],&M,&N)); |
494 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatGetLocalSize(ctx->A[0],&m,&n)); |
495 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecDuplicate(ctx->t,&ctxnew->t)); |
496 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatCreateShell(PetscObjectComm((PetscObject)A),m,n,M,N,(void*)ctxnew,B)); |
497 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetManageScalingShifts(*B)); |
498 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_MULT,&fun)); |
499 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_MULT,fun)); |
500 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_MULT_TRANSPOSE,&fun)); |
501 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_MULT_TRANSPOSE,fun)); |
502 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_GET_DIAGONAL,&fun)); |
503 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_GET_DIAGONAL,fun)); |
504 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_DUPLICATE,&fun)); |
505 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_DUPLICATE,fun)); |
506 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_DESTROY,&fun)); |
507 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_DESTROY,fun)); |
508 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellGetOperation(A,MATOP_AXPY,&fun)); |
509 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatShellSetOperation(*B,MATOP_AXPY,fun)); |
510 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
6 | PetscFunctionReturn(PETSC_SUCCESS); |
511 | } | ||
512 | |||
513 | 789 | static PetscErrorCode MatDestroy_Fun(Mat A) | |
514 | { | ||
515 | 789 | NEP_NLEIGS_MATSHELL *ctx; | |
516 | 789 | PetscInt i; | |
517 | |||
518 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
789 | PetscFunctionBeginUser; |
519 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
789 | if (A) { |
520 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
789 | PetscCall(MatShellGetContext(A,&ctx)); |
521 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
9543 | for (i=0;i<ctx->nmat;i++) PetscCall(MatDestroy(&ctx->A[i])); |
522 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
789 | PetscCall(VecDestroy(&ctx->t)); |
523 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
789 | PetscCall(PetscFree2(ctx->A,ctx->coeff)); |
524 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
789 | PetscCall(PetscFree(ctx)); |
525 | } | ||
526 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
153 | PetscFunctionReturn(PETSC_SUCCESS); |
527 | } | ||
528 | |||
529 | 7965 | static PetscErrorCode MatAXPY_Fun(Mat Y,PetscScalar a,Mat X,MatStructure str) | |
530 | { | ||
531 | 7965 | NEP_NLEIGS_MATSHELL *ctxY,*ctxX; | |
532 | 7965 | PetscInt i,j; | |
533 | 7965 | PetscBool found; | |
534 | |||
535 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
7965 | PetscFunctionBeginUser; |
536 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
7965 | PetscCall(MatShellGetContext(Y,&ctxY)); |
537 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
7965 | PetscCall(MatShellGetContext(X,&ctxX)); |
538 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
72879 | for (i=0;i<ctxX->nmat;i++) { |
539 | found = PETSC_FALSE; | ||
540 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
528012 | for (j=0;!found&&j<ctxY->nmat;j++) { |
541 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
463098 | if (ctxX->A[i]==ctxY->A[j]) { |
542 | 56949 | found = PETSC_TRUE; | |
543 | 56949 | ctxY->coeff[j] += a*ctxX->coeff[i]; | |
544 | } | ||
545 | } | ||
546 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
64914 | if (!found) { |
547 | 7965 | ctxY->coeff[ctxY->nmat] = a*ctxX->coeff[i]; | |
548 | 7965 | ctxY->A[ctxY->nmat++] = ctxX->A[i]; | |
549 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
64914 | PetscCall(PetscObjectReference((PetscObject)ctxX->A[i])); |
550 | } | ||
551 | } | ||
552 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
1587 | PetscFunctionReturn(PETSC_SUCCESS); |
553 | } | ||
554 | |||
555 | 610 | static PetscErrorCode MatScale_Fun(Mat M,PetscScalar a) | |
556 | { | ||
557 | 610 | NEP_NLEIGS_MATSHELL *ctx; | |
558 | 610 | PetscInt i; | |
559 | |||
560 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
610 | PetscFunctionBeginUser; |
561 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
610 | PetscCall(MatShellGetContext(M,&ctx)); |
562 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8091 | for (i=0;i<ctx->nmat;i++) ctx->coeff[i] *= a; |
563 |
5/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
120 | PetscFunctionReturn(PETSC_SUCCESS); |
564 | } | ||
565 | |||
566 | 753 | static PetscErrorCode NLEIGSMatToMatShellArray(Mat A,Mat *Ms,PetscInt maxnmat) | |
567 | { | ||
568 | 753 | NEP_NLEIGS_MATSHELL *ctx; | |
569 | 753 | PetscInt m,n,M,N; | |
570 | 753 | PetscBool has; | |
571 | |||
572 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
753 | PetscFunctionBegin; |
573 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatHasOperation(A,MATOP_DUPLICATE,&has)); |
574 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
753 | PetscCheck(has,PetscObjectComm((PetscObject)A),PETSC_ERR_USER,"MatDuplicate operation required"); |
575 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(PetscNew(&ctx)); |
576 | 753 | ctx->maxnmat = maxnmat; | |
577 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(PetscMalloc2(ctx->maxnmat,&ctx->A,ctx->maxnmat,&ctx->coeff)); |
578 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatDuplicate(A,MAT_COPY_VALUES,&ctx->A[0])); |
579 | 753 | ctx->nmat = 1; | |
580 | 753 | ctx->coeff[0] = 1.0; | |
581 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatCreateVecs(A,&ctx->t,NULL)); |
582 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatGetSize(A,&M,&N)); |
583 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatGetLocalSize(A,&m,&n)); |
584 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatCreateShell(PetscObjectComm((PetscObject)A),m,n,M,N,(void*)ctx,Ms)); |
585 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetManageScalingShifts(*Ms)); |
586 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_MULT,(PetscErrorCodeFn*)MatMult_Fun)); |
587 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_MULT_TRANSPOSE,(PetscErrorCodeFn*)MatMultTranspose_Fun)); |
588 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_GET_DIAGONAL,(PetscErrorCodeFn*)MatGetDiagonal_Fun)); |
589 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_DUPLICATE,(PetscErrorCodeFn*)MatDuplicate_Fun)); |
590 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_DESTROY,(PetscErrorCodeFn*)MatDestroy_Fun)); |
591 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_AXPY,(PetscErrorCodeFn*)MatAXPY_Fun)); |
592 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
753 | PetscCall(MatShellSetOperation(*Ms,MATOP_SCALE,(PetscErrorCodeFn*)MatScale_Fun)); |
593 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
147 | PetscFunctionReturn(PETSC_SUCCESS); |
594 | } | ||
595 | |||
596 | /* | ||
597 | MatIsShellAny - returns true if any of the n matrices is a shell matrix | ||
598 | */ | ||
599 | 163 | static PetscErrorCode MatIsShellAny(Mat *A,PetscInt n,PetscBool *shell) | |
600 | { | ||
601 | 163 | PetscInt i; | |
602 | 163 | PetscBool flg; | |
603 | |||
604 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
163 | PetscFunctionBegin; |
605 | 163 | *shell = PETSC_FALSE; | |
606 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
515 | for (i=0;i<n;i++) { |
607 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
382 | PetscCall(MatIsShell(A[i],&flg)); |
608 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
382 | if (flg) { *shell = PETSC_TRUE; break; } |
609 | } | ||
610 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
31 | PetscFunctionReturn(PETSC_SUCCESS); |
611 | } | ||
612 | |||
613 | 163 | static PetscErrorCode NEPNLEIGSDividedDifferences_split(NEP nep) | |
614 | { | ||
615 | 163 | PetscErrorCode ierr; | |
616 | 163 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
617 | 163 | PetscInt k,j,i,maxnmat,nmax; | |
618 | 163 | PetscReal norm0,norm,*matnorm; | |
619 | 163 | PetscScalar *s=ctx->s,*beta=ctx->beta,*xi=ctx->xi,*b,alpha,*coeffs,*pK,*pH,sone=1.0; | |
620 | 163 | Mat T,P,Ts,K,H; | |
621 | 163 | PetscBool shell,hasmnorm=PETSC_FALSE,matrix=PETSC_TRUE; | |
622 | 163 | PetscBLASInt n_; | |
623 | |||
624 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
163 | PetscFunctionBegin; |
625 | 163 | nmax = ctx->ddmaxit; | |
626 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscMalloc1(nep->nt*nmax,&ctx->coeffD)); |
627 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscMalloc3(nmax+1,&b,nmax+1,&coeffs,nep->nt,&matnorm)); |
628 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
515 | for (j=0;j<nep->nt;j++) { |
629 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
382 | PetscCall(MatHasOperation(nep->A[j],MATOP_NORM,&hasmnorm)); |
630 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
382 | if (!hasmnorm) break; |
631 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
352 | PetscCall(MatNorm(nep->A[j],NORM_INFINITY,matnorm+j)); |
632 | } | ||
633 | /* Try matrix functions scheme */ | ||
634 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscCalloc2(nmax*nmax,&pK,nmax*nmax,&pH)); |
635 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
13390 | for (i=0;i<nmax-1;i++) { |
636 | 13227 | pK[(nmax+1)*i] = 1.0; | |
637 | 13227 | pK[(nmax+1)*i+1] = beta[i+1]/xi[i]; | |
638 | 13227 | pH[(nmax+1)*i] = s[i]; | |
639 | 13227 | pH[(nmax+1)*i+1] = beta[i+1]; | |
640 | } | ||
641 | 163 | pH[nmax*nmax-1] = s[nmax-1]; | |
642 | 163 | pK[nmax*nmax-1] = 1.0; | |
643 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscBLASIntCast(nmax,&n_)); |
644 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
163 | PetscCallBLAS("BLAStrsm",BLAStrsm_("R","L","N","U",&n_,&n_,&sone,pK,&n_,pH,&n_)); |
645 | /* The matrix to be used is in H. K will be a work-space matrix */ | ||
646 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(MatCreateSeqDense(PETSC_COMM_SELF,nmax,nmax,pH,&H)); |
647 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(MatCreateSeqDense(PETSC_COMM_SELF,nmax,nmax,pK,&K)); |
648 |
3/4✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
575 | for (j=0;matrix&&j<nep->nt;j++) { |
649 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
412 | PetscCall(PetscPushErrorHandler(PetscReturnErrorHandler,NULL)); |
650 | 412 | ierr = FNEvaluateFunctionMat(nep->f[j],H,K); | |
651 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
412 | PetscCall(PetscPopErrorHandler()); |
652 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
412 | if (!ierr) { |
653 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
34942 | for (i=0;i<nmax;i++) ctx->coeffD[j+i*nep->nt] = pK[i]*beta[0]; |
654 | } else { | ||
655 | ✗ | matrix = PETSC_FALSE; | |
656 |
0/6✗ Branch 0 not taken.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
|
412 | PetscCall(PetscFPTrapPop()); |
657 | } | ||
658 | } | ||
659 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(MatDestroy(&H)); |
660 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(MatDestroy(&K)); |
661 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
163 | if (!matrix) { |
662 | ✗ | for (j=0;j<nep->nt;j++) { | |
663 | ✗ | PetscCall(FNEvaluateFunction(nep->f[j],s[0],ctx->coeffD+j)); | |
664 | ✗ | ctx->coeffD[j] *= beta[0]; | |
665 | } | ||
666 | } | ||
667 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
163 | if (hasmnorm) { |
668 | norm0 = 0.0; | ||
669 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
485 | for (j=0;j<nep->nt;j++) norm0 += matnorm[j]*PetscAbsScalar(ctx->coeffD[j]); |
670 | } else { | ||
671 | norm0 = 0.0; | ||
672 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 5 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
90 | for (j=0;j<nep->nt;j++) norm0 = PetscMax(PetscAbsScalar(ctx->coeffD[j]),norm0); |
673 | } | ||
674 | 163 | ctx->nmat = ctx->ddmaxit; | |
675 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1926 | for (k=1;k<ctx->ddmaxit;k++) { |
676 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
1906 | if (!matrix) { |
677 | ✗ | PetscCall(NEPNLEIGSEvalNRTFunct(nep,k,s[k],b)); | |
678 | ✗ | for (i=0;i<nep->nt;i++) { | |
679 | ✗ | PetscCall(FNEvaluateFunction(nep->f[i],s[k],ctx->coeffD+k*nep->nt+i)); | |
680 | ✗ | for (j=0;j<k;j++) { | |
681 | ✗ | ctx->coeffD[k*nep->nt+i] -= b[j]*ctx->coeffD[i+nep->nt*j]; | |
682 | } | ||
683 | ✗ | ctx->coeffD[k*nep->nt+i] /= b[k]; | |
684 | } | ||
685 | } | ||
686 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1906 | if (hasmnorm) { |
687 | norm = 0.0; | ||
688 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
4270 | for (j=0;j<nep->nt;j++) norm += matnorm[j]*PetscAbsScalar(ctx->coeffD[k*nep->nt+j]); |
689 | } else { | ||
690 | norm = 0.0; | ||
691 |
3/4✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
1800 | for (j=0;j<nep->nt;j++) norm = PetscMax(PetscAbsScalar(ctx->coeffD[k*nep->nt+j]),norm); |
692 | } | ||
693 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
1906 | if (k>1 && norm/norm0 < ctx->ddtol) { |
694 | 143 | ctx->nmat = k+1; | |
695 | 143 | break; | |
696 | } | ||
697 | } | ||
698 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
163 | if (!ctx->ksp) PetscCall(NEPNLEIGSGetKSPs(nep,&ctx->nshiftsw,&ctx->ksp)); |
699 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(MatIsShellAny(nep->A,nep->nt,&shell)); |
700 | 163 | maxnmat = PetscMax(ctx->ddmaxit,nep->nt); | |
701 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
386 | for (i=0;i<ctx->nshiftsw;i++) { |
702 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
223 | PetscCall(NEPNLEIGSEvalNRTFunct(nep,ctx->nmat-1,ctx->shifts[i],coeffs)); |
703 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
223 | if (!shell) PetscCall(MatDuplicate(nep->A[0],MAT_COPY_VALUES,&T)); |
704 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | else PetscCall(NLEIGSMatToMatShellArray(nep->A[0],&T,maxnmat)); |
705 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
223 | if (nep->P) { /* user-defined preconditioner */ |
706 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(MatDuplicate(nep->P[0],MAT_COPY_VALUES,&P)); |
707 | 213 | } else P=T; | |
708 | 223 | alpha = 0.0; | |
709 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
3492 | for (j=0;j<ctx->nmat;j++) alpha += coeffs[j]*ctx->coeffD[j*nep->nt]; |
710 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
223 | PetscCall(MatScale(T,alpha)); |
711 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 9 times.
✓ Branch 3 taken 1 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 1 times.
✓ Branch 7 taken 1 times.
|
223 | if (nep->P) PetscCall(MatScale(P,alpha)); |
712 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
532 | for (k=1;k<nep->nt;k++) { |
713 | alpha = 0.0; | ||
714 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
4016 | for (j=0;j<ctx->nmat;j++) alpha += coeffs[j]*ctx->coeffD[j*nep->nt+k]; |
715 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
309 | if (shell) PetscCall(NLEIGSMatToMatShellArray(nep->A[k],&Ts,maxnmat)); |
716 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
309 | PetscCall(MatAXPY(T,alpha,shell?Ts:nep->A[k],nep->mstr)); |
717 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
309 | if (nep->P) PetscCall(MatAXPY(P,alpha,nep->P[k],nep->mstrp)); |
718 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
309 | if (shell) PetscCall(MatDestroy(&Ts)); |
719 | } | ||
720 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
223 | PetscCall(NEP_KSPSetOperators(ctx->ksp[i],T,P)); |
721 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
223 | PetscCall(KSPSetUp(ctx->ksp[i])); |
722 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
223 | PetscCall(MatDestroy(&T)); |
723 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
223 | if (nep->P) PetscCall(MatDestroy(&P)); |
724 | } | ||
725 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscFree3(b,coeffs,matnorm)); |
726 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
163 | PetscCall(PetscFree2(pK,pH)); |
727 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
31 | PetscFunctionReturn(PETSC_SUCCESS); |
728 | } | ||
729 | |||
730 | 131 | static PetscErrorCode NEPNLEIGSDividedDifferences_callback(NEP nep) | |
731 | { | ||
732 | 131 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
733 | 131 | PetscInt k,j,i,maxnmat; | |
734 | 131 | PetscReal norm0,norm; | |
735 | 131 | PetscScalar *s=ctx->s,*beta=ctx->beta,*b,*coeffs; | |
736 | 131 | Mat *D=ctx->D,*DP,T,P; | |
737 | 131 | PetscBool shell,has,vec=PETSC_FALSE,precond=(nep->function_pre!=nep->function)?PETSC_TRUE:PETSC_FALSE; | |
738 | 131 | PetscRandom rand=NULL; | |
739 | 131 | Vec w[2]; | |
740 | |||
741 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
131 | PetscFunctionBegin; |
742 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | PetscCall(PetscMalloc2(ctx->ddmaxit+1,&b,ctx->ddmaxit+1,&coeffs)); |
743 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
131 | if (nep->V) PetscCall(BVGetRandomContext(nep->V,&rand)); |
744 | 131 | T = nep->function; | |
745 | 131 | P = nep->function_pre; | |
746 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | PetscCall(NEPComputeFunction(nep,s[0],T,P)); |
747 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | PetscCall(MatIsShell(T,&shell)); |
748 | 131 | maxnmat = PetscMax(ctx->ddmaxit,nep->nt); | |
749 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
131 | if (!shell) PetscCall(MatDuplicate(T,MAT_COPY_VALUES,&D[0])); |
750 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | else PetscCall(NLEIGSMatToMatShellArray(T,&D[0],maxnmat)); |
751 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
131 | if (beta[0]!=1.0) PetscCall(MatScale(D[0],1.0/beta[0])); |
752 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | PetscCall(MatHasOperation(D[0],MATOP_NORM,&has)); |
753 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
131 | if (has) PetscCall(MatNorm(D[0],NORM_FROBENIUS,&norm0)); |
754 | else { | ||
755 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatCreateVecs(D[0],NULL,&w[0])); |
756 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecDuplicate(w[0],&w[1])); |
757 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecDuplicate(w[0],&ctx->vrn)); |
758 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecSetRandomNormal(ctx->vrn,rand,w[0],w[1])); |
759 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecNormalize(ctx->vrn,NULL)); |
760 | 36 | vec = PETSC_TRUE; | |
761 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(MatNormEstimate(D[0],ctx->vrn,w[0],&norm0)); |
762 | } | ||
763 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
131 | if (precond) { |
764 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscMalloc1(ctx->ddmaxit,&DP)); |
765 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(MatDuplicate(P,MAT_COPY_VALUES,&DP[0])); |
766 | } | ||
767 | 131 | ctx->nmat = ctx->ddmaxit; | |
768 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1476 | for (k=1;k<ctx->ddmaxit;k++) { |
769 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1466 | PetscCall(NEPNLEIGSEvalNRTFunct(nep,k,s[k],b)); |
770 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1466 | PetscCall(NEPComputeFunction(nep,s[k],T,P)); |
771 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
1466 | if (!shell) PetscCall(MatDuplicate(T,MAT_COPY_VALUES,&D[k])); |
772 |
5/6✓ Branch 0 taken 9 times.
✓ Branch 1 taken 1 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 1 times.
✓ Branch 5 taken 1 times.
|
657 | else PetscCall(NLEIGSMatToMatShellArray(T,&D[k],maxnmat)); |
773 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
15837 | for (j=0;j<k;j++) PetscCall(MatAXPY(D[k],-b[j],D[j],nep->mstr)); |
774 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1466 | PetscCall(MatScale(D[k],1.0/b[k])); |
775 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1466 | PetscCall(MatHasOperation(D[k],MATOP_NORM,&has)); |
776 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
1466 | if (has) PetscCall(MatNorm(D[k],NORM_FROBENIUS,&norm)); |
777 | else { | ||
778 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
657 | if (!vec) { |
779 | ✗ | PetscCall(MatCreateVecs(D[k],NULL,&w[0])); | |
780 | ✗ | PetscCall(VecDuplicate(w[0],&w[1])); | |
781 | ✗ | PetscCall(VecDuplicate(w[0],&ctx->vrn)); | |
782 | ✗ | PetscCall(VecSetRandomNormal(ctx->vrn,rand,w[0],w[1])); | |
783 | ✗ | PetscCall(VecNormalize(ctx->vrn,NULL)); | |
784 | vec = PETSC_TRUE; | ||
785 | } | ||
786 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
657 | PetscCall(MatNormEstimate(D[k],ctx->vrn,w[0],&norm)); |
787 | } | ||
788 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1466 | if (precond) { |
789 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
25 | PetscCall(MatDuplicate(P,MAT_COPY_VALUES,&DP[k])); |
790 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
70 | for (j=0;j<k;j++) PetscCall(MatAXPY(DP[k],-b[j],DP[j],nep->mstrp)); |
791 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
25 | PetscCall(MatScale(DP[k],1.0/b[k])); |
792 | } | ||
793 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
1466 | if (k>1 && norm/norm0 < ctx->ddtol && k>1) { |
794 | 121 | ctx->nmat = k+1; | |
795 | 121 | break; | |
796 | } | ||
797 | } | ||
798 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
131 | if (!ctx->ksp) PetscCall(NEPNLEIGSGetKSPs(nep,&ctx->nshiftsw,&ctx->ksp)); |
799 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
292 | for (i=0;i<ctx->nshiftsw;i++) { |
800 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
161 | PetscCall(NEPNLEIGSEvalNRTFunct(nep,ctx->nmat-1,ctx->shifts[i],coeffs)); |
801 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
161 | PetscCall(MatDuplicate(D[0],MAT_COPY_VALUES,&T)); |
802 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
161 | if (coeffs[0]!=1.0) PetscCall(MatScale(T,coeffs[0])); |
803 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
2197 | for (j=1;j<ctx->nmat;j++) PetscCall(MatAXPY(T,coeffs[j],D[j],nep->mstr)); |
804 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
161 | if (precond) { |
805 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(MatDuplicate(DP[0],MAT_COPY_VALUES,&P)); |
806 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | if (coeffs[0]!=1.0) PetscCall(MatScale(P,coeffs[0])); |
807 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
35 | for (j=1;j<ctx->nmat;j++) PetscCall(MatAXPY(P,coeffs[j],DP[j],nep->mstrp)); |
808 | 151 | } else P=T; | |
809 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
161 | PetscCall(NEP_KSPSetOperators(ctx->ksp[i],T,P)); |
810 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
161 | PetscCall(KSPSetUp(ctx->ksp[i])); |
811 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
161 | PetscCall(MatDestroy(&T)); |
812 | } | ||
813 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | PetscCall(PetscFree2(b,coeffs)); |
814 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
131 | if (vec) { |
815 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecDestroy(&w[0])); |
816 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
36 | PetscCall(VecDestroy(&w[1])); |
817 | } | ||
818 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
131 | if (precond) { |
819 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(MatDestroy(&P)); |
820 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(MatDestroyMatrices(ctx->nmat,&DP)); |
821 | } | ||
822 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
23 | PetscFunctionReturn(PETSC_SUCCESS); |
823 | } | ||
824 | |||
825 | /* | ||
826 | NEPKrylovConvergence - This is the analogue to EPSKrylovConvergence. | ||
827 | */ | ||
828 | 693 | static PetscErrorCode NEPNLEIGSKrylovConvergence(NEP nep,PetscBool getall,PetscInt kini,PetscInt nits,PetscReal betah,PetscScalar betak,PetscInt *kout,Vec *w) | |
829 | { | ||
830 | 693 | PetscInt k,newk,marker,inside; | |
831 | 693 | PetscScalar re,im; | |
832 | 693 | PetscReal resnorm,tt; | |
833 | 693 | PetscBool istrivial; | |
834 | 693 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
835 | |||
836 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
693 | PetscFunctionBegin; |
837 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(RGIsTrivial(nep->rg,&istrivial)); |
838 | 693 | marker = -1; | |
839 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
693 | if (nep->trackall) getall = PETSC_TRUE; |
840 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
1907 | for (k=kini;k<kini+nits;k++) { |
841 | /* eigenvalue */ | ||
842 | 1907 | re = nep->eigr[k]; | |
843 | 1907 | im = nep->eigi[k]; | |
844 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
1907 | if (!istrivial) { |
845 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
1907 | if (!ctx->nshifts) PetscCall(NEPNLEIGSBackTransform((PetscObject)nep,1,&re,&im)); |
846 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1907 | PetscCall(RGCheckInside(nep->rg,1,&re,&im,&inside)); |
847 |
3/4✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
1907 | if (marker==-1 && inside<0) marker = k; |
848 | } | ||
849 | 1907 | newk = k; | |
850 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1907 | PetscCall(DSVectors(nep->ds,DS_MAT_X,&newk,&resnorm)); |
851 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1907 | tt = (ctx->nshifts)?SlepcAbsEigenvalue(betak-nep->eigr[k]*betah,nep->eigi[k]*betah):betah; |
852 | 1907 | resnorm *= PetscAbsReal(tt); | |
853 | /* error estimate */ | ||
854 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
1907 | PetscCall((*nep->converged)(nep,nep->eigr[k],nep->eigi[k],resnorm,&nep->errest[k],nep->convergedctx)); |
855 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
1907 | if (marker==-1 && nep->errest[k] >= nep->tol) marker = k; |
856 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
1907 | if (newk==k+1) { |
857 | ✗ | nep->errest[k+1] = nep->errest[k]; | |
858 | ✗ | k++; | |
859 | } | ||
860 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
1907 | if (marker!=-1 && !getall) break; |
861 | } | ||
862 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
693 | if (marker!=-1) k = marker; |
863 | 693 | *kout = k; | |
864 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
693 | PetscFunctionReturn(PETSC_SUCCESS); |
865 | } | ||
866 | |||
867 | 294 | static PetscErrorCode NEPSetUp_NLEIGS(NEP nep) | |
868 | { | ||
869 | 294 | PetscInt k,in; | |
870 | 294 | PetscScalar zero=0.0; | |
871 | 294 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
872 | 294 | SlepcSC sc; | |
873 | 294 | PetscBool istrivial; | |
874 | |||
875 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
294 | PetscFunctionBegin; |
876 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(NEPSetDimensions_Default(nep,nep->nev,&nep->ncv,&nep->mpd)); |
877 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
294 | PetscCheck(nep->ncv<=nep->nev+nep->mpd,PetscObjectComm((PetscObject)nep),PETSC_ERR_USER_INPUT,"The value of ncv must not be larger than nev+mpd"); |
878 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (nep->max_it==PETSC_DETERMINE) nep->max_it = PetscMax(5000,2*nep->n/nep->ncv); |
879 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (!ctx->ddmaxit) ctx->ddmaxit = LBPOINTS; |
880 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(RGIsTrivial(nep->rg,&istrivial)); |
881 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
294 | PetscCheck(!istrivial,PetscObjectComm((PetscObject)nep),PETSC_ERR_SUP,"NEPNLEIGS requires a nontrivial region defining the target set"); |
882 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (!nep->which) nep->which = NEP_TARGET_MAGNITUDE; |
883 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
294 | PetscCheck(nep->which==NEP_TARGET_MAGNITUDE || nep->which==NEP_TARGET_REAL || nep->which==NEP_TARGET_IMAGINARY || nep->which==NEP_WHICH_USER,PetscObjectComm((PetscObject)nep),PETSC_ERR_SUP,"This solver supports only target selection of eigenvalues"); |
884 | |||
885 | /* Initialize the NLEIGS context structure */ | ||
886 | 294 | k = ctx->ddmaxit; | |
887 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(PetscMalloc4(k,&ctx->s,k,&ctx->xi,k,&ctx->beta,k,&ctx->D)); |
888 | 294 | nep->data = ctx; | |
889 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (nep->tol==(PetscReal)PETSC_DETERMINE) nep->tol = SLEPC_DEFAULT_TOL; |
890 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (ctx->ddtol==(PetscReal)PETSC_DETERMINE) ctx->ddtol = nep->tol/10.0; |
891 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (!ctx->keep) ctx->keep = 0.5; |
892 | |||
893 | /* Compute Leja-Bagby points and scaling values */ | ||
894 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(NEPNLEIGSLejaBagbyPoints(nep)); |
895 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (nep->problem_type!=NEP_RATIONAL) { |
896 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(RGCheckInside(nep->rg,1,&nep->target,&zero,&in)); |
897 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
264 | PetscCheck(in>=0,PetscObjectComm((PetscObject)nep),PETSC_ERR_SUP,"The target is not inside the target set"); |
898 | } | ||
899 | |||
900 | /* Compute the divided difference matrices */ | ||
901 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
294 | if (nep->fui==NEP_USER_INTERFACE_SPLIT) PetscCall(NEPNLEIGSDividedDifferences_split(nep)); |
902 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
131 | else PetscCall(NEPNLEIGSDividedDifferences_callback(nep)); |
903 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(NEPAllocateSolution(nep,ctx->nmat-1)); |
904 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(NEPSetWorkVecs(nep,4)); |
905 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (!ctx->fullbasis) { |
906 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
264 | PetscCheck(!nep->twosided,PetscObjectComm((PetscObject)nep),PETSC_ERR_SUP,"Two-sided variant requires the full-basis option, rerun with -nep_nleigs_full_basis"); |
907 | /* set-up DS and transfer split operator functions */ | ||
908 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
498 | PetscCall(DSSetType(nep->ds,ctx->nshifts?DSGNHEP:DSNHEP)); |
909 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSAllocate(nep->ds,nep->ncv+1)); |
910 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSGetSlepcSC(nep->ds,&sc)); |
911 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (!ctx->nshifts) sc->map = NEPNLEIGSBackTransform; |
912 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSSetExtraRow(nep->ds,PETSC_TRUE)); |
913 | 264 | sc->mapobj = (PetscObject)nep; | |
914 | 264 | sc->rg = nep->rg; | |
915 | 264 | sc->comparison = nep->sc->comparison; | |
916 | 264 | sc->comparisonctx = nep->sc->comparisonctx; | |
917 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVDestroy(&ctx->V)); |
918 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVCreateTensor(nep->V,ctx->nmat-1,&ctx->V)); |
919 | 264 | nep->ops->solve = NEPSolve_NLEIGS; | |
920 | 264 | nep->ops->computevectors = NEPComputeVectors_Schur; | |
921 | } else { | ||
922 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(NEPSetUp_NLEIGS_FullBasis(nep)); |
923 | 30 | nep->ops->solve = NEPSolve_NLEIGS_FullBasis; | |
924 | 30 | nep->ops->computevectors = NULL; | |
925 | } | ||
926 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
54 | PetscFunctionReturn(PETSC_SUCCESS); |
927 | } | ||
928 | |||
929 | /* | ||
930 | Extend the TOAR basis by applying the matrix operator | ||
931 | over a vector which is decomposed on the TOAR way | ||
932 | Input: | ||
933 | - S,V: define the latest Arnoldi vector (nv vectors in V) | ||
934 | Output: | ||
935 | - t: new vector extending the TOAR basis | ||
936 | - r: temporally coefficients to compute the TOAR coefficients | ||
937 | for the new Arnoldi vector | ||
938 | Workspace: t_ (two vectors) | ||
939 | */ | ||
940 | 9553 | static PetscErrorCode NEPTOARExtendBasis(NEP nep,PetscInt idxrktg,PetscScalar *S,PetscInt ls,PetscInt nv,BV W,BV V,Vec t,PetscScalar *r,PetscInt lr,Vec *t_) | |
941 | { | ||
942 | 9553 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
943 | 9553 | PetscInt deg=ctx->nmat-1,k,j; | |
944 | 9553 | Vec v=t_[0],q=t_[1],w; | |
945 | 9553 | PetscScalar *beta=ctx->beta,*s=ctx->s,*xi=ctx->xi,*coeffs,sigma; | |
946 | |||
947 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
9553 | PetscFunctionBegin; |
948 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
9553 | if (!ctx->ksp) PetscCall(NEPNLEIGSGetKSPs(nep,&ctx->nshiftsw,&ctx->ksp)); |
949 | 9553 | sigma = ctx->shifts[idxrktg]; | |
950 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVSetActiveColumns(nep->V,0,nv)); |
951 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(PetscMalloc1(ctx->nmat,&coeffs)); |
952 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
9553 | PetscCheck(PetscAbsScalar(s[deg-2]-sigma)>100*PETSC_MACHINE_EPSILON,PETSC_COMM_SELF,PETSC_ERR_CONV_FAILED,"Breakdown in NLEIGS"); |
953 | /* i-part stored in (i-1) position */ | ||
954 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
261401 | for (j=0;j<nv;j++) { |
955 | 251848 | r[(deg-2)*lr+j] = (S[(deg-2)*ls+j]+(beta[deg-1]/xi[deg-2])*S[(deg-1)*ls+j])/(s[deg-2]-sigma); | |
956 | } | ||
957 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVSetActiveColumns(W,0,deg)); |
958 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVGetColumn(W,deg-1,&w)); |
959 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVMultVec(V,1.0/beta[deg],0,w,S+(deg-1)*ls)); |
960 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVRestoreColumn(W,deg-1,&w)); |
961 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVGetColumn(W,deg-2,&w)); |
962 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVMultVec(V,1.0,0.0,w,r+(deg-2)*lr)); |
963 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVRestoreColumn(W,deg-2,&w)); |
964 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
93558 | for (k=deg-2;k>0;k--) { |
965 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
84005 | PetscCheck(PetscAbsScalar(s[k-1]-sigma)>100*PETSC_MACHINE_EPSILON,PETSC_COMM_SELF,PETSC_ERR_CONV_FAILED,"Breakdown in NLEIGS"); |
966 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
2568122 | for (j=0;j<nv;j++) r[(k-1)*lr+j] = (S[(k-1)*ls+j]+(beta[k]/xi[k-1])*S[k*ls+j]-beta[k]*(1.0-sigma/xi[k-1])*r[(k)*lr+j])/(s[k-1]-sigma); |
967 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
84005 | PetscCall(BVGetColumn(W,k-1,&w)); |
968 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
84005 | PetscCall(BVMultVec(V,1.0,0.0,w,r+(k-1)*lr)); |
969 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
84005 | PetscCall(BVRestoreColumn(W,k-1,&w)); |
970 | } | ||
971 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
9553 | if (nep->fui==NEP_USER_INTERFACE_SPLIT) { |
972 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
66783 | for (j=0;j<ctx->nmat-2;j++) coeffs[j] = ctx->coeffD[nep->nt*j]; |
973 | 6774 | coeffs[ctx->nmat-2] = ctx->coeffD[nep->nt*(ctx->nmat-1)]; | |
974 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
6774 | PetscCall(BVMultVec(W,1.0,0.0,v,coeffs)); |
975 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
6774 | PetscCall(MatMult(nep->A[0],v,q)); |
976 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
18270 | for (k=1;k<nep->nt;k++) { |
977 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
90462 | for (j=0;j<ctx->nmat-2;j++) coeffs[j] = ctx->coeffD[nep->nt*j+k]; |
978 | 11496 | coeffs[ctx->nmat-2] = ctx->coeffD[nep->nt*(ctx->nmat-1)+k]; | |
979 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
11496 | PetscCall(BVMultVec(W,1.0,0,v,coeffs)); |
980 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
11496 | PetscCall(MatMult(nep->A[k],v,t)); |
981 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
11496 | PetscCall(VecAXPY(q,1.0,t)); |
982 | } | ||
983 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
6774 | PetscCall(KSPSolve(ctx->ksp[idxrktg],q,t)); |
984 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
6774 | PetscCall(VecScale(t,-1.0)); |
985 | } else { | ||
986 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
36328 | for (k=0;k<deg-1;k++) { |
987 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
33549 | PetscCall(BVGetColumn(W,k,&w)); |
988 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
33549 | PetscCall(MatMult(ctx->D[k],w,q)); |
989 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
33549 | PetscCall(BVRestoreColumn(W,k,&w)); |
990 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
33549 | PetscCall(BVInsertVec(W,k,q)); |
991 | } | ||
992 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(BVGetColumn(W,deg-1,&w)); |
993 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(MatMult(ctx->D[deg],w,q)); |
994 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(BVRestoreColumn(W,k,&w)); |
995 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(BVInsertVec(W,k,q)); |
996 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
39107 | for (j=0;j<ctx->nmat-1;j++) coeffs[j] = 1.0; |
997 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(BVMultVec(W,1.0,0.0,q,coeffs)); |
998 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(KSPSolve(ctx->ksp[idxrktg],q,t)); |
999 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
2779 | PetscCall(VecScale(t,-1.0)); |
1000 | } | ||
1001 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
9553 | PetscCall(PetscFree(coeffs)); |
1002 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
1832 | PetscFunctionReturn(PETSC_SUCCESS); |
1003 | } | ||
1004 | |||
1005 | /* | ||
1006 | Compute TOAR coefficients of the blocks of the new Arnoldi vector computed | ||
1007 | */ | ||
1008 | 9553 | static PetscErrorCode NEPTOARCoefficients(NEP nep,PetscScalar sigma,PetscInt nv,PetscScalar *S,PetscInt ls,PetscScalar *r,PetscInt lr,PetscScalar *x,PetscScalar *work) | |
1009 | { | ||
1010 | 9553 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1011 | 9553 | PetscInt k,j,d=ctx->nmat-1; | |
1012 | 9553 | PetscScalar *t=work; | |
1013 | |||
1014 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
9553 | PetscFunctionBegin; |
1015 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(NEPNLEIGSEvalNRTFunct(nep,d-1,sigma,t)); |
1016 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
103111 | for (k=0;k<d-1;k++) { |
1017 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
2912466 | for (j=0;j<=nv;j++) r[k*lr+j] += t[k]*x[j]; |
1018 | } | ||
1019 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
270409 | for (j=0;j<=nv;j++) r[(d-1)*lr+j] = t[d-1]*x[j]; |
1020 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
1832 | PetscFunctionReturn(PETSC_SUCCESS); |
1021 | } | ||
1022 | |||
1023 | /* | ||
1024 | Compute continuation vector coefficients for the Rational-Krylov run. | ||
1025 | dim(work) >= (end-ini)*(end-ini+1) + end+1 + 2*(end-ini+1), dim(t) = end. | ||
1026 | */ | ||
1027 | 9553 | static PetscErrorCode NEPNLEIGS_RKcontinuation(NEP nep,PetscInt ini,PetscInt end,PetscScalar *K,PetscScalar *H,PetscInt ld,PetscScalar sigma,PetscScalar *S,PetscInt lds,PetscScalar *cont,PetscScalar *t,PetscScalar *work) | |
1028 | { | ||
1029 | 9553 | PetscScalar *x,*W,*tau,sone=1.0,szero=0.0; | |
1030 | 9553 | PetscInt i,j,n1,n,nwu=0; | |
1031 | 9553 | PetscBLASInt info,n_,n1_,one=1,dim,lds_; | |
1032 | 9553 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1033 | |||
1034 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
9553 | PetscFunctionBegin; |
1035 |
4/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
|
9553 | if (!ctx->nshifts || !end) { |
1036 | 8843 | t[0] = 1; | |
1037 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
8843 | PetscCall(PetscArraycpy(cont,S+end*lds,lds)); |
1038 | } else { | ||
1039 | 710 | n = end-ini; | |
1040 | 710 | n1 = n+1; | |
1041 | 710 | x = work+nwu; | |
1042 | 710 | nwu += end+1; | |
1043 | 710 | tau = work+nwu; | |
1044 | 710 | nwu += n; | |
1045 | 710 | W = work+nwu; | |
1046 | 710 | nwu += n1*n; | |
1047 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8000 | for (j=ini;j<end;j++) { |
1048 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
105630 | for (i=ini;i<=end;i++) W[(j-ini)*n1+i-ini] = K[j*ld+i] -H[j*ld+i]*sigma; |
1049 | } | ||
1050 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscBLASIntCast(n,&n_)); |
1051 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscBLASIntCast(n1,&n1_)); |
1052 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscBLASIntCast(end+1,&dim)); |
1053 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscFPTrapPush(PETSC_FP_TRAP_OFF)); |
1054 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
710 | PetscCallBLAS("LAPACKgeqrf",LAPACKgeqrf_(&n1_,&n_,W,&n1_,tau,work+nwu,&n1_,&info)); |
1055 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
710 | SlepcCheckLapackInfo("geqrf",info); |
1056 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8000 | for (i=0;i<end;i++) t[i] = 0.0; |
1057 | 710 | t[end] = 1.0; | |
1058 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8000 | for (j=n-1;j>=0;j--) { |
1059 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
49170 | for (i=0;i<ini+j;i++) x[i] = 0.0; |
1060 | 7290 | x[ini+j] = 1.0; | |
1061 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
56460 | for (i=j+1;i<n1;i++) x[i+ini] = W[i+n1*j]; |
1062 | 7290 | tau[j] = PetscConj(tau[j]); | |
1063 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
7290 | PetscCallBLAS("LAPACKlarf",LAPACKlarf_("L",&dim,&one,x,&one,tau+j,t,&dim,work+nwu)); |
1064 | } | ||
1065 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscBLASIntCast(lds,&lds_)); |
1066 |
10/20✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✓ Branch 14 taken 2 times.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
|
710 | PetscCallBLAS("BLASgemv",BLASgemv_("N",&lds_,&n1_,&sone,S,&lds_,t,&one,&szero,cont,&one)); |
1067 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
710 | PetscCall(PetscFPTrapPop()); |
1068 | } | ||
1069 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
1832 | PetscFunctionReturn(PETSC_SUCCESS); |
1070 | } | ||
1071 | |||
1072 | /* | ||
1073 | Compute a run of Arnoldi iterations | ||
1074 | */ | ||
1075 | 693 | static PetscErrorCode NEPNLEIGSTOARrun(NEP nep,Mat MK,Mat MH,BV W,PetscInt k,PetscInt *M,PetscReal *betah,PetscScalar *betak,PetscBool *breakdown,Vec *t_) | |
1076 | { | ||
1077 | 693 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1078 | 693 | PetscInt i,j,m=*M,lwa,deg=ctx->nmat-1,lds,nqt,ld,l,ldh; | |
1079 | 693 | Vec t; | |
1080 | 693 | PetscReal norm=0.0; | |
1081 | 693 | PetscScalar *x,*work,*tt,sigma=1.0,*cont,*S,*K=NULL,*H; | |
1082 | 693 | PetscBool lindep; | |
1083 | 693 | Mat MS; | |
1084 | |||
1085 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
693 | PetscFunctionBegin; |
1086 | 693 | *betah = 0.0; *betak = 0.0; | |
1087 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(MatDenseGetArray(MH,&H)); |
1088 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (MK) PetscCall(MatDenseGetArray(MK,&K)); |
1089 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(MatDenseGetLDA(MH,&ldh)); |
1090 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVTensorGetFactors(ctx->V,NULL,&MS)); |
1091 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(MatDenseGetArray(MS,&S)); |
1092 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVGetSizes(nep->V,NULL,NULL,&ld)); |
1093 | 693 | lds = ld*deg; | |
1094 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVGetActiveColumns(nep->V,&l,&nqt)); |
1095 | 693 | lwa = PetscMax(ld,deg)+(m+1)*(m+1)+4*(m+1); | |
1096 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(PetscMalloc4(ld,&x,lwa,&work,m+1,&tt,lds,&cont)); |
1097 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVSetActiveColumns(ctx->V,0,m)); |
1098 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
10246 | for (j=k;j<m;j++) { |
1099 | 9553 | sigma = ctx->shifts[(++(ctx->idxrk))%ctx->nshiftsw]; | |
1100 | |||
1101 | /* Continuation vector */ | ||
1102 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(NEPNLEIGS_RKcontinuation(nep,0,j,K,H,ldh,sigma,S,lds,cont,tt,work)); |
1103 | |||
1104 | /* apply operator */ | ||
1105 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVGetColumn(nep->V,nqt,&t)); |
1106 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(NEPTOARExtendBasis(nep,(ctx->idxrk)%ctx->nshiftsw,cont,ld,nqt,W,nep->V,t,S+(j+1)*lds,ld,t_)); |
1107 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVRestoreColumn(nep->V,nqt,&t)); |
1108 | |||
1109 | /* orthogonalize */ | ||
1110 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVOrthogonalizeColumn(nep->V,nqt,x,&norm,&lindep)); |
1111 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
9553 | if (!lindep) { |
1112 | 9008 | x[nqt] = norm; | |
1113 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9008 | PetscCall(BVScaleColumn(nep->V,nqt,1.0/norm)); |
1114 | 9008 | nqt++; | |
1115 | 545 | } else x[nqt] = 0.0; | |
1116 | |||
1117 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(NEPTOARCoefficients(nep,sigma,nqt-1,cont,ld,S+(j+1)*lds,ld,x,work)); |
1118 | |||
1119 | /* Level-2 orthogonalization */ | ||
1120 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVOrthogonalizeColumn(ctx->V,j+1,H+j*ldh,&norm,breakdown)); |
1121 | 9553 | H[j+1+ldh*j] = norm; | |
1122 |
3/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
|
9553 | if (ctx->nshifts && MK) { |
1123 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8770 | for (i=0;i<=j;i++) K[i+ldh*j] = sigma*H[i+ldh*j] + tt[i]; |
1124 | 740 | K[j+1+ldh*j] = sigma*H[j+1+ldh*j]; | |
1125 | } | ||
1126 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
9553 | if (*breakdown) { |
1127 | ✗ | *M = j+1; | |
1128 | ✗ | break; | |
1129 | } | ||
1130 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVScaleColumn(ctx->V,j+1,1.0/norm)); |
1131 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
9553 | PetscCall(BVSetActiveColumns(nep->V,l,nqt)); |
1132 | } | ||
1133 | 693 | *betah = norm; | |
1134 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
693 | if (ctx->nshifts) *betak = norm*sigma; |
1135 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(PetscFree4(x,work,tt,cont)); |
1136 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(MatDenseRestoreArray(MS,&S)); |
1137 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(MatDenseRestoreArray(MH,&H)); |
1138 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (MK) PetscCall(MatDenseRestoreArray(MK,&K)); |
1139 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVTensorRestoreFactors(ctx->V,NULL,&MS)); |
1140 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
132 | PetscFunctionReturn(PETSC_SUCCESS); |
1141 | } | ||
1142 | |||
1143 | 264 | PetscErrorCode NEPSolve_NLEIGS(NEP nep) | |
1144 | { | ||
1145 | 264 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1146 | 264 | PetscInt i,k=0,l,nv=0,ld,lds,nq; | |
1147 | 264 | PetscInt deg=ctx->nmat-1,nconv=0,dsn,dsk; | |
1148 | 264 | PetscScalar *pU,betak=0,*eigr,*eigi; | |
1149 | 264 | const PetscScalar *S; | |
1150 | 264 | PetscReal betah; | |
1151 | 264 | PetscBool falselock=PETSC_FALSE,breakdown=PETSC_FALSE; | |
1152 | 264 | BV W; | |
1153 | 264 | Mat H,K=NULL,MS,MQ,U; | |
1154 | |||
1155 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
264 | PetscFunctionBegin; |
1156 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (ctx->lock) { |
1157 | /* undocumented option to use a cheaper locking instead of the true locking */ | ||
1158 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
234 | PetscCall(PetscOptionsGetBool(NULL,NULL,"-nep_nleigs_falselocking",&falselock,NULL)); |
1159 | } | ||
1160 | |||
1161 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVGetSizes(nep->V,NULL,NULL,&ld)); |
1162 | 264 | lds = deg*ld; | |
1163 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
264 | if (!ctx->nshifts) PetscCall(PetscMalloc2(nep->ncv,&eigr,nep->ncv,&eigi)); |
1164 | 30 | else { eigr = nep->eigr; eigi = nep->eigi; } | |
1165 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
264 | PetscCall(BVDuplicateResize(nep->V,PetscMax(nep->nt-1,ctx->nmat-1),&W)); |
1166 | |||
1167 | /* clean projected matrix (including the extra-arrow) */ | ||
1168 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSSetDimensions(nep->ds,PETSC_DETERMINE,PETSC_DETERMINE,PETSC_DETERMINE)); |
1169 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSGetMat(nep->ds,DS_MAT_A,&H)); |
1170 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(MatZeroEntries(H)); |
1171 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSRestoreMat(nep->ds,DS_MAT_A,&H)); |
1172 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (ctx->nshifts) { |
1173 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(DSGetMat(nep->ds,DS_MAT_B,&H)); |
1174 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(MatZeroEntries(H)); |
1175 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(DSRestoreMat(nep->ds,DS_MAT_B,&H)); |
1176 | } | ||
1177 | |||
1178 | /* Get the starting Arnoldi vector */ | ||
1179 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVTensorBuildFirstColumn(ctx->V,nep->nini)); |
1180 | |||
1181 | /* Restart loop */ | ||
1182 | 264 | l = 0; | |
1183 | 264 | while (nep->reason == NEP_CONVERGED_ITERATING) { | |
1184 | 693 | nep->its++; | |
1185 | |||
1186 | /* Compute an nv-step Krylov relation */ | ||
1187 | 693 | nv = PetscMin(nep->nconv+nep->mpd,nep->ncv); | |
1188 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (ctx->nshifts) PetscCall(DSGetMat(nep->ds,DS_MAT_A,&K)); |
1189 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSGetMat(nep->ds,ctx->nshifts?DS_MAT_B:DS_MAT_A,&H)); |
1190 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(NEPNLEIGSTOARrun(nep,K,H,W,nep->nconv+l,&nv,&betah,&betak,&breakdown,nep->work)); |
1191 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSRestoreMat(nep->ds,ctx->nshifts?DS_MAT_B:DS_MAT_A,&H)); |
1192 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (ctx->nshifts) PetscCall(DSRestoreMat(nep->ds,DS_MAT_A,&K)); |
1193 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSSetDimensions(nep->ds,nv,nep->nconv,nep->nconv+l)); |
1194 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (l==0) PetscCall(DSSetState(nep->ds,DS_STATE_INTERMEDIATE)); |
1195 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
429 | else PetscCall(DSSetState(nep->ds,DS_STATE_RAW)); |
1196 | |||
1197 | /* Solve projected problem */ | ||
1198 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSSolve(nep->ds,nep->eigr,nep->eigi)); |
1199 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSSort(nep->ds,nep->eigr,nep->eigi,NULL,NULL,NULL)); |
1200 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSUpdateExtraRow(nep->ds)); |
1201 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(DSSynchronize(nep->ds,nep->eigr,nep->eigi)); |
1202 | |||
1203 | /* Check convergence */ | ||
1204 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(NEPNLEIGSKrylovConvergence(nep,PETSC_FALSE,nep->nconv,nv-nep->nconv,betah,betak,&k,nep->work)); |
1205 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall((*nep->stopping)(nep,nep->its,nep->max_it,k,nep->nev,&nep->reason,nep->stoppingctx)); |
1206 | |||
1207 | /* Update l */ | ||
1208 |
3/4✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
|
693 | if (nep->reason != NEP_CONVERGED_ITERATING || breakdown) l = 0; |
1209 | else { | ||
1210 | 429 | l = PetscMax(1,(PetscInt)((nv-k)*ctx->keep)); | |
1211 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
429 | PetscCall(DSGetTruncateSize(nep->ds,k,nv,&l)); |
1212 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
429 | if (!breakdown) { |
1213 | /* Prepare the Rayleigh quotient for restart */ | ||
1214 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
429 | PetscCall(DSGetDimensions(nep->ds,&dsn,NULL,&dsk,NULL)); |
1215 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
429 | PetscCall(DSSetDimensions(nep->ds,dsn,k,dsk)); |
1216 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
429 | PetscCall(DSTruncate(nep->ds,k+l,PETSC_FALSE)); |
1217 | } | ||
1218 | } | ||
1219 | 693 | nconv = k; | |
1220 |
5/6✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
|
693 | if (!ctx->lock && nep->reason == NEP_CONVERGED_ITERATING && !breakdown) { l += k; k = 0; } |
1221 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
693 | if (l) PetscCall(PetscInfo(nep,"Preparing to restart keeping l=%" PetscInt_FMT " vectors\n",l)); |
1222 | |||
1223 | /* Update S */ | ||
1224 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
1331 | PetscCall(DSGetMat(nep->ds,ctx->nshifts?DS_MAT_Z:DS_MAT_Q,&MQ)); |
1225 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVMultInPlace(ctx->V,MQ,nep->nconv,k+l)); |
1226 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
1331 | PetscCall(DSRestoreMat(nep->ds,ctx->nshifts?DS_MAT_Z:DS_MAT_Q,&MQ)); |
1227 | |||
1228 | /* Copy last column of S */ | ||
1229 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVCopyColumn(ctx->V,nv,k+l)); |
1230 | |||
1231 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
693 | if (breakdown && nep->reason == NEP_CONVERGED_ITERATING) { |
1232 | /* Stop if breakdown */ | ||
1233 | ✗ | PetscCall(PetscInfo(nep,"Breakdown (it=%" PetscInt_FMT " norm=%g)\n",nep->its,(double)betah)); | |
1234 | ✗ | nep->reason = NEP_DIVERGED_BREAKDOWN; | |
1235 | } | ||
1236 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
693 | if (nep->reason != NEP_CONVERGED_ITERATING) l--; |
1237 | /* truncate S */ | ||
1238 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
693 | PetscCall(BVGetActiveColumns(nep->V,NULL,&nq)); |
1239 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
693 | if (k+l+deg<=nq) { |
1240 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
638 | PetscCall(BVSetActiveColumns(ctx->V,nep->nconv,k+l+1)); |
1241 |
7/10✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 8 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
|
638 | if (!falselock && ctx->lock) PetscCall(BVTensorCompress(ctx->V,k-nep->nconv)); |
1242 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
60 | else PetscCall(BVTensorCompress(ctx->V,0)); |
1243 | } | ||
1244 | 693 | nep->nconv = k; | |
1245 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
693 | if (!ctx->nshifts) { |
1246 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
14667 | for (i=0;i<nv;i++) { eigr[i] = nep->eigr[i]; eigi[i] = nep->eigi[i]; } |
1247 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
638 | PetscCall(NEPNLEIGSBackTransform((PetscObject)nep,nv,eigr,eigi)); |
1248 | } | ||
1249 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
957 | PetscCall(NEPMonitor(nep,nep->its,nconv,eigr,eigi,nep->errest,nv)); |
1250 | } | ||
1251 | 264 | nep->nconv = nconv; | |
1252 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
264 | if (nep->nconv>0) { |
1253 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVSetActiveColumns(ctx->V,0,nep->nconv)); |
1254 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVGetActiveColumns(nep->V,NULL,&nq)); |
1255 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVSetActiveColumns(nep->V,0,nq)); |
1256 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (nq>nep->nconv) { |
1257 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
40 | PetscCall(BVTensorCompress(ctx->V,nep->nconv)); |
1258 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
40 | PetscCall(BVSetActiveColumns(nep->V,0,nep->nconv)); |
1259 | 40 | nq = nep->nconv; | |
1260 | } | ||
1261 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (ctx->nshifts) { |
1262 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(DSGetMat(nep->ds,DS_MAT_B,&MQ)); |
1263 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(BVMultInPlace(ctx->V,MQ,0,nep->nconv)); |
1264 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(DSRestoreMat(nep->ds,DS_MAT_B,&MQ)); |
1265 | } | ||
1266 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVTensorGetFactors(ctx->V,NULL,&MS)); |
1267 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(MatDenseGetArrayRead(MS,&S)); |
1268 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(PetscMalloc1(nq*nep->nconv,&pU)); |
1269 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
1418 | for (i=0;i<nep->nconv;i++) PetscCall(PetscArraycpy(pU+i*nq,S+i*lds,nq)); |
1270 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(MatDenseRestoreArrayRead(MS,&S)); |
1271 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVTensorRestoreFactors(ctx->V,NULL,&MS)); |
1272 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(MatCreateSeqDense(PETSC_COMM_SELF,nq,nep->nconv,pU,&U)); |
1273 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVSetActiveColumns(nep->V,0,nq)); |
1274 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVMultInPlace(nep->V,U,0,nep->nconv)); |
1275 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVSetActiveColumns(nep->V,0,nep->nconv)); |
1276 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(MatDestroy(&U)); |
1277 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
264 | PetscCall(PetscFree(pU)); |
1278 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(DSTruncate(nep->ds,nep->nconv,PETSC_TRUE)); |
1279 | } | ||
1280 | |||
1281 | /* Map eigenvalues back to the original problem */ | ||
1282 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
264 | if (!ctx->nshifts) { |
1283 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
234 | PetscCall(NEPNLEIGSBackTransform((PetscObject)nep,nep->nconv,nep->eigr,nep->eigi)); |
1284 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
234 | PetscCall(PetscFree2(eigr,eigi)); |
1285 | } | ||
1286 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
264 | PetscCall(BVDestroy(&W)); |
1287 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
48 | PetscFunctionReturn(PETSC_SUCCESS); |
1288 | } | ||
1289 | |||
1290 | 211 | static PetscErrorCode NEPNLEIGSSetSingularitiesFunction_NLEIGS(NEP nep,NEPNLEIGSSingularitiesFn *fun,void *ctx) | |
1291 | { | ||
1292 | 211 | NEP_NLEIGS *nepctx=(NEP_NLEIGS*)nep->data; | |
1293 | |||
1294 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
211 | PetscFunctionBegin; |
1295 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
211 | if (fun) nepctx->computesingularities = fun; |
1296 |
2/2✓ Branch 0 taken 6 times.
✓ Branch 1 taken 10 times.
|
211 | if (ctx) nepctx->singularitiesctx = ctx; |
1297 | 211 | nep->state = NEP_STATE_INITIAL; | |
1298 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
211 | PetscFunctionReturn(PETSC_SUCCESS); |
1299 | } | ||
1300 | |||
1301 | /*@C | ||
1302 | NEPNLEIGSSetSingularitiesFunction - Sets a user function to compute a discretization | ||
1303 | of the singularity set (where T(.) is not analytic). | ||
1304 | |||
1305 | Logically Collective | ||
1306 | |||
1307 | Input Parameters: | ||
1308 | + nep - the NEP context | ||
1309 | . fun - user function (if NULL then NEP retains any previously set value) | ||
1310 | - ctx - [optional] user-defined context for private data for the function | ||
1311 | (may be NULL, in which case NEP retains any previously set value) | ||
1312 | |||
1313 | Notes: | ||
1314 | The user-defined function can set a smaller value of maxnp if necessary. | ||
1315 | It is wrong to return a larger value. | ||
1316 | |||
1317 | If the problem type has been set to rational with NEPSetProblemType(), | ||
1318 | then it is not necessary to set the singularities explicitly since the | ||
1319 | solver will try to determine them automatically. | ||
1320 | |||
1321 | Level: intermediate | ||
1322 | |||
1323 | .seealso: NEPNLEIGSGetSingularitiesFunction(), NEPSetProblemType() | ||
1324 | @*/ | ||
1325 | 211 | PetscErrorCode NEPNLEIGSSetSingularitiesFunction(NEP nep,NEPNLEIGSSingularitiesFn *fun,void *ctx) | |
1326 | { | ||
1327 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
211 | PetscFunctionBegin; |
1328 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
211 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1329 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
211 | PetscTryMethod(nep,"NEPNLEIGSSetSingularitiesFunction_C",(NEP,PetscErrorCode(*)(NEP,PetscInt*,PetscScalar*,void*),void*),(nep,fun,ctx)); |
1330 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
211 | PetscFunctionReturn(PETSC_SUCCESS); |
1331 | } | ||
1332 | |||
1333 | 10 | static PetscErrorCode NEPNLEIGSGetSingularitiesFunction_NLEIGS(NEP nep,NEPNLEIGSSingularitiesFn **fun,void **ctx) | |
1334 | { | ||
1335 | 10 | NEP_NLEIGS *nepctx=(NEP_NLEIGS*)nep->data; | |
1336 | |||
1337 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1338 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (fun) *fun = nepctx->computesingularities; |
1339 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
10 | if (ctx) *ctx = nepctx->singularitiesctx; |
1340 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
10 | PetscFunctionReturn(PETSC_SUCCESS); |
1341 | } | ||
1342 | |||
1343 | /*@C | ||
1344 | NEPNLEIGSGetSingularitiesFunction - Returns the Function and optionally the user | ||
1345 | provided context for computing a discretization of the singularity set. | ||
1346 | |||
1347 | Not Collective | ||
1348 | |||
1349 | Input Parameter: | ||
1350 | . nep - the nonlinear eigensolver context | ||
1351 | |||
1352 | Output Parameters: | ||
1353 | + fun - location to put the function (or NULL) | ||
1354 | - ctx - location to stash the function context (or NULL) | ||
1355 | |||
1356 | Level: advanced | ||
1357 | |||
1358 | .seealso: NEPNLEIGSSetSingularitiesFunction() | ||
1359 | @*/ | ||
1360 | 10 | PetscErrorCode NEPNLEIGSGetSingularitiesFunction(NEP nep,NEPNLEIGSSingularitiesFn **fun,void **ctx) | |
1361 | { | ||
1362 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1363 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
10 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1364 |
9/16✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
|
10 | PetscUseMethod(nep,"NEPNLEIGSGetSingularitiesFunction_C",(NEP,PetscErrorCode(**)(NEP,PetscInt*,PetscScalar*,void*),void**),(nep,fun,ctx)); |
1365 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
10 | PetscFunctionReturn(PETSC_SUCCESS); |
1366 | } | ||
1367 | |||
1368 | 30 | static PetscErrorCode NEPNLEIGSSetRestart_NLEIGS(NEP nep,PetscReal keep) | |
1369 | { | ||
1370 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1371 | |||
1372 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1373 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
30 | if (keep==(PetscReal)PETSC_DEFAULT || keep==(PetscReal)PETSC_DECIDE) ctx->keep = 0.5; |
1374 | else { | ||
1375 |
2/6✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
|
30 | PetscCheck(keep>=0.1 && keep<=0.9,PetscObjectComm((PetscObject)nep),PETSC_ERR_ARG_OUTOFRANGE,"The keep argument must be in the range [0.1,0.9]"); |
1376 | 30 | ctx->keep = keep; | |
1377 | } | ||
1378 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
6 | PetscFunctionReturn(PETSC_SUCCESS); |
1379 | } | ||
1380 | |||
1381 | /*@ | ||
1382 | NEPNLEIGSSetRestart - Sets the restart parameter for the NLEIGS | ||
1383 | method, in particular the proportion of basis vectors that must be kept | ||
1384 | after restart. | ||
1385 | |||
1386 | Logically Collective | ||
1387 | |||
1388 | Input Parameters: | ||
1389 | + nep - the nonlinear eigensolver context | ||
1390 | - keep - the number of vectors to be kept at restart | ||
1391 | |||
1392 | Options Database Key: | ||
1393 | . -nep_nleigs_restart - Sets the restart parameter | ||
1394 | |||
1395 | Notes: | ||
1396 | Allowed values are in the range [0.1,0.9]. The default is 0.5. | ||
1397 | |||
1398 | Level: advanced | ||
1399 | |||
1400 | .seealso: NEPNLEIGSGetRestart() | ||
1401 | @*/ | ||
1402 | 30 | PetscErrorCode NEPNLEIGSSetRestart(NEP nep,PetscReal keep) | |
1403 | { | ||
1404 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1405 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
30 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1406 |
29/66✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✓ Branch 18 taken 2 times.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 21 taken 2 times.
✓ Branch 22 taken 2 times.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✓ Branch 25 taken 2 times.
✓ Branch 26 taken 2 times.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✓ Branch 29 taken 2 times.
✓ Branch 30 taken 2 times.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 2 times.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✓ Branch 36 taken 2 times.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 2 times.
✗ Branch 40 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✓ Branch 43 taken 2 times.
✗ Branch 44 not taken.
✗ Branch 45 not taken.
✗ Branch 46 not taken.
✓ Branch 47 taken 2 times.
✓ Branch 48 taken 2 times.
✗ Branch 49 not taken.
✗ Branch 50 not taken.
✓ Branch 51 taken 2 times.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✓ Branch 54 taken 2 times.
✗ Branch 55 not taken.
✗ Branch 56 not taken.
✓ Branch 57 taken 2 times.
✗ Branch 58 not taken.
✗ Branch 59 not taken.
✓ Branch 60 taken 2 times.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✓ Branch 63 taken 2 times.
✗ Branch 64 not taken.
✗ Branch 65 not taken.
|
30 | PetscValidLogicalCollectiveReal(nep,keep,2); |
1407 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
30 | PetscTryMethod(nep,"NEPNLEIGSSetRestart_C",(NEP,PetscReal),(nep,keep)); |
1408 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
30 | PetscFunctionReturn(PETSC_SUCCESS); |
1409 | } | ||
1410 | |||
1411 | 60 | static PetscErrorCode NEPNLEIGSGetRestart_NLEIGS(NEP nep,PetscReal *keep) | |
1412 | { | ||
1413 | 60 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1414 | |||
1415 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
1416 | 60 | *keep = ctx->keep; | |
1417 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
60 | PetscFunctionReturn(PETSC_SUCCESS); |
1418 | } | ||
1419 | |||
1420 | /*@ | ||
1421 | NEPNLEIGSGetRestart - Gets the restart parameter used in the NLEIGS method. | ||
1422 | |||
1423 | Not Collective | ||
1424 | |||
1425 | Input Parameter: | ||
1426 | . nep - the nonlinear eigensolver context | ||
1427 | |||
1428 | Output Parameter: | ||
1429 | . keep - the restart parameter | ||
1430 | |||
1431 | Level: advanced | ||
1432 | |||
1433 | .seealso: NEPNLEIGSSetRestart() | ||
1434 | @*/ | ||
1435 | 60 | PetscErrorCode NEPNLEIGSGetRestart(NEP nep,PetscReal *keep) | |
1436 | { | ||
1437 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
1438 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
60 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1439 |
2/8✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
60 | PetscAssertPointer(keep,2); |
1440 |
9/16✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
|
60 | PetscUseMethod(nep,"NEPNLEIGSGetRestart_C",(NEP,PetscReal*),(nep,keep)); |
1441 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
60 | PetscFunctionReturn(PETSC_SUCCESS); |
1442 | } | ||
1443 | |||
1444 | 30 | static PetscErrorCode NEPNLEIGSSetLocking_NLEIGS(NEP nep,PetscBool lock) | |
1445 | { | ||
1446 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1447 | |||
1448 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1449 | 30 | ctx->lock = lock; | |
1450 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
30 | PetscFunctionReturn(PETSC_SUCCESS); |
1451 | } | ||
1452 | |||
1453 | /*@ | ||
1454 | NEPNLEIGSSetLocking - Choose between locking and non-locking variants of | ||
1455 | the NLEIGS method. | ||
1456 | |||
1457 | Logically Collective | ||
1458 | |||
1459 | Input Parameters: | ||
1460 | + nep - the nonlinear eigensolver context | ||
1461 | - lock - true if the locking variant must be selected | ||
1462 | |||
1463 | Options Database Key: | ||
1464 | . -nep_nleigs_locking - Sets the locking flag | ||
1465 | |||
1466 | Notes: | ||
1467 | The default is to lock converged eigenpairs when the method restarts. | ||
1468 | This behaviour can be changed so that all directions are kept in the | ||
1469 | working subspace even if already converged to working accuracy (the | ||
1470 | non-locking variant). | ||
1471 | |||
1472 | Level: advanced | ||
1473 | |||
1474 | .seealso: NEPNLEIGSGetLocking() | ||
1475 | @*/ | ||
1476 | 30 | PetscErrorCode NEPNLEIGSSetLocking(NEP nep,PetscBool lock) | |
1477 | { | ||
1478 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1479 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
30 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1480 |
27/62✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✓ Branch 19 taken 2 times.
✓ Branch 20 taken 2 times.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 23 taken 2 times.
✓ Branch 24 taken 2 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 27 taken 2 times.
✓ Branch 28 taken 2 times.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✓ Branch 31 taken 2 times.
✓ Branch 32 taken 2 times.
✗ Branch 33 not taken.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✗ Branch 36 not taken.
✓ Branch 37 taken 2 times.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✓ Branch 41 taken 2 times.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 2 times.
✓ Branch 46 taken 2 times.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 49 taken 2 times.
✓ Branch 50 taken 2 times.
✗ Branch 51 not taken.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✗ Branch 54 not taken.
✓ Branch 55 taken 2 times.
✗ Branch 56 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✓ Branch 59 taken 2 times.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
|
30 | PetscValidLogicalCollectiveBool(nep,lock,2); |
1481 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
30 | PetscTryMethod(nep,"NEPNLEIGSSetLocking_C",(NEP,PetscBool),(nep,lock)); |
1482 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
30 | PetscFunctionReturn(PETSC_SUCCESS); |
1483 | } | ||
1484 | |||
1485 | 60 | static PetscErrorCode NEPNLEIGSGetLocking_NLEIGS(NEP nep,PetscBool *lock) | |
1486 | { | ||
1487 | 60 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1488 | |||
1489 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
1490 | 60 | *lock = ctx->lock; | |
1491 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
60 | PetscFunctionReturn(PETSC_SUCCESS); |
1492 | } | ||
1493 | |||
1494 | /*@ | ||
1495 | NEPNLEIGSGetLocking - Gets the locking flag used in the NLEIGS method. | ||
1496 | |||
1497 | Not Collective | ||
1498 | |||
1499 | Input Parameter: | ||
1500 | . nep - the nonlinear eigensolver context | ||
1501 | |||
1502 | Output Parameter: | ||
1503 | . lock - the locking flag | ||
1504 | |||
1505 | Level: advanced | ||
1506 | |||
1507 | .seealso: NEPNLEIGSSetLocking() | ||
1508 | @*/ | ||
1509 | 60 | PetscErrorCode NEPNLEIGSGetLocking(NEP nep,PetscBool *lock) | |
1510 | { | ||
1511 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
1512 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
60 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1513 |
2/8✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
60 | PetscAssertPointer(lock,2); |
1514 |
9/16✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
|
60 | PetscUseMethod(nep,"NEPNLEIGSGetLocking_C",(NEP,PetscBool*),(nep,lock)); |
1515 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
60 | PetscFunctionReturn(PETSC_SUCCESS); |
1516 | } | ||
1517 | |||
1518 | 102 | static PetscErrorCode NEPNLEIGSSetInterpolation_NLEIGS(NEP nep,PetscReal tol,PetscInt degree) | |
1519 | { | ||
1520 | 102 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1521 | |||
1522 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
102 | PetscFunctionBegin; |
1523 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
102 | if (tol == (PetscReal)PETSC_DETERMINE) { |
1524 | 72 | ctx->ddtol = PETSC_DETERMINE; | |
1525 | 72 | nep->state = NEP_STATE_INITIAL; | |
1526 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | } else if (tol != (PetscReal)PETSC_CURRENT) { |
1527 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
30 | PetscCheck(tol>0.0,PetscObjectComm((PetscObject)nep),PETSC_ERR_ARG_OUTOFRANGE,"Illegal value of tol. Must be > 0"); |
1528 | 30 | ctx->ddtol = tol; | |
1529 | } | ||
1530 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
102 | if (degree == PETSC_DETERMINE) { |
1531 | ✗ | ctx->ddmaxit = 0; | |
1532 | ✗ | if (nep->state) PetscCall(NEPReset(nep)); | |
1533 | ✗ | nep->state = NEP_STATE_INITIAL; | |
1534 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
102 | } else if (degree != PETSC_CURRENT) { |
1535 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
102 | PetscCheck(degree>0,PetscObjectComm((PetscObject)nep),PETSC_ERR_ARG_OUTOFRANGE,"Illegal value of degree. Must be > 0"); |
1536 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
102 | if (ctx->ddmaxit != degree) { |
1537 | 102 | ctx->ddmaxit = degree; | |
1538 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
102 | if (nep->state) PetscCall(NEPReset(nep)); |
1539 | 102 | nep->state = NEP_STATE_INITIAL; | |
1540 | } | ||
1541 | } | ||
1542 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
18 | PetscFunctionReturn(PETSC_SUCCESS); |
1543 | } | ||
1544 | |||
1545 | /*@ | ||
1546 | NEPNLEIGSSetInterpolation - Sets the tolerance and maximum degree | ||
1547 | when building the interpolation via divided differences. | ||
1548 | |||
1549 | Collective | ||
1550 | |||
1551 | Input Parameters: | ||
1552 | + nep - the nonlinear eigensolver context | ||
1553 | . tol - tolerance to stop computing divided differences | ||
1554 | - degree - maximum degree of interpolation | ||
1555 | |||
1556 | Options Database Key: | ||
1557 | + -nep_nleigs_interpolation_tol <tol> - Sets the tolerance to stop computing divided differences | ||
1558 | - -nep_nleigs_interpolation_degree <degree> - Sets the maximum degree of interpolation | ||
1559 | |||
1560 | Notes: | ||
1561 | PETSC_CURRENT can be used to preserve the current value of any of the | ||
1562 | arguments, and PETSC_DETERMINE to set them to a default value. | ||
1563 | |||
1564 | Level: advanced | ||
1565 | |||
1566 | .seealso: NEPNLEIGSGetInterpolation() | ||
1567 | @*/ | ||
1568 | 102 | PetscErrorCode NEPNLEIGSSetInterpolation(NEP nep,PetscReal tol,PetscInt degree) | |
1569 | { | ||
1570 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
102 | PetscFunctionBegin; |
1571 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
102 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1572 |
29/66✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✓ Branch 18 taken 2 times.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 21 taken 2 times.
✓ Branch 22 taken 2 times.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✓ Branch 25 taken 2 times.
✓ Branch 26 taken 2 times.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✓ Branch 29 taken 2 times.
✓ Branch 30 taken 2 times.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✓ Branch 33 taken 2 times.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✓ Branch 36 taken 2 times.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✓ Branch 39 taken 2 times.
✗ Branch 40 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✓ Branch 43 taken 2 times.
✗ Branch 44 not taken.
✗ Branch 45 not taken.
✗ Branch 46 not taken.
✓ Branch 47 taken 2 times.
✓ Branch 48 taken 2 times.
✗ Branch 49 not taken.
✗ Branch 50 not taken.
✓ Branch 51 taken 2 times.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✓ Branch 54 taken 2 times.
✗ Branch 55 not taken.
✗ Branch 56 not taken.
✓ Branch 57 taken 2 times.
✗ Branch 58 not taken.
✗ Branch 59 not taken.
✓ Branch 60 taken 2 times.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✓ Branch 63 taken 2 times.
✗ Branch 64 not taken.
✗ Branch 65 not taken.
|
102 | PetscValidLogicalCollectiveReal(nep,tol,2); |
1573 |
27/62✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✓ Branch 19 taken 2 times.
✓ Branch 20 taken 2 times.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 23 taken 2 times.
✓ Branch 24 taken 2 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 27 taken 2 times.
✓ Branch 28 taken 2 times.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✓ Branch 31 taken 2 times.
✓ Branch 32 taken 2 times.
✗ Branch 33 not taken.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✗ Branch 36 not taken.
✓ Branch 37 taken 2 times.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✓ Branch 41 taken 2 times.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 2 times.
✓ Branch 46 taken 2 times.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 49 taken 2 times.
✓ Branch 50 taken 2 times.
✗ Branch 51 not taken.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✗ Branch 54 not taken.
✓ Branch 55 taken 2 times.
✗ Branch 56 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✓ Branch 59 taken 2 times.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
|
102 | PetscValidLogicalCollectiveInt(nep,degree,3); |
1574 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
102 | PetscTryMethod(nep,"NEPNLEIGSSetInterpolation_C",(NEP,PetscReal,PetscInt),(nep,tol,degree)); |
1575 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
102 | PetscFunctionReturn(PETSC_SUCCESS); |
1576 | } | ||
1577 | |||
1578 | 334 | static PetscErrorCode NEPNLEIGSGetInterpolation_NLEIGS(NEP nep,PetscReal *tol,PetscInt *degree) | |
1579 | { | ||
1580 | 334 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1581 | |||
1582 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
334 | PetscFunctionBegin; |
1583 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
334 | if (tol) *tol = ctx->ddtol; |
1584 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
334 | if (degree) *degree = ctx->ddmaxit; |
1585 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
334 | PetscFunctionReturn(PETSC_SUCCESS); |
1586 | } | ||
1587 | |||
1588 | /*@ | ||
1589 | NEPNLEIGSGetInterpolation - Gets the tolerance and maximum degree | ||
1590 | when building the interpolation via divided differences. | ||
1591 | |||
1592 | Not Collective | ||
1593 | |||
1594 | Input Parameter: | ||
1595 | . nep - the nonlinear eigensolver context | ||
1596 | |||
1597 | Output Parameters: | ||
1598 | + tol - tolerance to stop computing divided differences | ||
1599 | - degree - maximum degree of interpolation | ||
1600 | |||
1601 | Level: advanced | ||
1602 | |||
1603 | .seealso: NEPNLEIGSSetInterpolation() | ||
1604 | @*/ | ||
1605 | 334 | PetscErrorCode NEPNLEIGSGetInterpolation(NEP nep,PetscReal *tol,PetscInt *degree) | |
1606 | { | ||
1607 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
334 | PetscFunctionBegin; |
1608 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
334 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1609 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
334 | PetscTryMethod(nep,"NEPNLEIGSGetInterpolation_C",(NEP,PetscReal*,PetscInt*),(nep,tol,degree)); |
1610 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
334 | PetscFunctionReturn(PETSC_SUCCESS); |
1611 | } | ||
1612 | |||
1613 | 30 | static PetscErrorCode NEPNLEIGSSetRKShifts_NLEIGS(NEP nep,PetscInt ns,PetscScalar *shifts) | |
1614 | { | ||
1615 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1616 | 30 | PetscInt i; | |
1617 | |||
1618 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1619 |
1/4✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
30 | PetscCheck(ns>=0,PetscObjectComm((PetscObject)nep),PETSC_ERR_ARG_WRONG,"Number of shifts must be non-negative"); |
1620 |
1/10✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
|
30 | if (ctx->nshifts) PetscCall(PetscFree(ctx->shifts)); |
1621 |
2/8✗ Branch 0 not taken.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
30 | for (i=0;i<ctx->nshiftsw;i++) PetscCall(KSPDestroy(&ctx->ksp[i])); |
1622 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
30 | PetscCall(PetscFree(ctx->ksp)); |
1623 | 30 | ctx->ksp = NULL; | |
1624 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | if (ns) { |
1625 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(PetscMalloc1(ns,&ctx->shifts)); |
1626 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
150 | for (i=0;i<ns;i++) ctx->shifts[i] = shifts[i]; |
1627 | } | ||
1628 | 30 | ctx->nshifts = ns; | |
1629 | 30 | nep->state = NEP_STATE_INITIAL; | |
1630 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
30 | PetscFunctionReturn(PETSC_SUCCESS); |
1631 | } | ||
1632 | |||
1633 | /*@ | ||
1634 | NEPNLEIGSSetRKShifts - Sets a list of shifts to be used in the Rational | ||
1635 | Krylov method. | ||
1636 | |||
1637 | Collective | ||
1638 | |||
1639 | Input Parameters: | ||
1640 | + nep - the nonlinear eigensolver context | ||
1641 | . ns - number of shifts | ||
1642 | - shifts - array of scalar values specifying the shifts | ||
1643 | |||
1644 | Options Database Key: | ||
1645 | . -nep_nleigs_rk_shifts - Sets the list of shifts | ||
1646 | |||
1647 | Notes: | ||
1648 | If only one shift is provided, the built subspace built is equivalent to | ||
1649 | shift-and-invert Krylov-Schur (provided that the absolute convergence | ||
1650 | criterion is used). | ||
1651 | |||
1652 | In the case of real scalars, complex shifts are not allowed. In the | ||
1653 | command line, a comma-separated list of complex values can be provided with | ||
1654 | the format [+/-][realnumber][+/-]realnumberi with no spaces, e.g. | ||
1655 | -nep_nleigs_rk_shifts 1.0+2.0i,1.5+2.0i,1.0+1.5i | ||
1656 | |||
1657 | Use ns=0 to remove previously set shifts. | ||
1658 | |||
1659 | Level: advanced | ||
1660 | |||
1661 | .seealso: NEPNLEIGSGetRKShifts() | ||
1662 | @*/ | ||
1663 | 30 | PetscErrorCode NEPNLEIGSSetRKShifts(NEP nep,PetscInt ns,PetscScalar shifts[]) | |
1664 | { | ||
1665 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
1666 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
30 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1667 |
27/62✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✓ Branch 19 taken 2 times.
✓ Branch 20 taken 2 times.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 23 taken 2 times.
✓ Branch 24 taken 2 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 27 taken 2 times.
✓ Branch 28 taken 2 times.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✓ Branch 31 taken 2 times.
✓ Branch 32 taken 2 times.
✗ Branch 33 not taken.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✗ Branch 36 not taken.
✓ Branch 37 taken 2 times.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✓ Branch 41 taken 2 times.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 2 times.
✓ Branch 46 taken 2 times.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 49 taken 2 times.
✓ Branch 50 taken 2 times.
✗ Branch 51 not taken.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✗ Branch 54 not taken.
✓ Branch 55 taken 2 times.
✗ Branch 56 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✓ Branch 59 taken 2 times.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
|
30 | PetscValidLogicalCollectiveInt(nep,ns,2); |
1668 |
3/10✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
|
30 | if (ns) PetscAssertPointer(shifts,3); |
1669 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
30 | PetscTryMethod(nep,"NEPNLEIGSSetRKShifts_C",(NEP,PetscInt,PetscScalar*),(nep,ns,shifts)); |
1670 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
30 | PetscFunctionReturn(PETSC_SUCCESS); |
1671 | } | ||
1672 | |||
1673 | 10 | static PetscErrorCode NEPNLEIGSGetRKShifts_NLEIGS(NEP nep,PetscInt *ns,PetscScalar **shifts) | |
1674 | { | ||
1675 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1676 | 10 | PetscInt i; | |
1677 | |||
1678 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1679 | 10 | *ns = ctx->nshifts; | |
1680 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (ctx->nshifts) { |
1681 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscMalloc1(ctx->nshifts,shifts)); |
1682 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
50 | for (i=0;i<ctx->nshifts;i++) (*shifts)[i] = ctx->shifts[i]; |
1683 | } | ||
1684 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
2 | PetscFunctionReturn(PETSC_SUCCESS); |
1685 | } | ||
1686 | |||
1687 | /*@C | ||
1688 | NEPNLEIGSGetRKShifts - Gets the list of shifts used in the Rational | ||
1689 | Krylov method. | ||
1690 | |||
1691 | Not Collective | ||
1692 | |||
1693 | Input Parameter: | ||
1694 | . nep - the nonlinear eigensolver context | ||
1695 | |||
1696 | Output Parameters: | ||
1697 | + ns - number of shifts | ||
1698 | - shifts - array of shifts | ||
1699 | |||
1700 | Note: | ||
1701 | The user is responsible for deallocating the returned array. | ||
1702 | |||
1703 | Level: advanced | ||
1704 | |||
1705 | .seealso: NEPNLEIGSSetRKShifts() | ||
1706 | @*/ | ||
1707 | 10 | PetscErrorCode NEPNLEIGSGetRKShifts(NEP nep,PetscInt *ns,PetscScalar *shifts[]) PeNS | |
1708 | { | ||
1709 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1710 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
10 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1711 |
2/8✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | PetscAssertPointer(ns,2); |
1712 |
2/8✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | PetscAssertPointer(shifts,3); |
1713 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
10 | PetscTryMethod(nep,"NEPNLEIGSGetRKShifts_C",(NEP,PetscInt*,PetscScalar**),(nep,ns,shifts)); |
1714 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
10 | PetscFunctionReturn(PETSC_SUCCESS); |
1715 | } | ||
1716 | |||
1717 | 274 | static PetscErrorCode NEPNLEIGSGetKSPs_NLEIGS(NEP nep,PetscInt *nsolve,KSP **ksp) | |
1718 | { | ||
1719 | 274 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1720 | 274 | PetscInt i; | |
1721 | 274 | PC pc; | |
1722 | |||
1723 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
1724 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (!ctx->ksp) { |
1725 |
4/6✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(NEPNLEIGSSetShifts(nep,&ctx->nshiftsw)); |
1726 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscMalloc1(ctx->nshiftsw,&ctx->ksp)); |
1727 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
638 | for (i=0;i<ctx->nshiftsw;i++) { |
1728 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(KSPCreate(PetscObjectComm((PetscObject)nep),&ctx->ksp[i])); |
1729 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(PetscObjectIncrementTabLevel((PetscObject)ctx->ksp[i],(PetscObject)nep,1)); |
1730 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(KSPSetOptionsPrefix(ctx->ksp[i],((PetscObject)nep)->prefix)); |
1731 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(KSPAppendOptionsPrefix(ctx->ksp[i],"nep_nleigs_")); |
1732 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(PetscObjectSetOptions((PetscObject)ctx->ksp[i],((PetscObject)nep)->options)); |
1733 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(KSPSetErrorIfNotConverged(ctx->ksp[i],PETSC_TRUE)); |
1734 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
613 | PetscCall(KSPSetTolerances(ctx->ksp[i],1e-3*SlepcDefaultTol(nep->tol),PETSC_CURRENT,PETSC_CURRENT,PETSC_CURRENT)); |
1735 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(KSPGetPC(ctx->ksp[i],&pc)); |
1736 |
8/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 10 times.
✓ Branch 4 taken 10 times.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 10 times.
✓ Branch 7 taken 10 times.
|
364 | if ((nep->fui==NEP_USER_INTERFACE_SPLIT && nep->P) || (nep->fui==NEP_USER_INTERFACE_CALLBACK && nep->function_pre!=nep->function)) { |
1737 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
20 | PetscCall(KSPSetType(ctx->ksp[i],KSPBCGS)); |
1738 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
20 | PetscCall(PCSetType(pc,PCBJACOBI)); |
1739 | } else { | ||
1740 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
344 | PetscCall(KSPSetType(ctx->ksp[i],KSPPREONLY)); |
1741 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
364 | PetscCall(PCSetType(pc,PCLU)); |
1742 | } | ||
1743 | } | ||
1744 | } | ||
1745 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (nsolve) *nsolve = ctx->nshiftsw; |
1746 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (ksp) *ksp = ctx->ksp; |
1747 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
50 | PetscFunctionReturn(PETSC_SUCCESS); |
1748 | } | ||
1749 | |||
1750 | /*@C | ||
1751 | NEPNLEIGSGetKSPs - Retrieve the array of linear solver objects associated with | ||
1752 | the nonlinear eigenvalue solver. | ||
1753 | |||
1754 | Collective | ||
1755 | |||
1756 | Input Parameter: | ||
1757 | . nep - nonlinear eigenvalue solver | ||
1758 | |||
1759 | Output Parameters: | ||
1760 | + nsolve - number of returned KSP objects | ||
1761 | - ksp - array of linear solver object | ||
1762 | |||
1763 | Notes: | ||
1764 | The number of KSP objects is equal to the number of shifts provided by the user, | ||
1765 | or 1 if the user did not provide shifts. | ||
1766 | |||
1767 | Level: advanced | ||
1768 | |||
1769 | .seealso: NEPNLEIGSSetRKShifts() | ||
1770 | @*/ | ||
1771 | 274 | PetscErrorCode NEPNLEIGSGetKSPs(NEP nep,PetscInt *nsolve,KSP **ksp) | |
1772 | { | ||
1773 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
1774 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
274 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1775 |
9/16✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
|
274 | PetscUseMethod(nep,"NEPNLEIGSGetKSPs_C",(NEP,PetscInt*,KSP**),(nep,nsolve,ksp)); |
1776 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
274 | PetscFunctionReturn(PETSC_SUCCESS); |
1777 | } | ||
1778 | |||
1779 | 40 | static PetscErrorCode NEPNLEIGSSetFullBasis_NLEIGS(NEP nep,PetscBool fullbasis) | |
1780 | { | ||
1781 | 40 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1782 | |||
1783 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
40 | PetscFunctionBegin; |
1784 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
40 | if (fullbasis!=ctx->fullbasis) { |
1785 | 30 | ctx->fullbasis = fullbasis; | |
1786 | 30 | nep->state = NEP_STATE_INITIAL; | |
1787 | 30 | nep->useds = PetscNot(fullbasis); | |
1788 | } | ||
1789 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
40 | PetscFunctionReturn(PETSC_SUCCESS); |
1790 | } | ||
1791 | |||
1792 | /*@ | ||
1793 | NEPNLEIGSSetFullBasis - Choose between TOAR-basis (default) and full-basis | ||
1794 | variants of the NLEIGS method. | ||
1795 | |||
1796 | Logically Collective | ||
1797 | |||
1798 | Input Parameters: | ||
1799 | + nep - the nonlinear eigensolver context | ||
1800 | - fullbasis - true if the full-basis variant must be selected | ||
1801 | |||
1802 | Options Database Key: | ||
1803 | . -nep_nleigs_full_basis - Sets the full-basis flag | ||
1804 | |||
1805 | Notes: | ||
1806 | The default is to use a compact representation of the Krylov basis, that is, | ||
1807 | V = (I otimes U) S, with a tensor BV. This behaviour can be changed so that | ||
1808 | the full basis V is explicitly stored and operated with. This variant is more | ||
1809 | expensive in terms of memory and computation, but is necessary in some cases, | ||
1810 | particularly for two-sided computations, see NEPSetTwoSided(). | ||
1811 | |||
1812 | In the full-basis variant, the NLEIGS solver uses an EPS object to explicitly | ||
1813 | solve the linearized eigenproblem, see NEPNLEIGSGetEPS(). | ||
1814 | |||
1815 | Level: advanced | ||
1816 | |||
1817 | .seealso: NEPNLEIGSGetFullBasis(), NEPNLEIGSGetEPS(), NEPSetTwoSided(), BVCreateTensor() | ||
1818 | @*/ | ||
1819 | 40 | PetscErrorCode NEPNLEIGSSetFullBasis(NEP nep,PetscBool fullbasis) | |
1820 | { | ||
1821 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
40 | PetscFunctionBegin; |
1822 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
40 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1823 |
27/62✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✓ Branch 19 taken 2 times.
✓ Branch 20 taken 2 times.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 23 taken 2 times.
✓ Branch 24 taken 2 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 27 taken 2 times.
✓ Branch 28 taken 2 times.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✓ Branch 31 taken 2 times.
✓ Branch 32 taken 2 times.
✗ Branch 33 not taken.
✓ Branch 34 taken 2 times.
✗ Branch 35 not taken.
✗ Branch 36 not taken.
✓ Branch 37 taken 2 times.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✓ Branch 41 taken 2 times.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✓ Branch 45 taken 2 times.
✓ Branch 46 taken 2 times.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 49 taken 2 times.
✓ Branch 50 taken 2 times.
✗ Branch 51 not taken.
✓ Branch 52 taken 2 times.
✗ Branch 53 not taken.
✗ Branch 54 not taken.
✓ Branch 55 taken 2 times.
✗ Branch 56 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✓ Branch 59 taken 2 times.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
|
40 | PetscValidLogicalCollectiveBool(nep,fullbasis,2); |
1824 |
8/14✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 10 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✓ Branch 13 taken 2 times.
|
40 | PetscTryMethod(nep,"NEPNLEIGSSetFullBasis_C",(NEP,PetscBool),(nep,fullbasis)); |
1825 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
40 | PetscFunctionReturn(PETSC_SUCCESS); |
1826 | } | ||
1827 | |||
1828 | 10 | static PetscErrorCode NEPNLEIGSGetFullBasis_NLEIGS(NEP nep,PetscBool *fullbasis) | |
1829 | { | ||
1830 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1831 | |||
1832 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1833 | 10 | *fullbasis = ctx->fullbasis; | |
1834 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
10 | PetscFunctionReturn(PETSC_SUCCESS); |
1835 | } | ||
1836 | |||
1837 | /*@ | ||
1838 | NEPNLEIGSGetFullBasis - Gets the flag that indicates if NLEIGS is using the | ||
1839 | full-basis variant. | ||
1840 | |||
1841 | Not Collective | ||
1842 | |||
1843 | Input Parameter: | ||
1844 | . nep - the nonlinear eigensolver context | ||
1845 | |||
1846 | Output Parameter: | ||
1847 | . fullbasis - the flag | ||
1848 | |||
1849 | Level: advanced | ||
1850 | |||
1851 | .seealso: NEPNLEIGSSetFullBasis() | ||
1852 | @*/ | ||
1853 | 10 | PetscErrorCode NEPNLEIGSGetFullBasis(NEP nep,PetscBool *fullbasis) | |
1854 | { | ||
1855 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1856 |
3/16✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 15 not taken.
|
10 | PetscValidHeaderSpecific(nep,NEP_CLASSID,1); |
1857 |
2/8✗ Branch 0 not taken.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | PetscAssertPointer(fullbasis,2); |
1858 |
9/16✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 10 times.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 2 times.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 15 taken 2 times.
|
10 | PetscUseMethod(nep,"NEPNLEIGSGetFullBasis_C",(NEP,PetscBool*),(nep,fullbasis)); |
1859 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
10 | PetscFunctionReturn(PETSC_SUCCESS); |
1860 | } | ||
1861 | |||
1862 | #define SHIFTMAX 30 | ||
1863 | |||
1864 | 274 | static PetscErrorCode NEPSetFromOptions_NLEIGS(NEP nep,PetscOptionItems PetscOptionsObject) | |
1865 | { | ||
1866 | 274 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1867 | 274 | PetscInt i=0,k; | |
1868 | 274 | PetscBool flg1,flg2,b; | |
1869 | 274 | PetscReal r; | |
1870 | 274 | PetscScalar array[SHIFTMAX]; | |
1871 | |||
1872 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
1873 |
1/12✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
274 | PetscOptionsHeadBegin(PetscOptionsObject,"NEP NLEIGS Options"); |
1874 | |||
1875 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsReal("-nep_nleigs_restart","Proportion of vectors kept after restart","NEPNLEIGSSetRestart",0.5,&r,&flg1)); |
1876 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
274 | if (flg1) PetscCall(NEPNLEIGSSetRestart(nep,r)); |
1877 | |||
1878 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsBool("-nep_nleigs_locking","Choose between locking and non-locking variants","NEPNLEIGSSetLocking",PETSC_FALSE,&b,&flg1)); |
1879 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
274 | if (flg1) PetscCall(NEPNLEIGSSetLocking(nep,b)); |
1880 | |||
1881 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsBool("-nep_nleigs_full_basis","Choose between TOAR and full-basis variants","NEPNLEIGSSetFullBasis",PETSC_FALSE,&b,&flg1)); |
1882 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
274 | if (flg1) PetscCall(NEPNLEIGSSetFullBasis(nep,b)); |
1883 | |||
1884 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(NEPNLEIGSGetInterpolation(nep,&r,&i)); |
1885 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (!i) i = PETSC_DETERMINE; |
1886 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsInt("-nep_nleigs_interpolation_degree","Maximum number of terms for interpolation via divided differences","NEPNLEIGSSetInterpolation",i,&i,&flg1)); |
1887 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsReal("-nep_nleigs_interpolation_tol","Tolerance for interpolation via divided differences","NEPNLEIGSSetInterpolation",r,&r,&flg2)); |
1888 |
7/10✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 8 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
|
274 | if (flg1 || flg2) PetscCall(NEPNLEIGSSetInterpolation(nep,r,i)); |
1889 | |||
1890 | 274 | k = SHIFTMAX; | |
1891 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8494 | for (i=0;i<k;i++) array[i] = 0; |
1892 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
274 | PetscCall(PetscOptionsScalarArray("-nep_nleigs_rk_shifts","Shifts for Rational Krylov","NEPNLEIGSSetRKShifts",array,&k,&flg1)); |
1893 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
274 | if (flg1) PetscCall(NEPNLEIGSSetRKShifts(nep,k,array)); |
1894 | |||
1895 |
2/14✓ Branch 0 taken 8 times.
✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
|
274 | PetscOptionsHeadEnd(); |
1896 | |||
1897 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
274 | if (!ctx->ksp) PetscCall(NEPNLEIGSGetKSPs(nep,&ctx->nshiftsw,&ctx->ksp)); |
1898 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
638 | for (i=0;i<ctx->nshiftsw;i++) PetscCall(KSPSetFromOptions(ctx->ksp[i])); |
1899 | |||
1900 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
274 | if (ctx->fullbasis) { |
1901 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
30 | if (!ctx->eps) PetscCall(NEPNLEIGSGetEPS(nep,&ctx->eps)); |
1902 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(EPSSetFromOptions(ctx->eps)); |
1903 | } | ||
1904 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
50 | PetscFunctionReturn(PETSC_SUCCESS); |
1905 | } | ||
1906 | |||
1907 | 10 | static PetscErrorCode NEPView_NLEIGS(NEP nep,PetscViewer viewer) | |
1908 | { | ||
1909 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1910 | 10 | PetscBool isascii; | |
1911 | 10 | PetscInt i; | |
1912 | 10 | char str[50]; | |
1913 | |||
1914 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
1915 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&isascii)); |
1916 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (isascii) { |
1917 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPrintf(viewer," %d%% of basis vectors kept after restart\n",(int)(100*ctx->keep))); |
1918 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | if (ctx->fullbasis) PetscCall(PetscViewerASCIIPrintf(viewer," using the full-basis variant\n")); |
1919 |
6/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
10 | else PetscCall(PetscViewerASCIIPrintf(viewer," using the %slocking variant\n",ctx->lock?"":"non-")); |
1920 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPrintf(viewer," divided difference terms: used=%" PetscInt_FMT ", max=%" PetscInt_FMT "\n",ctx->nmat,ctx->ddmaxit)); |
1921 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPrintf(viewer," tolerance for divided difference convergence: %g\n",(double)ctx->ddtol)); |
1922 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (ctx->nshifts) { |
1923 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPrintf(viewer," RK shifts: ")); |
1924 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIUseTabs(viewer,PETSC_FALSE)); |
1925 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
50 | for (i=0;i<ctx->nshifts;i++) { |
1926 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
40 | PetscCall(SlepcSNPrintfScalar(str,sizeof(str),ctx->shifts[i],PETSC_FALSE)); |
1927 |
7/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 2 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
50 | PetscCall(PetscViewerASCIIPrintf(viewer,"%s%s",str,(i<ctx->nshifts-1)?",":"")); |
1928 | } | ||
1929 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPrintf(viewer,"\n")); |
1930 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIUseTabs(viewer,PETSC_TRUE)); |
1931 | } | ||
1932 |
1/8✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
|
10 | if (!ctx->ksp) PetscCall(NEPNLEIGSGetKSPs(nep,&ctx->nshiftsw,&ctx->ksp)); |
1933 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPushTab(viewer)); |
1934 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(KSPView(ctx->ksp[0],viewer)); |
1935 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
10 | PetscCall(PetscViewerASCIIPopTab(viewer)); |
1936 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
10 | if (ctx->fullbasis) { |
1937 | ✗ | if (!ctx->eps) PetscCall(NEPNLEIGSGetEPS(nep,&ctx->eps)); | |
1938 | ✗ | PetscCall(PetscViewerASCIIPushTab(viewer)); | |
1939 | ✗ | PetscCall(EPSView(ctx->eps,viewer)); | |
1940 | ✗ | PetscCall(PetscViewerASCIIPopTab(viewer)); | |
1941 | } | ||
1942 | } | ||
1943 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
2 | PetscFunctionReturn(PETSC_SUCCESS); |
1944 | } | ||
1945 | |||
1946 | 294 | static PetscErrorCode NEPReset_NLEIGS(NEP nep) | |
1947 | { | ||
1948 | 294 | PetscInt k; | |
1949 | 294 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
1950 | |||
1951 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
294 | PetscFunctionBegin; |
1952 |
7/10✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 8 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
|
294 | if (nep->fui==NEP_USER_INTERFACE_SPLIT) PetscCall(PetscFree(ctx->coeffD)); |
1953 | else { | ||
1954 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
1728 | for (k=0;k<ctx->nmat;k++) PetscCall(MatDestroy(&ctx->D[k])); |
1955 | } | ||
1956 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(PetscFree4(ctx->s,ctx->xi,ctx->beta,ctx->D)); |
1957 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
678 | for (k=0;k<ctx->nshiftsw;k++) PetscCall(KSPReset(ctx->ksp[k])); |
1958 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
294 | PetscCall(VecDestroy(&ctx->vrn)); |
1959 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (ctx->fullbasis) { |
1960 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(MatDestroy(&ctx->A)); |
1961 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
30 | PetscCall(EPSReset(ctx->eps)); |
1962 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
150 | for (k=0;k<4;k++) PetscCall(VecDestroy(&ctx->w[k])); |
1963 | } | ||
1964 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
54 | PetscFunctionReturn(PETSC_SUCCESS); |
1965 | } | ||
1966 | |||
1967 | 345 | static PetscErrorCode NEPDestroy_NLEIGS(NEP nep) | |
1968 | { | ||
1969 | 345 | PetscInt k; | |
1970 | 345 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
1971 | |||
1972 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
345 | PetscFunctionBegin; |
1973 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(BVDestroy(&ctx->V)); |
1974 |
7/8✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 10 times.
✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
✓ Branch 6 taken 2 times.
✓ Branch 7 taken 2 times.
|
709 | for (k=0;k<ctx->nshiftsw;k++) PetscCall(KSPDestroy(&ctx->ksp[k])); |
1975 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
345 | PetscCall(PetscFree(ctx->ksp)); |
1976 |
7/10✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✓ Branch 5 taken 8 times.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 2 times.
|
345 | if (ctx->nshifts) PetscCall(PetscFree(ctx->shifts)); |
1977 |
6/8✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
345 | if (ctx->fullbasis) PetscCall(EPSDestroy(&ctx->eps)); |
1978 |
5/8✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 2 times.
✓ Branch 3 taken 8 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 2 times.
|
345 | PetscCall(PetscFree(nep->data)); |
1979 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetSingularitiesFunction_C",NULL)); |
1980 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetSingularitiesFunction_C",NULL)); |
1981 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetRestart_C",NULL)); |
1982 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetRestart_C",NULL)); |
1983 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetLocking_C",NULL)); |
1984 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetLocking_C",NULL)); |
1985 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetInterpolation_C",NULL)); |
1986 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetInterpolation_C",NULL)); |
1987 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetRKShifts_C",NULL)); |
1988 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetRKShifts_C",NULL)); |
1989 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetKSPs_C",NULL)); |
1990 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetFullBasis_C",NULL)); |
1991 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetFullBasis_C",NULL)); |
1992 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetEPS_C",NULL)); |
1993 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetEPS_C",NULL)); |
1994 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
65 | PetscFunctionReturn(PETSC_SUCCESS); |
1995 | } | ||
1996 | |||
1997 | 345 | SLEPC_EXTERN PetscErrorCode NEPCreate_NLEIGS(NEP nep) | |
1998 | { | ||
1999 | 345 | NEP_NLEIGS *ctx; | |
2000 | |||
2001 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
345 | PetscFunctionBegin; |
2002 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscNew(&ctx)); |
2003 | 345 | nep->data = (void*)ctx; | |
2004 | 345 | ctx->lock = PETSC_TRUE; | |
2005 | 345 | ctx->ddtol = PETSC_DETERMINE; | |
2006 | |||
2007 | 345 | nep->useds = PETSC_TRUE; | |
2008 | |||
2009 | 345 | nep->ops->setup = NEPSetUp_NLEIGS; | |
2010 | 345 | nep->ops->setfromoptions = NEPSetFromOptions_NLEIGS; | |
2011 | 345 | nep->ops->view = NEPView_NLEIGS; | |
2012 | 345 | nep->ops->destroy = NEPDestroy_NLEIGS; | |
2013 | 345 | nep->ops->reset = NEPReset_NLEIGS; | |
2014 | |||
2015 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetSingularitiesFunction_C",NEPNLEIGSSetSingularitiesFunction_NLEIGS)); |
2016 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetSingularitiesFunction_C",NEPNLEIGSGetSingularitiesFunction_NLEIGS)); |
2017 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetRestart_C",NEPNLEIGSSetRestart_NLEIGS)); |
2018 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetRestart_C",NEPNLEIGSGetRestart_NLEIGS)); |
2019 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetLocking_C",NEPNLEIGSSetLocking_NLEIGS)); |
2020 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetLocking_C",NEPNLEIGSGetLocking_NLEIGS)); |
2021 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetInterpolation_C",NEPNLEIGSSetInterpolation_NLEIGS)); |
2022 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetInterpolation_C",NEPNLEIGSGetInterpolation_NLEIGS)); |
2023 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetRKShifts_C",NEPNLEIGSSetRKShifts_NLEIGS)); |
2024 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetRKShifts_C",NEPNLEIGSGetRKShifts_NLEIGS)); |
2025 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetKSPs_C",NEPNLEIGSGetKSPs_NLEIGS)); |
2026 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetFullBasis_C",NEPNLEIGSSetFullBasis_NLEIGS)); |
2027 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetFullBasis_C",NEPNLEIGSGetFullBasis_NLEIGS)); |
2028 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSSetEPS_C",NEPNLEIGSSetEPS_NLEIGS)); |
2029 |
4/6✓ Branch 0 taken 2 times.
✓ Branch 1 taken 8 times.
✓ Branch 2 taken 2 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
|
345 | PetscCall(PetscObjectComposeFunction((PetscObject)nep,"NEPNLEIGSGetEPS_C",NEPNLEIGSGetEPS_NLEIGS)); |
2030 |
6/12✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 2 times.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✓ Branch 11 taken 2 times.
|
65 | PetscFunctionReturn(PETSC_SUCCESS); |
2031 | } | ||
2032 |