LCOV - code coverage report
Current view: top level - nep/impls/nleigs - nleigs.h (source / functions) Hit Total Coverage
Test: SLEPc Lines: 8 8 100.0 %
Date: 2024-11-21 00:40:22 Functions: 1 1 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       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             :    Private header for NLEIGS
      12             : */
      13             : 
      14             : #pragma once
      15             : 
      16             : #define  LBPOINTS  100   /* default value of the maximum number of Leja-Bagby points */
      17             : #define  NDPOINTS  1e4   /* number of discretization points */
      18             : 
      19             : typedef struct {
      20             :   BV             V;         /* tensor vector basis for the linearization */
      21             :   BV             W;         /* tensor vector basis for the linearization */
      22             :   PetscInt       nmat;      /* number of interpolation points */
      23             :   PetscScalar    *s,*xi;    /* Leja-Bagby points */
      24             :   PetscScalar    *beta;     /* scaling factors */
      25             :   Mat            *D;        /* divided difference matrices */
      26             :   PetscScalar    *coeffD;   /* coefficients for divided differences in split form */
      27             :   PetscInt       nshifts;   /* provided number of shifts */
      28             :   PetscScalar    *shifts;   /* user-provided shifts for the Rational Krylov variant */
      29             :   PetscInt       nshiftsw;  /* actual number of shifts (1 if Krylov-Schur) */
      30             :   PetscReal      ddtol;     /* tolerance for divided difference convergence */
      31             :   PetscInt       ddmaxit;   /* maximum number of divided difference terms */
      32             :   PetscReal      keep;      /* restart parameter */
      33             :   PetscBool      lock;      /* locking/non-locking variant */
      34             :   PetscInt       idxrk;     /* index of next shift to use */
      35             :   KSP            *ksp;      /* ksp array for storing shift factorizations */
      36             :   Vec            vrn;       /* random vector with normally distributed value */
      37             :   PetscBool      fullbasis; /* use full Krylov basis instead of TOAR basis */
      38             :   EPS            eps;       /* eigensolver used in the full basis variant */
      39             :   Mat            A;         /* shell matrix used for the eps in full basis */
      40             :   Vec            w[6];      /* work vectors */
      41             :   void           *singularitiesctx;
      42             :   PetscErrorCode (*computesingularities)(NEP,PetscInt*,PetscScalar*,void*);
      43             : } NEP_NLEIGS;
      44             : 
      45             : typedef struct {
      46             :   PetscInt    nmat,maxnmat;
      47             :   PetscScalar *coeff;
      48             :   Mat         *A;
      49             :   Vec         t;
      50             : } NEP_NLEIGS_MATSHELL;
      51             : 
      52          25 : static inline PetscErrorCode NEPNLEIGSSetShifts(NEP nep,PetscInt *nshiftsw)
      53             : {
      54          25 :   NEP_NLEIGS *ctx = (NEP_NLEIGS*)nep->data;
      55             : 
      56          25 :   PetscFunctionBegin;
      57          25 :   if (!ctx->nshifts) {
      58          22 :     ctx->shifts = &nep->target;
      59          22 :     *nshiftsw = 1;
      60           3 :   } else *nshiftsw = ctx->nshifts;
      61          25 :   PetscFunctionReturn(PETSC_SUCCESS);
      62             : }
      63             : 
      64             : SLEPC_INTERN PetscErrorCode NEPSetUp_NLEIGS_FullBasis(NEP);
      65             : SLEPC_INTERN PetscErrorCode NEPNLEIGSSetEPS_NLEIGS(NEP,EPS);
      66             : SLEPC_INTERN PetscErrorCode NEPNLEIGSGetEPS_NLEIGS(NEP,EPS*);
      67             : SLEPC_INTERN PetscErrorCode NEPNLEIGSBackTransform(PetscObject,PetscInt,PetscScalar*,PetscScalar *vali);
      68             : SLEPC_INTERN PetscErrorCode NEPNLEIGSEvalNRTFunct(NEP,PetscInt,PetscScalar,PetscScalar*);
      69             : SLEPC_INTERN PetscErrorCode NEPSolve_NLEIGS_FullBasis(NEP);
      70             : SLEPC_INTERN PetscErrorCode NEPSolve_NLEIGS(NEP);

Generated by: LCOV version 1.14