Skip to content
Snippets Groups Projects
Select Git revision
  • 077fec0bca034377a3ab2953f5ba398693dd8cfa
  • master default
  • cgnsUnstructured
  • partitioning
  • poppler
  • HighOrderBLCurving
  • gmsh_3_0_4
  • gmsh_3_0_3
  • gmsh_3_0_2
  • gmsh_3_0_1
  • gmsh_3_0_0
  • gmsh_2_16_0
  • gmsh_2_15_0
  • gmsh_2_14_1
  • gmsh_2_14_0
  • gmsh_2_13_2
  • gmsh_2_13_1
  • gmsh_2_12_0
  • gmsh_2_11_0
  • gmsh_2_10_1
  • gmsh_2_10_0
  • gmsh_2_9_3
  • gmsh_2_9_2
  • gmsh_2_9_1
  • gmsh_2_9_0
  • gmsh_2_8_6
26 results

FAQ

Blame
  • Forked from gmsh / gmsh
    Source project has a limited visibility.
    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