Flow123d  release_3.0.0-684-g928e266
generic_field.impl.hh
Go to the documentation of this file.
1 /*!
2  *
3  * Copyright (C) 2015 Technical University of Liberec. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it under
6  * the terms of the GNU General Public License version 3 as published by the
7  * Free Software Foundation. (http://www.gnu.org/licenses/gpl-3.0.en.html)
8  *
9  * This program is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
12  *
13  *
14  * @file generic_field.impl.hh
15  * @brief
16  */
17 
18 #ifndef GENERIC_FIELD_IMPL_HH_
19 #define GENERIC_FIELD_IMPL_HH_
20 
21 #include <memory>
22 #include "mesh/mesh.h"
23 #include "mesh/partitioning.hh"
24 #include "mesh/accessors.hh"
25 
26 #include "fields/generic_field.hh"
27 #include "fields/field_fe.hh"
28 #include "la/vector_mpi.hh"
30 
31 #include "fem/mapping_p1.hh"
32 #include "fem/fe_p.hh"
33 #include "fem/dofhandler.hh"
34 #include "fem/discrete_space.hh"
35 
36 
37 template <int spacedim>
39  IndexField region_id;
40  region_id.name("region_id");
41  region_id.units( UnitSI::dimensionless() );
42  region_id.set_mesh(mesh);
43 
44  RegionSet all_regions=mesh.region_db().get_region_set("ALL");
45  for(Region reg : all_regions) {
46  auto field_algo=std::make_shared<FieldConstant<spacedim, DoubleScalar>>();
47  field_algo->set_value(reg.id());
48  region_id.set_field(
49  {reg} ,
50  field_algo,
51  0.0); // time=0.0
52  }
53  return region_id;
54 }
55 
56 template <int spacedim>
58  static MappingP1<1,3> map1;
59  static MappingP1<2,3> map2;
60  static MappingP1<3,3> map3;
61  static FE_P_disc<0> fe0(0);
62  static FE_P_disc<1> fe1(0);
63  static FE_P_disc<2> fe2(0);
64  static FE_P_disc<3> fe3(0);
65  DOFHandlerMultiDim dh_par(mesh);
66  std::shared_ptr<DiscreteSpace> ds = std::make_shared<EqualOrderDiscreteSpace>( &mesh, &fe0, &fe1, &fe2, &fe3);
67  dh_par.distribute_dofs(ds);
68  std::shared_ptr<DOFHandlerMultiDim> dh = dh_par.sequential();
69 
70  auto field_subdomain_data = mesh.get_part()->subdomain_id_field_data();
71  std::vector<LongIdx> indices(1);
72  VectorMPI *data_vec = new VectorMPI(mesh.n_elements());
73  ASSERT_EQ(dh->max_elem_dofs(), 1);
74  unsigned int i_ele=0;
75  for (auto cell : dh->own_range()) {
76  cell.get_dof_indices(indices);
77  (*data_vec)[ indices[0] ] = (*field_subdomain_data)[i_ele];
78  ++i_ele;
79  }
80  std::shared_ptr< FieldFE<spacedim, DoubleScalar> > field_ptr = std::make_shared< FieldFE<spacedim, DoubleScalar> >();
81  field_ptr->set_fe_data(dh, &map1, &map2, &map3, data_vec);
82 
83  IndexField subdomain;
84  subdomain.name("subdomain");
85  subdomain.units( UnitSI::dimensionless() );
86  subdomain.set_mesh(mesh);
87 
88  subdomain.set_field(
89  mesh.region_db().get_region_set("ALL"),
90  field_ptr,
91  0.0); // time=0.0
92 
93  return subdomain;
94 }
95 
96 
97 
98 #endif /* GENERAL_FIELD_IMPL_HH_ */
Class MappingP1 implements the affine transformation of the unit cell onto the actual cell...
std::shared_ptr< DOFHandlerMultiDim > sequential()
Returns sequential version of the current dof handler.
Definition: dofhandler.cc:88
static auto subdomain(Mesh &mesh) -> IndexField
Declaration of class which handles the ordering of degrees of freedom (dof) and mappings between loca...
Class template representing a field with values dependent on: point, element, and region...
Definition: field.hh:83
void distribute_dofs(std::shared_ptr< DiscreteSpace > ds)
Distributes degrees of freedom on the mesh needed for the given discrete space.
Definition: dofhandler.cc:266
Definition: mesh.h:80
Fields computed from the mesh data.
FieldCommon & units(const UnitSI &units)
Set basic units of the field.
Definitions of basic Lagrangean finite elements with polynomial shape functions.
static auto region_id(Mesh &mesh) -> IndexField
Provides the numbering of the finite element degrees of freedom on the computational mesh...
Definition: dofhandler.hh:156
Declaration of class which provides the finite element for every mesh cell.
void set_field(const RegionSet &domain, FieldBasePtr field, double time=0.0)
Definition: field.impl.hh:198
FieldCommon & name(const string &name)
void set_mesh(const Mesh &mesh) override
Definition: field.impl.hh:159
static UnitSI & dimensionless()
Returns dimensionless unit.
Definition: unit_si.cc:55
#define ASSERT_EQ(a, b)
Definition of comparative assert macro (EQual)
Definition: asserts.hh:327