/*! \file Enum_comp.h
\brief def de l'enuméré permettant d'identifier chaque loi de comportement
*/
// FICHIER : Enum_comp.h
// This file is part of the Herezh++ application.
//
// The finite element software Herezh++ is dedicated to the field
// of mechanics for large transformations of solid structures.
// It is developed by Gérard Rio (APP: IDDN.FR.010.0106078.000.R.P.2006.035.20600)
// INSTITUT DE RECHERCHE DUPUY DE LÔME (IRDL) .
//
// Herezh++ is distributed under GPL 3 license ou ultérieure.
//
// Copyright (C) 1997-2022 Université Bretagne Sud (France)
// AUTHOR : Gérard Rio
// E-MAIL : gerardrio56@free.fr
//
// 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 .
//
// For more information, please consult: .
// Afin de realiser un gain en place memoire, les noms des lois de comportement sont
// stockes a l'aide d'un type enumere. Les fonctions Nom_comp et Id_nom_comp rendent
// possible le lien entre les noms des lois de comportement et les identificateurs
// de type enumere correspondants.
#ifndef ENUM_COMP_H
#define ENUM_COMP_H
#include
using namespace std;
/// @addtogroup Group_types_enumeres
/// @{
/// énuméré permettant d'identifier chaque loi de comportement
enum Enum_comp { ISOELAS=1,ISOELAS1D, ISOELAS2D_D,ISOELAS2D_C,ISO_ELAS_ESPO1D
,ISO_ELAS_SE1D,ISO_ELAS_ESPO3D
,ORTHOELA3D,ORTHOELA2D_D,ORTHOELA2D_C
,HYPO_ORTHO3D,HYPO_ORTHO2D_D,HYPO_ORTHO2D_C
,PROJECTION_ANISOTROPE_3D
,VISCOELA,ISOHYPER,ISOHYPER1,ISOHYPER10, ISOHYSTE
,TRELOAR, ISOHYPER3DFAVIER1,ISOHYPER3DFAVIER2,ISOHYPER3DFAVIER3
,ISOHYPER3DFAVIER4,ISOHYPER3DORGEAS1,ISOHYPER3DORGEAS2
,ISOHYPERBULK3,ISOHYPERBULK_GENE
,PRANDTL_REUSS,PRANDTL_REUSS2D_D,PRANDTL_REUSS2D_C
,PRANDTL_REUSS1D
,NEWTON1D,NEWTON2D_C,NEWTON2D_D,NEWTON3D
,HYPO_ELAS3D,HYPO_ELAS2D_C,HYPO_ELAS2D_D,HYPO_ELAS1D
,MAXWELL1D,MAXWELL2D_C,MAXWELL2D_D,MAXWELL3D
,LOI_ADDITIVE_EN_SIGMA,LOI_DES_MELANGES_EN_SIGMA,LOI_CRITERE
,LOI_CONTRAINTES_PLANES,LOI_CONTRAINTES_PLANES_DOUBLE,LOI_DEFORMATIONS_PLANES
,HYSTERESIS_1D,HYSTERESIS_3D,HYSTERESIS_BULK,LOI_ISO_THERMO
,MOONEY_RIVLIN_1D,MOONEY_RIVLIN_3D,POLY_HYPER3D,HART_SMITH3D,MAHEO_HYPER
,HYPER_EXTERNE_W
,LOI_DE_TAIT,LOI_VIA_UMAT,LOI_VIA_UMAT_CP
,LOI_COULOMB
,LOI_RIEN1D,LOI_RIEN2D_D,LOI_RIEN2D_C,LOI_RIEN3D
,RIEN_COMP};
/// @} // end of group
/// @addtogroup Group_types_enumeres
/// @{
/// énuméré permettant de savoir si une loi est : 1D, 2D en deformations planes ou contraintes planes, 3D générale
enum Enum_comp_3D_CP_DP_1D { COMP_1D =1, COMP_CONTRAINTES_PLANES, COMP_DEFORMATIONS_PLANES, COMP_3D , RIEN_COMP_3D_CP_DP_1D};
/// @} // end of group
// ***** !!!! penser à changer *****
//****** nbmax_caractere_Enum_comp si nécessaire *****
const int nbmax_caractere_Enum_comp = 26;
// ----- 1) concernant Enum_comp ------
// Retourne le nom d'une loi de comportement a partir de son identificateur de
// type enumere id_comport correspondant
string Nom_comp(const Enum_comp id_comport);
// Retourne l'identificateur de type enumere associe au nom de la loi de
// comportement nom_comport
Enum_comp Id_nom_comp(const string& nom_comport);
// indique si la loi est inactive mécaniquement
// typiquement de type : LOI_RIEN... ou RIEN_COMP
bool Loi_rien(const Enum_comp id_comport);
// surcharge de l'operator de lecture
istream & operator >> (istream & entree, Enum_comp& a);
// surcharge de l'operator d'ecriture
ostream & operator << (ostream & sort, const Enum_comp& a);
// ----- 2) concernant Enum_comp_3D_CP_DP_1D -----
// Retourne le nom a partir de son identificateur du type enumere id_Enum_comp_3D_CP_DP_1D correspondant
string Nom_comp_3D_CP_DP_1D(const Enum_comp_3D_CP_DP_1D id_Enum_comp_3D_CP_DP_1D);
// Retourne l'identificateur de type enumere associe à un nom nom_comp_3D_CP_DP_1D
Enum_comp_3D_CP_DP_1D Id_nom_comp_3D_CP_DP_1D(const string nom_comp_3D_CP_DP_1D);
// indique le type Enum_comp_3D_CP_DP_1D correspondant à une loi de comportement
Enum_comp_3D_CP_DP_1D Comp_3D_CP_DP_1D(const Enum_comp id_comport);
// surcharge de l'operator de lecture
istream & operator >> (istream & entree, Enum_comp_3D_CP_DP_1D& a);
// surcharge de l'operator d'ecriture
ostream & operator << (ostream & sort, const Enum_comp_3D_CP_DP_1D& a);
#endif