svMultiPhysics
Loading...
Searching...
No Matches
set_equation_dof.h
1/* Copyright (c) Stanford University, The Regents of the University of California, and others.
2 *
3 * All Rights Reserved.
4 *
5 * See Copyright-SimVascular.txt for additional details.
6 *
7 * Permission is hereby granted, free of charge, to any person obtaining
8 * a copy of this software and associated documentation files (the
9 * "Software"), to deal in the Software without restriction, including
10 * without limitation the rights to use, copy, modify, merge, publish,
11 * distribute, sublicense, and/or sell copies of the Software, and to
12 * permit persons to whom the Software is furnished to do so, subject
13 * to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included
16 * in all copies or substantial portions of the Software.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
19 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
21 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
22 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
23 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
25 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
26 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
30
31#include <map>
32#include <tuple>
33
34/// @brief The 'equation_dof_map' map defined here sets equation dof and sym data members.
35//
36using EquationDofType = std::tuple<int, std::string>;
37
38std::map<consts::EquationType, EquationDofType> equation_dof_map =
39{
40 {EquationType::phys_fluid, std::make_tuple(nsd+1, "NS") },
41 {EquationType::phys_heatF, std::make_tuple(1, "HF") },
42 {EquationType::phys_heatS, std::make_tuple(1, "HS") },
43 {EquationType::phys_lElas, std::make_tuple(nsd, "LE") },
44 {EquationType::phys_struct, std::make_tuple(nsd, "ST") },
45 {EquationType::phys_ustruct, std::make_tuple(nsd+1, "ST") },
46 {EquationType::phys_CMM, std::make_tuple(nsd+1, "CM") },
47 {EquationType::phys_shell, std::make_tuple(nsd, "SH") },
48 {EquationType::phys_FSI, std::make_tuple(nsd+1, "FS") },
49 {EquationType::phys_mesh, std::make_tuple(nsd, "MS") },
50 {EquationType::phys_CEP, std::make_tuple(1, "EP") },
51 {EquationType::phys_stokes, std::make_tuple(nsd+1, "SS") }
52};
53