| 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-defined callback function | ||
| 1303 | to compute a discretization of the singularity set (the values where | ||
| 1304 | $T(\cdot)$ is not analytic). | ||
| 1305 | |||
| 1306 | Logically Collective | ||
| 1307 | |||
| 1308 | Input Parameters: | ||
| 1309 | + nep - the nonlinear eigensolver context | ||
| 1310 | . fun - user function (if `NULL` then `NEP` retains any previously set value) | ||
| 1311 | - ctx - [optional] user-defined context for private data for the function | ||
| 1312 | (may be `NULL`, in which case `NEP` retains any previously set value) | ||
| 1313 | |||
| 1314 | Notes: | ||
| 1315 | If the problem type has been set to `NEP_RATIONAL` with `NEPSetProblemType()`, | ||
| 1316 | then it is not necessary to set the singularities explicitly since the | ||
| 1317 | solver will try to determine them automatically. | ||
| 1318 | |||
| 1319 | If the problem is `NEP_GENERAL`, it is also possible to omit the | ||
| 1320 | singularities callback. In that case, a discretization of the singularity | ||
| 1321 | set is approximated via the AAA algorithm {cite:p}`Nak18,Els19`. | ||
| 1322 | |||
| 1323 | Level: intermediate | ||
| 1324 | |||
| 1325 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetSingularitiesFunction()`, `NEPSetProblemType()` | ||
| 1326 | @*/ | ||
| 1327 | 211 | PetscErrorCode NEPNLEIGSSetSingularitiesFunction(NEP nep,NEPNLEIGSSingularitiesFn *fun,void *ctx) | |
| 1328 | { | ||
| 1329 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
211 | PetscFunctionBegin; |
| 1330 |
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); |
| 1331 |
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)); |
| 1332 |
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); |
| 1333 | } | ||
| 1334 | |||
| 1335 | 10 | static PetscErrorCode NEPNLEIGSGetSingularitiesFunction_NLEIGS(NEP nep,NEPNLEIGSSingularitiesFn **fun,void **ctx) | |
| 1336 | { | ||
| 1337 | 10 | NEP_NLEIGS *nepctx=(NEP_NLEIGS*)nep->data; | |
| 1338 | |||
| 1339 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1340 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (fun) *fun = nepctx->computesingularities; |
| 1341 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
10 | if (ctx) *ctx = nepctx->singularitiesctx; |
| 1342 |
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); |
| 1343 | } | ||
| 1344 | |||
| 1345 | /*@C | ||
| 1346 | NEPNLEIGSGetSingularitiesFunction - Returns the callback function and optionally the user | ||
| 1347 | provided context for computing a discretization of the singularity set. | ||
| 1348 | |||
| 1349 | Not Collective | ||
| 1350 | |||
| 1351 | Input Parameter: | ||
| 1352 | . nep - the nonlinear eigensolver context | ||
| 1353 | |||
| 1354 | Output Parameters: | ||
| 1355 | + fun - location to put the function (or `NULL`) | ||
| 1356 | - ctx - location to stash the function context (or `NULL`) | ||
| 1357 | |||
| 1358 | Level: intermediate | ||
| 1359 | |||
| 1360 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetSingularitiesFunction()` | ||
| 1361 | @*/ | ||
| 1362 | 10 | PetscErrorCode NEPNLEIGSGetSingularitiesFunction(NEP nep,NEPNLEIGSSingularitiesFn **fun,void **ctx) | |
| 1363 | { | ||
| 1364 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1365 |
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); |
| 1366 |
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)); |
| 1367 |
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); |
| 1368 | } | ||
| 1369 | |||
| 1370 | 30 | static PetscErrorCode NEPNLEIGSSetRestart_NLEIGS(NEP nep,PetscReal keep) | |
| 1371 | { | ||
| 1372 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1373 | |||
| 1374 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1375 |
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; |
| 1376 | else { | ||
| 1377 |
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]"); |
| 1378 | 30 | ctx->keep = keep; | |
| 1379 | } | ||
| 1380 |
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); |
| 1381 | } | ||
| 1382 | |||
| 1383 | /*@ | ||
| 1384 | NEPNLEIGSSetRestart - Sets the restart parameter for the NLEIGS | ||
| 1385 | method, in particular the proportion of basis vectors that must be kept | ||
| 1386 | after restart. | ||
| 1387 | |||
| 1388 | Logically Collective | ||
| 1389 | |||
| 1390 | Input Parameters: | ||
| 1391 | + nep - the nonlinear eigensolver context | ||
| 1392 | - keep - the number of vectors to be kept at restart | ||
| 1393 | |||
| 1394 | Options Database Key: | ||
| 1395 | . -nep_nleigs_restart \<keep\> - sets the restart parameter | ||
| 1396 | |||
| 1397 | Notes: | ||
| 1398 | Allowed values are in the range [0.1,0.9]. The default is 0.5. | ||
| 1399 | |||
| 1400 | Level: advanced | ||
| 1401 | |||
| 1402 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetRestart()` | ||
| 1403 | @*/ | ||
| 1404 | 30 | PetscErrorCode NEPNLEIGSSetRestart(NEP nep,PetscReal keep) | |
| 1405 | { | ||
| 1406 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1407 |
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); |
| 1408 |
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); |
| 1409 |
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)); |
| 1410 |
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); |
| 1411 | } | ||
| 1412 | |||
| 1413 | 60 | static PetscErrorCode NEPNLEIGSGetRestart_NLEIGS(NEP nep,PetscReal *keep) | |
| 1414 | { | ||
| 1415 | 60 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1416 | |||
| 1417 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
| 1418 | 60 | *keep = ctx->keep; | |
| 1419 |
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); |
| 1420 | } | ||
| 1421 | |||
| 1422 | /*@ | ||
| 1423 | NEPNLEIGSGetRestart - Gets the restart parameter used in the NLEIGS method. | ||
| 1424 | |||
| 1425 | Not Collective | ||
| 1426 | |||
| 1427 | Input Parameter: | ||
| 1428 | . nep - the nonlinear eigensolver context | ||
| 1429 | |||
| 1430 | Output Parameter: | ||
| 1431 | . keep - the restart parameter | ||
| 1432 | |||
| 1433 | Level: advanced | ||
| 1434 | |||
| 1435 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetRestart()` | ||
| 1436 | @*/ | ||
| 1437 | 60 | PetscErrorCode NEPNLEIGSGetRestart(NEP nep,PetscReal *keep) | |
| 1438 | { | ||
| 1439 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
| 1440 |
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); |
| 1441 |
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); |
| 1442 |
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)); |
| 1443 |
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); |
| 1444 | } | ||
| 1445 | |||
| 1446 | 30 | static PetscErrorCode NEPNLEIGSSetLocking_NLEIGS(NEP nep,PetscBool lock) | |
| 1447 | { | ||
| 1448 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1449 | |||
| 1450 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1451 | 30 | ctx->lock = lock; | |
| 1452 |
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); |
| 1453 | } | ||
| 1454 | |||
| 1455 | /*@ | ||
| 1456 | NEPNLEIGSSetLocking - Choose between locking and non-locking variants of | ||
| 1457 | the NLEIGS method. | ||
| 1458 | |||
| 1459 | Logically Collective | ||
| 1460 | |||
| 1461 | Input Parameters: | ||
| 1462 | + nep - the nonlinear eigensolver context | ||
| 1463 | - lock - true if the locking variant must be selected | ||
| 1464 | |||
| 1465 | Options Database Key: | ||
| 1466 | . -nep_nleigs_locking - sets the locking flag | ||
| 1467 | |||
| 1468 | Notes: | ||
| 1469 | The default is to lock converged eigenpairs when the method restarts. | ||
| 1470 | This behavior can be changed so that all directions are kept in the | ||
| 1471 | working subspace even if already converged to working accuracy (the | ||
| 1472 | non-locking variant). | ||
| 1473 | |||
| 1474 | Level: advanced | ||
| 1475 | |||
| 1476 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetLocking()` | ||
| 1477 | @*/ | ||
| 1478 | 30 | PetscErrorCode NEPNLEIGSSetLocking(NEP nep,PetscBool lock) | |
| 1479 | { | ||
| 1480 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1481 |
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); |
| 1482 |
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); |
| 1483 |
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)); |
| 1484 |
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); |
| 1485 | } | ||
| 1486 | |||
| 1487 | 60 | static PetscErrorCode NEPNLEIGSGetLocking_NLEIGS(NEP nep,PetscBool *lock) | |
| 1488 | { | ||
| 1489 | 60 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1490 | |||
| 1491 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
| 1492 | 60 | *lock = ctx->lock; | |
| 1493 |
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); |
| 1494 | } | ||
| 1495 | |||
| 1496 | /*@ | ||
| 1497 | NEPNLEIGSGetLocking - Gets the locking flag used in the NLEIGS method. | ||
| 1498 | |||
| 1499 | Not Collective | ||
| 1500 | |||
| 1501 | Input Parameter: | ||
| 1502 | . nep - the nonlinear eigensolver context | ||
| 1503 | |||
| 1504 | Output Parameter: | ||
| 1505 | . lock - the locking flag | ||
| 1506 | |||
| 1507 | Level: advanced | ||
| 1508 | |||
| 1509 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetLocking()` | ||
| 1510 | @*/ | ||
| 1511 | 60 | PetscErrorCode NEPNLEIGSGetLocking(NEP nep,PetscBool *lock) | |
| 1512 | { | ||
| 1513 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
60 | PetscFunctionBegin; |
| 1514 |
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); |
| 1515 |
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); |
| 1516 |
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)); |
| 1517 |
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); |
| 1518 | } | ||
| 1519 | |||
| 1520 | 102 | static PetscErrorCode NEPNLEIGSSetInterpolation_NLEIGS(NEP nep,PetscReal tol,PetscInt degree) | |
| 1521 | { | ||
| 1522 | 102 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1523 | |||
| 1524 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
102 | PetscFunctionBegin; |
| 1525 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
102 | if (tol == (PetscReal)PETSC_DETERMINE) { |
| 1526 | 72 | ctx->ddtol = PETSC_DETERMINE; | |
| 1527 | 72 | nep->state = NEP_STATE_INITIAL; | |
| 1528 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | } else if (tol != (PetscReal)PETSC_CURRENT) { |
| 1529 |
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"); |
| 1530 | 30 | ctx->ddtol = tol; | |
| 1531 | } | ||
| 1532 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
102 | if (degree == PETSC_DETERMINE) { |
| 1533 | ✗ | ctx->ddmaxit = 0; | |
| 1534 | ✗ | if (nep->state) PetscCall(NEPReset(nep)); | |
| 1535 | ✗ | nep->state = NEP_STATE_INITIAL; | |
| 1536 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
102 | } else if (degree != PETSC_CURRENT) { |
| 1537 |
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"); |
| 1538 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
102 | if (ctx->ddmaxit != degree) { |
| 1539 | 102 | ctx->ddmaxit = degree; | |
| 1540 |
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)); |
| 1541 | 102 | nep->state = NEP_STATE_INITIAL; | |
| 1542 | } | ||
| 1543 | } | ||
| 1544 |
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); |
| 1545 | } | ||
| 1546 | |||
| 1547 | /*@ | ||
| 1548 | NEPNLEIGSSetInterpolation - Sets the tolerance and maximum degree | ||
| 1549 | when building the interpolation via divided differences. | ||
| 1550 | |||
| 1551 | Collective | ||
| 1552 | |||
| 1553 | Input Parameters: | ||
| 1554 | + nep - the nonlinear eigensolver context | ||
| 1555 | . tol - tolerance to stop computing divided differences | ||
| 1556 | - degree - maximum degree of interpolation | ||
| 1557 | |||
| 1558 | Options Database Keys: | ||
| 1559 | + -nep_nleigs_interpolation_tol \<tol\> - sets the tolerance to stop computing divided differences | ||
| 1560 | - -nep_nleigs_interpolation_degree \<degree\> - sets the maximum degree of interpolation | ||
| 1561 | |||
| 1562 | Note: | ||
| 1563 | `PETSC_CURRENT` can be used to preserve the current value of any of the | ||
| 1564 | arguments, and `PETSC_DETERMINE` to set them to a default value. | ||
| 1565 | |||
| 1566 | Level: advanced | ||
| 1567 | |||
| 1568 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetInterpolation()` | ||
| 1569 | @*/ | ||
| 1570 | 102 | PetscErrorCode NEPNLEIGSSetInterpolation(NEP nep,PetscReal tol,PetscInt degree) | |
| 1571 | { | ||
| 1572 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
102 | PetscFunctionBegin; |
| 1573 |
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); |
| 1574 |
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); |
| 1575 |
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); |
| 1576 |
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)); |
| 1577 |
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); |
| 1578 | } | ||
| 1579 | |||
| 1580 | 334 | static PetscErrorCode NEPNLEIGSGetInterpolation_NLEIGS(NEP nep,PetscReal *tol,PetscInt *degree) | |
| 1581 | { | ||
| 1582 | 334 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1583 | |||
| 1584 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
334 | PetscFunctionBegin; |
| 1585 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
334 | if (tol) *tol = ctx->ddtol; |
| 1586 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
334 | if (degree) *degree = ctx->ddmaxit; |
| 1587 |
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); |
| 1588 | } | ||
| 1589 | |||
| 1590 | /*@ | ||
| 1591 | NEPNLEIGSGetInterpolation - Gets the tolerance and maximum degree | ||
| 1592 | when building the interpolation via divided differences. | ||
| 1593 | |||
| 1594 | Not Collective | ||
| 1595 | |||
| 1596 | Input Parameter: | ||
| 1597 | . nep - the nonlinear eigensolver context | ||
| 1598 | |||
| 1599 | Output Parameters: | ||
| 1600 | + tol - tolerance to stop computing divided differences | ||
| 1601 | - degree - maximum degree of interpolation | ||
| 1602 | |||
| 1603 | Level: advanced | ||
| 1604 | |||
| 1605 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetInterpolation()` | ||
| 1606 | @*/ | ||
| 1607 | 334 | PetscErrorCode NEPNLEIGSGetInterpolation(NEP nep,PetscReal *tol,PetscInt *degree) | |
| 1608 | { | ||
| 1609 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
334 | PetscFunctionBegin; |
| 1610 |
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); |
| 1611 |
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)); |
| 1612 |
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); |
| 1613 | } | ||
| 1614 | |||
| 1615 | 30 | static PetscErrorCode NEPNLEIGSSetRKShifts_NLEIGS(NEP nep,PetscInt ns,PetscScalar *shifts) | |
| 1616 | { | ||
| 1617 | 30 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1618 | 30 | PetscInt i; | |
| 1619 | |||
| 1620 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1621 |
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"); |
| 1622 |
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)); |
| 1623 |
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])); |
| 1624 |
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)); |
| 1625 | 30 | ctx->ksp = NULL; | |
| 1626 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
30 | if (ns) { |
| 1627 |
4/6✓ Branch 0 taken 2 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)); |
| 1628 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
150 | for (i=0;i<ns;i++) ctx->shifts[i] = shifts[i]; |
| 1629 | } | ||
| 1630 | 30 | ctx->nshifts = ns; | |
| 1631 | 30 | nep->state = NEP_STATE_INITIAL; | |
| 1632 |
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); |
| 1633 | } | ||
| 1634 | |||
| 1635 | /*@ | ||
| 1636 | NEPNLEIGSSetRKShifts - Sets a list of shifts to be used in the Rational | ||
| 1637 | Krylov method. | ||
| 1638 | |||
| 1639 | Collective | ||
| 1640 | |||
| 1641 | Input Parameters: | ||
| 1642 | + nep - the nonlinear eigensolver context | ||
| 1643 | . ns - number of shifts | ||
| 1644 | - shifts - array of scalar values specifying the shifts | ||
| 1645 | |||
| 1646 | Options Database Key: | ||
| 1647 | . -nep_nleigs_rk_shifts <s0,s1,...> - sets the list of shifts | ||
| 1648 | |||
| 1649 | Notes: | ||
| 1650 | If only one shift is provided, the built subspace is equivalent to | ||
| 1651 | shift-and-invert Krylov-Schur (provided that the absolute convergence | ||
| 1652 | criterion is used). Otherwise, the rational Krylov variant is run. | ||
| 1653 | |||
| 1654 | In the case of real scalars, complex shifts are not allowed. In the | ||
| 1655 | command line, a comma-separated list of complex values can be provided with | ||
| 1656 | the format `[+/-][realnumber][+/-]realnumberi` with no spaces, e.g. | ||
| 1657 | `-nep_nleigs_rk_shifts 1.0+2.0i,1.5+2.0i,1.0+1.5i`. | ||
| 1658 | |||
| 1659 | Use `ns=0` to remove previously set shifts. | ||
| 1660 | |||
| 1661 | Level: advanced | ||
| 1662 | |||
| 1663 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetRKShifts()` | ||
| 1664 | @*/ | ||
| 1665 | 30 | PetscErrorCode NEPNLEIGSSetRKShifts(NEP nep,PetscInt ns,PetscScalar shifts[]) | |
| 1666 | { | ||
| 1667 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
30 | PetscFunctionBegin; |
| 1668 |
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); |
| 1669 |
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); |
| 1670 |
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); |
| 1671 |
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)); |
| 1672 |
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); |
| 1673 | } | ||
| 1674 | |||
| 1675 | 10 | static PetscErrorCode NEPNLEIGSGetRKShifts_NLEIGS(NEP nep,PetscInt *ns,PetscScalar **shifts) | |
| 1676 | { | ||
| 1677 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1678 | 10 | PetscInt i; | |
| 1679 | |||
| 1680 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1681 | 10 | *ns = ctx->nshifts; | |
| 1682 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (ctx->nshifts) { |
| 1683 |
4/6✓ Branch 0 taken 2 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)); |
| 1684 |
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]; |
| 1685 | } | ||
| 1686 |
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); |
| 1687 | } | ||
| 1688 | |||
| 1689 | /*@C | ||
| 1690 | NEPNLEIGSGetRKShifts - Gets the list of shifts used in the Rational | ||
| 1691 | Krylov method. | ||
| 1692 | |||
| 1693 | Not Collective | ||
| 1694 | |||
| 1695 | Input Parameter: | ||
| 1696 | . nep - the nonlinear eigensolver context | ||
| 1697 | |||
| 1698 | Output Parameters: | ||
| 1699 | + ns - number of shifts | ||
| 1700 | - shifts - array of shifts | ||
| 1701 | |||
| 1702 | Note: | ||
| 1703 | The user is responsible for deallocating the returned array. | ||
| 1704 | |||
| 1705 | Level: advanced | ||
| 1706 | |||
| 1707 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetRKShifts()` | ||
| 1708 | @*/ | ||
| 1709 | 10 | PetscErrorCode NEPNLEIGSGetRKShifts(NEP nep,PetscInt *ns,PetscScalar *shifts[]) PeNS | |
| 1710 | { | ||
| 1711 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1712 |
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); |
| 1713 |
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); |
| 1714 |
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); |
| 1715 |
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)); |
| 1716 |
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); |
| 1717 | } | ||
| 1718 | |||
| 1719 | 274 | static PetscErrorCode NEPNLEIGSGetKSPs_NLEIGS(NEP nep,PetscInt *nsolve,KSP **ksp) | |
| 1720 | { | ||
| 1721 | 274 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
| 1722 | 274 | PetscInt i; | |
| 1723 | 274 | PC pc; | |
| 1724 | |||
| 1725 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
| 1726 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (!ctx->ksp) { |
| 1727 |
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)); |
| 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.
|
274 | PetscCall(PetscMalloc1(ctx->nshiftsw,&ctx->ksp)); |
| 1729 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
638 | for (i=0;i<ctx->nshiftsw;i++) { |
| 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(KSPCreate(PetscObjectComm((PetscObject)nep),&ctx->ksp[i])); |
| 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(PetscObjectIncrementTabLevel((PetscObject)ctx->ksp[i],(PetscObject)nep,1)); |
| 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(KSPSetOptionsPrefix(ctx->ksp[i],((PetscObject)nep)->prefix)); |
| 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(KSPAppendOptionsPrefix(ctx->ksp[i],"nep_nleigs_")); |
| 1734 |
4/6✓ Branch 0 taken 2 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)); |
| 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(KSPSetErrorIfNotConverged(ctx->ksp[i],PETSC_TRUE)); |
| 1736 |
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)); |
| 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.
|
364 | PetscCall(KSPGetPC(ctx->ksp[i],&pc)); |
| 1738 |
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)) { |
| 1739 |
4/6✓ Branch 0 taken 2 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)); |
| 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.
|
20 | PetscCall(PCSetType(pc,PCBJACOBI)); |
| 1741 | } else { | ||
| 1742 |
4/6✓ Branch 0 taken 2 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)); |
| 1743 |
4/6✓ Branch 0 taken 2 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)); |
| 1744 | } | ||
| 1745 | } | ||
| 1746 | } | ||
| 1747 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (nsolve) *nsolve = ctx->nshiftsw; |
| 1748 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (ksp) *ksp = ctx->ksp; |
| 1749 |
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); |
| 1750 | } | ||
| 1751 | |||
| 1752 | /*@C | ||
| 1753 | NEPNLEIGSGetKSPs - Retrieve the array of linear solver objects associated with | ||
| 1754 | the nonlinear eigenvalue solver. | ||
| 1755 | |||
| 1756 | Collective | ||
| 1757 | |||
| 1758 | Input Parameter: | ||
| 1759 | . nep - the nonlinear eigensolver context | ||
| 1760 | |||
| 1761 | Output Parameters: | ||
| 1762 | + nsolve - number of returned `KSP` objects | ||
| 1763 | - ksp - array of linear solver object | ||
| 1764 | |||
| 1765 | Note: | ||
| 1766 | The number of `KSP` objects is equal to the number of shifts provided by the user, | ||
| 1767 | or 1 if the user did not provide shifts. | ||
| 1768 | |||
| 1769 | Level: advanced | ||
| 1770 | |||
| 1771 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetRKShifts()` | ||
| 1772 | @*/ | ||
| 1773 | 274 | PetscErrorCode NEPNLEIGSGetKSPs(NEP nep,PetscInt *nsolve,KSP **ksp) | |
| 1774 | { | ||
| 1775 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
| 1776 |
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); |
| 1777 |
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)); |
| 1778 |
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); |
| 1779 | } | ||
| 1780 | |||
| 1781 | 40 | static PetscErrorCode NEPNLEIGSSetFullBasis_NLEIGS(NEP nep,PetscBool fullbasis) | |
| 1782 | { | ||
| 1783 | 40 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1784 | |||
| 1785 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
40 | PetscFunctionBegin; |
| 1786 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
40 | if (fullbasis!=ctx->fullbasis) { |
| 1787 | 30 | ctx->fullbasis = fullbasis; | |
| 1788 | 30 | nep->state = NEP_STATE_INITIAL; | |
| 1789 | 30 | nep->useds = PetscNot(fullbasis); | |
| 1790 | } | ||
| 1791 |
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); |
| 1792 | } | ||
| 1793 | |||
| 1794 | /*@ | ||
| 1795 | NEPNLEIGSSetFullBasis - Choose between TOAR-basis (default) and full-basis | ||
| 1796 | variants of the NLEIGS method. | ||
| 1797 | |||
| 1798 | Logically Collective | ||
| 1799 | |||
| 1800 | Input Parameters: | ||
| 1801 | + nep - the nonlinear eigensolver context | ||
| 1802 | - fullbasis - true if the full-basis variant must be selected | ||
| 1803 | |||
| 1804 | Options Database Key: | ||
| 1805 | . -nep_nleigs_full_basis - sets the full-basis flag | ||
| 1806 | |||
| 1807 | Notes: | ||
| 1808 | The default is to use a compact representation of the Krylov basis, that is, | ||
| 1809 | $V = (I \otimes U) S$, with a `BVTENSOR`. This behavior can be changed so that | ||
| 1810 | the full basis $V$ is explicitly stored and operated with. This variant is more | ||
| 1811 | expensive in terms of memory and computation, but is necessary in some cases, | ||
| 1812 | particularly for two-sided computations, see `NEPSetTwoSided()`. | ||
| 1813 | |||
| 1814 | In the full-basis variant, the NLEIGS solver uses an `EPS` object to explicitly | ||
| 1815 | solve the linearized eigenproblem, see `NEPNLEIGSGetEPS()`. | ||
| 1816 | |||
| 1817 | Level: advanced | ||
| 1818 | |||
| 1819 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSGetFullBasis()`, `NEPNLEIGSGetEPS()`, `NEPSetTwoSided()`, `BVCreateTensor()` | ||
| 1820 | @*/ | ||
| 1821 | 40 | PetscErrorCode NEPNLEIGSSetFullBasis(NEP nep,PetscBool fullbasis) | |
| 1822 | { | ||
| 1823 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
40 | PetscFunctionBegin; |
| 1824 |
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); |
| 1825 |
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); |
| 1826 |
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)); |
| 1827 |
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); |
| 1828 | } | ||
| 1829 | |||
| 1830 | 10 | static PetscErrorCode NEPNLEIGSGetFullBasis_NLEIGS(NEP nep,PetscBool *fullbasis) | |
| 1831 | { | ||
| 1832 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1833 | |||
| 1834 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1835 | 10 | *fullbasis = ctx->fullbasis; | |
| 1836 |
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); |
| 1837 | } | ||
| 1838 | |||
| 1839 | /*@ | ||
| 1840 | NEPNLEIGSGetFullBasis - Gets the flag that indicates if NLEIGS is using the | ||
| 1841 | full-basis variant. | ||
| 1842 | |||
| 1843 | Not Collective | ||
| 1844 | |||
| 1845 | Input Parameter: | ||
| 1846 | . nep - the nonlinear eigensolver context | ||
| 1847 | |||
| 1848 | Output Parameter: | ||
| 1849 | . fullbasis - the flag | ||
| 1850 | |||
| 1851 | Level: advanced | ||
| 1852 | |||
| 1853 | .seealso: [](ch:nep), `NEPNLEIGS`, `NEPNLEIGSSetFullBasis()` | ||
| 1854 | @*/ | ||
| 1855 | 10 | PetscErrorCode NEPNLEIGSGetFullBasis(NEP nep,PetscBool *fullbasis) | |
| 1856 | { | ||
| 1857 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 1858 |
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); |
| 1859 |
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); |
| 1860 |
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)); |
| 1861 |
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); |
| 1862 | } | ||
| 1863 | |||
| 1864 | #define SHIFTMAX 30 | ||
| 1865 | |||
| 1866 | 274 | static PetscErrorCode NEPSetFromOptions_NLEIGS(NEP nep,PetscOptionItems PetscOptionsObject) | |
| 1867 | { | ||
| 1868 | 274 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
| 1869 | 274 | PetscInt i=0,k; | |
| 1870 | 274 | PetscBool flg1,flg2,b; | |
| 1871 | 274 | PetscReal r; | |
| 1872 | 274 | PetscScalar array[SHIFTMAX]; | |
| 1873 | |||
| 1874 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
274 | PetscFunctionBegin; |
| 1875 |
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"); |
| 1876 | |||
| 1877 |
4/6✓ Branch 0 taken 2 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)); |
| 1878 |
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)); |
| 1879 | |||
| 1880 |
4/6✓ Branch 0 taken 2 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)); |
| 1881 |
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)); |
| 1882 | |||
| 1883 |
4/6✓ Branch 0 taken 2 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)); |
| 1884 |
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)); |
| 1885 | |||
| 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(NEPNLEIGSGetInterpolation(nep,&r,&i)); |
| 1887 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
274 | if (!i) i = PETSC_DETERMINE; |
| 1888 |
4/6✓ Branch 0 taken 2 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)); |
| 1889 |
4/6✓ Branch 0 taken 2 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)); |
| 1890 |
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)); |
| 1891 | |||
| 1892 | 274 | k = SHIFTMAX; | |
| 1893 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
8494 | for (i=0;i<k;i++) array[i] = 0; |
| 1894 |
4/6✓ Branch 0 taken 2 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)); |
| 1895 |
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)); |
| 1896 | |||
| 1897 |
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(); |
| 1898 | |||
| 1899 |
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)); |
| 1900 |
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])); |
| 1901 | |||
| 1902 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
274 | if (ctx->fullbasis) { |
| 1903 |
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)); |
| 1904 |
4/6✓ Branch 0 taken 2 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)); |
| 1905 | } | ||
| 1906 |
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); |
| 1907 | } | ||
| 1908 | |||
| 1909 | 10 | static PetscErrorCode NEPView_NLEIGS(NEP nep,PetscViewer viewer) | |
| 1910 | { | ||
| 1911 | 10 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1912 | 10 | PetscBool isascii; | |
| 1913 | 10 | PetscInt i; | |
| 1914 | 10 | char str[50]; | |
| 1915 | |||
| 1916 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
10 | PetscFunctionBegin; |
| 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(PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&isascii)); |
| 1918 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (isascii) { |
| 1919 |
4/6✓ Branch 0 taken 2 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))); |
| 1920 |
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")); |
| 1921 |
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-")); |
| 1922 |
4/6✓ Branch 0 taken 2 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)); |
| 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," tolerance for divided difference convergence: %g\n",(double)ctx->ddtol)); |
| 1924 |
1/2✓ Branch 0 taken 10 times.
✗ Branch 1 not taken.
|
10 | if (ctx->nshifts) { |
| 1925 |
4/6✓ Branch 0 taken 2 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: ")); |
| 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.
|
10 | PetscCall(PetscViewerASCIIUseTabs(viewer,PETSC_FALSE)); |
| 1927 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
50 | for (i=0;i<ctx->nshifts;i++) { |
| 1928 |
4/6✓ Branch 0 taken 2 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)); |
| 1929 |
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)?",":"")); |
| 1930 | } | ||
| 1931 |
4/6✓ Branch 0 taken 2 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")); |
| 1932 |
4/6✓ Branch 0 taken 2 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)); |
| 1933 | } | ||
| 1934 |
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)); |
| 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(PetscViewerASCIIPushTab(viewer)); |
| 1936 |
4/6✓ Branch 0 taken 2 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)); |
| 1937 |
4/6✓ Branch 0 taken 2 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)); |
| 1938 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
|
10 | if (ctx->fullbasis) { |
| 1939 | ✗ | if (!ctx->eps) PetscCall(NEPNLEIGSGetEPS(nep,&ctx->eps)); | |
| 1940 | ✗ | PetscCall(PetscViewerASCIIPushTab(viewer)); | |
| 1941 | ✗ | PetscCall(EPSView(ctx->eps,viewer)); | |
| 1942 | ✗ | PetscCall(PetscViewerASCIIPopTab(viewer)); | |
| 1943 | } | ||
| 1944 | } | ||
| 1945 |
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); |
| 1946 | } | ||
| 1947 | |||
| 1948 | 294 | static PetscErrorCode NEPReset_NLEIGS(NEP nep) | |
| 1949 | { | ||
| 1950 | 294 | PetscInt k; | |
| 1951 | 294 | NEP_NLEIGS *ctx=(NEP_NLEIGS*)nep->data; | |
| 1952 | |||
| 1953 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
294 | PetscFunctionBegin; |
| 1954 |
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)); |
| 1955 | else { | ||
| 1956 |
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])); |
| 1957 | } | ||
| 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(PetscFree4(ctx->s,ctx->xi,ctx->beta,ctx->D)); |
| 1959 |
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])); |
| 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.
|
294 | PetscCall(VecDestroy(&ctx->vrn)); |
| 1961 |
2/2✓ Branch 0 taken 10 times.
✓ Branch 1 taken 10 times.
|
294 | if (ctx->fullbasis) { |
| 1962 |
4/6✓ Branch 0 taken 2 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)); |
| 1963 |
4/6✓ Branch 0 taken 2 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)); |
| 1964 |
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])); |
| 1965 | } | ||
| 1966 |
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); |
| 1967 | } | ||
| 1968 | |||
| 1969 | 345 | static PetscErrorCode NEPDestroy_NLEIGS(NEP nep) | |
| 1970 | { | ||
| 1971 | 345 | PetscInt k; | |
| 1972 | 345 | NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data; | |
| 1973 | |||
| 1974 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
345 | PetscFunctionBegin; |
| 1975 |
4/6✓ Branch 0 taken 2 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)); |
| 1976 |
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])); |
| 1977 |
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)); |
| 1978 |
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)); |
| 1979 |
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)); |
| 1980 |
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)); |
| 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,"NEPNLEIGSSetSingularitiesFunction_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,"NEPNLEIGSGetSingularitiesFunction_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,"NEPNLEIGSSetRestart_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,"NEPNLEIGSGetRestart_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,"NEPNLEIGSSetLocking_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,"NEPNLEIGSGetLocking_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,"NEPNLEIGSSetInterpolation_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,"NEPNLEIGSGetInterpolation_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,"NEPNLEIGSSetRKShifts_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,"NEPNLEIGSGetRKShifts_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,"NEPNLEIGSGetKSPs_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,"NEPNLEIGSSetFullBasis_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,"NEPNLEIGSGetFullBasis_C",NULL)); |
| 1994 |
4/6✓ Branch 0 taken 2 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)); |
| 1995 |
4/6✓ Branch 0 taken 2 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)); |
| 1996 |
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); |
| 1997 | } | ||
| 1998 | |||
| 1999 | /*MC | ||
| 2000 | NEPNLEIGS - NEPNLEIGS = "nleigs" - The NLEIGS method. | ||
| 2001 | |||
| 2002 | Notes: | ||
| 2003 | This solver implements the NLEIGS method {cite:p}`Gut14`, which | ||
| 2004 | is based on rational interpolation followed by linearization. | ||
| 2005 | In our implementation, the linear eigensolver for the linearization | ||
| 2006 | operates with a compressed Krylov basis, as in the TOAR polynomial | ||
| 2007 | eigensolver, see the detailed description in {cite:p}`Cam21`. | ||
| 2008 | |||
| 2009 | This method is particularly appropriate for nonlinear problems with | ||
| 2010 | singularities. The solver will try to determine the singularities | ||
| 2011 | automatically, but the user can also provide them with | ||
| 2012 | `NEPNLEIGSSetSingularitiesFunction()`. | ||
| 2013 | |||
| 2014 | By default, the solver performs the static NLEIGS variant, with | ||
| 2015 | constant shift given by `NEPSetTarget()`. But the dynamic variant | ||
| 2016 | (rational Krylov) is also available if a list of shifts is given | ||
| 2017 | in `NEPNLEIGSSetRKShifts()`. | ||
| 2018 | |||
| 2019 | `NEPNLEIGS` also implements a two-sided variant for computing left | ||
| 2020 | eigenvectors when `NEPSetTwoSided()` has been set. | ||
| 2021 | |||
| 2022 | Apart from working with the compressed basis, it is also possible | ||
| 2023 | to enable the operation with an explicit basis for the linear | ||
| 2024 | eigensolver, see `NEPNLEIGSSetFullBasis()`. This allows using | ||
| 2025 | other eigensolvers via an `EPS` object obtained with `NEPNLEIGSGetEPS()`. | ||
| 2026 | Also, the explicit basis is activated in the two-sided variant. | ||
| 2027 | |||
| 2028 | Level: beginner | ||
| 2029 | |||
| 2030 | .seealso: [](ch:nep), `NEP`, `NEPType`, `NEPSetType()`, `NEPNLEIGSSetSingularitiesFunction()`, `NEPSetTarget()`, `NEPNLEIGSSetRKShifts()`, `NEPNLEIGSSetFullBasis()`, `NEPNLEIGSGetEPS()`, `NEPSetTwoSided()` | ||
| 2031 | M*/ | ||
| 2032 | 345 | SLEPC_EXTERN PetscErrorCode NEPCreate_NLEIGS(NEP nep) | |
| 2033 | { | ||
| 2034 | 345 | NEP_NLEIGS *ctx; | |
| 2035 | |||
| 2036 |
1/2✓ Branch 0 taken 2 times.
✗ Branch 1 not taken.
|
345 | PetscFunctionBegin; |
| 2037 |
4/6✓ Branch 0 taken 2 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)); |
| 2038 | 345 | nep->data = (void*)ctx; | |
| 2039 | 345 | ctx->lock = PETSC_TRUE; | |
| 2040 | 345 | ctx->ddtol = PETSC_DETERMINE; | |
| 2041 | |||
| 2042 | 345 | nep->useds = PETSC_TRUE; | |
| 2043 | |||
| 2044 | 345 | nep->ops->setup = NEPSetUp_NLEIGS; | |
| 2045 | 345 | nep->ops->setfromoptions = NEPSetFromOptions_NLEIGS; | |
| 2046 | 345 | nep->ops->view = NEPView_NLEIGS; | |
| 2047 | 345 | nep->ops->destroy = NEPDestroy_NLEIGS; | |
| 2048 | 345 | nep->ops->reset = NEPReset_NLEIGS; | |
| 2049 | |||
| 2050 |
4/6✓ Branch 0 taken 2 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)); |
| 2051 |
4/6✓ Branch 0 taken 2 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)); |
| 2052 |
4/6✓ Branch 0 taken 2 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)); |
| 2053 |
4/6✓ Branch 0 taken 2 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)); |
| 2054 |
4/6✓ Branch 0 taken 2 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)); |
| 2055 |
4/6✓ Branch 0 taken 2 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)); |
| 2056 |
4/6✓ Branch 0 taken 2 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)); |
| 2057 |
4/6✓ Branch 0 taken 2 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)); |
| 2058 |
4/6✓ Branch 0 taken 2 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)); |
| 2059 |
4/6✓ Branch 0 taken 2 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)); |
| 2060 |
4/6✓ Branch 0 taken 2 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)); |
| 2061 |
4/6✓ Branch 0 taken 2 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)); |
| 2062 |
4/6✓ Branch 0 taken 2 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)); |
| 2063 |
4/6✓ Branch 0 taken 2 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)); |
| 2064 |
4/6✓ Branch 0 taken 2 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)); |
| 2065 |
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); |
| 2066 | } | ||
| 2067 |