view src/PETSc_factory.h @ 261:f22588ae37af

Improve template meshfunction implementation * inst/import_meshfunction_type.m: provide to the auxiliary functions a type name and a valid identifier * inst/private/generate_mf_*.m: add space before closing angle bracket to avoid parse errors
author Eugenio Gianniti <eugenio.gianniti@mail.polimi.it>
date Thu, 07 Aug 2014 11:13:54 +0200
parents 8fe68d94ab76
children 61830a4f9ab9
line wrap: on
line source

/*
 Copyright (C) 2014 Eugenio Gianniti <eugenio.gianniti@mail.polimi.it>

 This program is free software; you can redistribute it and/or modify it under
 the terms of the GNU General Public License as published by the Free Software
 Foundation; either version 3 of the License, or (at your option) any later
 version.

 This program is distributed in the hope that it will be useful, but WITHOUT
 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 details.

 You should have received a copy of the GNU General Public License along with
 this program; if not, see <http://www.gnu.org/licenses/>.
*/

#ifndef __FEMFENICS_PETSC_FACTORY__
#define __FEMFENICS_PETSC_FACTORY__

#include "femfenics_base_factory.h"

class PETSc_factory : public femfenics_base_factory
{
  public:

  virtual ~PETSc_factory () {}

  octave_value matrix (dolfin::Matrix const&) const;
  octave_value vector (dolfin::Vector const&) const;

  static femfenics_base_factory const& instance (void);

  private:

  PETSc_factory () {}
  PETSc_factory (PETSc_factory const&);
  PETSc_factory & operator = (PETSc_factory const&);

  static void add_to_arrays (Array <octave_idx_type> &,
                             Array <octave_idx_type> &,
                             Array <double> &,
                             std::vector <std::size_t> const&,
                             std::vector <std::size_t> const&,
                             std::vector <double> const&);

  octave_value do_matrix_serial (dolfin::Matrix const&) const;
  octave_value do_matrix_parallel (dolfin::Matrix const&) const;
  octave_value do_vector_serial (dolfin::Vector const&) const;
  octave_value do_vector_parallel (dolfin::Vector const&) const;
};

#endif