Skip to content
Snippets Groups Projects
Select Git revision
  • 8b4bbdadc13fef7f4d4b882b362f2504612ab83c
  • master default protected
  • NewDistributionGmshFWI
  • parametrizationSimpleWave
  • tuto_obstacle
  • everything
  • cleanup_configuuration_mesh
  • fix
  • source_estimation
  • unique_ptr
  • SobolevDirectionalFilter
  • OT
  • newPhysics
  • SimultaneousFrequency
  • SobolevDistance
  • BonesImaging
  • MultiParameter
  • UpdateAntho
  • v2.0
  • v1.0
20 results

updater.cpp

Blame
  • linearSystemMUMPS.h 2.61 KiB
    // Gmsh - Copyright (C) 1997-2019 C. Geuzaine, J.-F. Remacle
    //
    // See the LICENSE.txt file for license information. Please report all
    // issues on https://gitlab.onelab.info/gmsh/gmsh/issues.
    
    #ifndef LINEAR_SYSTEM_MUMPS_H
    #define LINEAR_SYSTEM_MUMPS_H
    
    // Interface to a linear system with MUMPS
    
    #include "GmshConfig.h"
    #include "GmshMessage.h"
    #include "linearSystem.h"
    
    #if defined(HAVE_MUMPS)
    #include "dmumps_c.h"
    #include "zmumps_c.h"
    
    template <class scalar> class linearSystemMUMPS : public linearSystem<scalar> {
    public:
      linearSystemMUMPS()
      {
        Msg::Info("linearSystemMUMPS not implemented for this element type");
      }
    
      virtual bool isAllocated() const { return false; }
      virtual void allocate(int nbRows) {}
      virtual void clear() {}
      virtual void zeroMatrix() {}
      virtual void zeroRightHandSide() {}
      virtual void zeroSolution() {}
      virtual int systemSolve() { return 1; }
      virtual void insertInSparsityPattern(int row, int col) {}
      virtual double normInfRightHandSide() const { return 0.; }
      virtual double normInfSolution() const { return 0.; }
    
      virtual void addToMatrix(int row, int col, const double &val) {}
      virtual void getFromMatrix(int row, int col, double &val) const {}
      virtual void addToRightHandSide(int row, const scalar &val, int ith = 0) {}
      virtual void getFromRightHandSide(int row, scalar &val) const {}
      virtual void getFromSolution(int row, scalar &val) const {}
      virtual void addToSolution(int row, const scalar &val) {}
    };
    
    template <> class linearSystemMUMPS<double> : public linearSystem<double> {
    private:
      int _n;
      int _nz;
    
      std::vector<int> _irn;
      std::vector<int> _jcn;
    
      std::vector<DMUMPS_REAL> _x;
      std::vector<DMUMPS_REAL> _b;
      std::vector<DMUMPS_REAL> _a;
    
      // _ij[i][j] is the index of _a that is the (i, j) element of
      // the system matrix
      std::vector<std::map<int, int> > _ij;
    
    public:
      linearSystemMUMPS();
    
      virtual bool isAllocated() const;
      virtual void allocate(int nbRows);
      virtual void clear();
      virtual void zeroMatrix();
    
      virtual void zeroRightHandSide();
      virtual void zeroSolution();
      virtual int systemSolve();
      virtual void insertInSparsityPattern(int row, int col);
      virtual double normInfRightHandSide() const;
      virtual double normInfSolution() const;
    
      virtual void addToMatrix(int row, int col, const double &val);
      virtual void getFromMatrix(int row, int col, double &val) const;
      virtual void addToRightHandSide(int row, const double &val, int ith = 0);
      virtual void getFromRightHandSide(int row, double &val) const;
      virtual void getFromSolution(int row, double &val) const;
      virtual void addToSolution(int row, const double &val);
    };
    
    #endif
    
    #endif