TRUST 1.9.8
HPC thermohydraulic platform
Loading...
Searching...
No Matches
Terme_Source_Solide_SWIFT_VDF.h
1/****************************************************************************
2* Copyright (c) 2024, CEA
3* All rights reserved.
4*
5* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
6* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
7* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
8* 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
9*
10* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
11* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
12* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
13*
14*****************************************************************************/
15
16#ifndef Terme_Source_Solide_SWIFT_VDF_included
17#define Terme_Source_Solide_SWIFT_VDF_included
18
19/*! @brief class Terme_Source_Solide_SWIFT_VDF Cette classe permet le forcage d'un champ moyen de temperature
20 *
21 * d'un solide issu d'un calcul SWIFT vers le champ moyen du calcul
22 * LES grossier correspondant.
23 *
24 *
25 */
26#include <Source_base.h>
27#include <TRUST_Ref.h>
28
29
30class Probleme_base;
31class Conduction;
32
34{
35 Declare_instanciable(Terme_Source_Solide_SWIFT_VDF);
36
37public :
38 DoubleTab& calculer(DoubleTab& ) const override;
39 void init_calcul_moyenne(const Conduction& my_eqn, DoubleVect& Y, IntVect& corresp, IntVect& compt);
40 void calcul_moyenne(const Conduction& my_eqn, DoubleVect& T_moy, const IntVect& corresp, const IntVect& compt) const;
42 void mettre_a_jour(double temps) override { }
43
44 void associer_pb(const Probleme_base& ) override;
45 void associer_domaines(const Domaine_dis_base& ,const Domaine_Cl_dis_base& ) override;
46
47 inline void dimensionner_blocs(matrices_t matrices, const tabs_t& semi_impl) const override {}
48 void ajouter_blocs(matrices_t matrices, DoubleTab& secmem, const tabs_t& semi_impl) const override;
49 inline int has_interface_blocs() const override
50 {
51 return 1;
52 };
53
54protected :
59
60 double tau = -123.; // tau est la constante de temps du forcage.
61
62 DoubleVect Y_swift; // Coordonnees des points ou est definie la temperature dans le solide
63 DoubleVect Y_corse; // ou doit etre fait le forcage.
64
65 IntVect compt_swift; // Nombre de points a meme Y.
66 IntVect compt_corse;
67
68 IntVect corresp_swift; // Correspondance numerotation globale -> numerotation locale dans Y.
70 IntVect corresp_SC;
71
72};
73#endif
Classe Conduction Cette classe represente l'equation d'evolution.
Definition Conduction.h:41
classe Domaine_Cl_dis_base Les objets Domaine_Cl_dis_base representent les conditions aux limites
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.
classe Probleme_base C'est un Probleme_U qui n'est pas un couplage.
classe Source_base Un objet Source_base est un terme apparaissant au second membre d'une
Definition Source_base.h:42
void calcul_moyenne(const Conduction &my_eqn, DoubleVect &T_moy, const IntVect &corresp, const IntVect &compt) const
DoubleTab & calculer(DoubleTab &) const override
void mettre_a_jour(double temps) override
DOES NOTHING - to override in derived classes.
OBS_PTR(Conduction) eq_swift
OBS_PTR(Probleme_base) pb_corse
OBS_PTR(Conduction) eq_corse
void init_calcul_moyenne(const Conduction &my_eqn, DoubleVect &Y, IntVect &corresp, IntVect &compt)
void dimensionner_blocs(matrices_t matrices, const tabs_t &semi_impl) const override
OBS_PTR(Probleme_base) pb_swift
void ajouter_blocs(matrices_t matrices, DoubleTab &secmem, const tabs_t &semi_impl) const override
void associer_domaines(const Domaine_dis_base &, const Domaine_Cl_dis_base &) override
void associer_pb(const Probleme_base &) override