/usr/include/dolfin/fem/MultiMeshDofMap.h is in libdolfin-dev 2017.2.0.post0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 | // Copyright (C) 2013-2016 Anders Logg
//
// This file is part of DOLFIN.
//
// DOLFIN is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// DOLFIN 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 Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with DOLFIN. If not, see <http://www.gnu.org/licenses/>.
//
// First added: 2013-09-19
// Last changed: 2016-03-02
#ifndef __MULTI_MESH_DOF_MAP_H
#define __MULTI_MESH_DOF_MAP_H
#include "GenericDofMap.h"
#include <dolfin/mesh/MultiMesh.h>
namespace dolfin
{
// Forward declarations
class MultiMeshFunctionSpace;
class MultiMesh;
/// This class handles the mapping of degrees of freedom for MultiMesh
/// function spaces.
class MultiMeshDofMap
{
public:
/// Constructor
MultiMeshDofMap();
/// Copy constructor
MultiMeshDofMap(const MultiMeshDofMap& dofmap);
/// Destructor
~MultiMeshDofMap();
/// Return the number dofmaps (parts) of the MultiMesh dofmap
///
/// *Returns*
/// std::size_t
/// The number of dofmaps (parts) of the MultiMesh dofmap
std::size_t num_parts() const;
/// Return dofmap (part) number i
///
/// *Returns*
/// _GenericDofMap_
/// Dofmap (part) number i
std::shared_ptr<const GenericDofMap> part(std::size_t i) const;
/// Add dofmap
///
/// *Arguments*
/// dofmap (_GenericDofMap_)
/// The dofmap.
void add(std::shared_ptr<const GenericDofMap> dofmap);
/// Build MultiMesh dofmap
void build(const MultiMeshFunctionSpace& function_space,
const std::vector<dolfin::la_index>& offsets);
/// Clear MultiMesh dofmap
void clear();
/// Return the dimension of the global finite element function
/// space
std::size_t global_dimension() const;
/// Return the ownership range (dofs in this range are owned by
/// this process)
std::pair<std::size_t, std::size_t> ownership_range() const;
/// Return map from nonlocal-dofs (that appear in local dof map)
/// to owning process
const std::vector<int>& off_process_owner() const;
/// Return the map
std::shared_ptr<IndexMap> index_map() const;
/// Return informal string representation (pretty-print)
std::string str(bool verbose) const;
/// Return inactive dofs
std::vector<dolfin::la_index> inactive_dofs(const MultiMesh &multimesh,
std::size_t part_id) const;
private:
// Index Map containing total global dimension (sum of parts)
// FIXME: make it work in parallel
std::shared_ptr<IndexMap> _index_map;
// List of original dofmaps
std::vector<std::shared_ptr<const GenericDofMap>> _original_dofmaps;
// List of modified dofmaps
std::vector<std::shared_ptr<GenericDofMap>> _new_dofmaps;
};
}
#endif
|