Salome HOME
05e38d86d4e5d23399db9f25238a8f5172bf9637
[tools/eficas.git] / Aster / Cata / cataSTA9 / SD / sd_modele.py
1 #@ MODIF sd_modele SD  DATE 06/05/2008   AUTEUR PELLET J.PELLET 
2 # -*- coding: iso-8859-1 -*-
3 #            CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2007  EDF R&D                  WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
9 # (AT YOUR OPTION) ANY LATER VERSION.
10 #
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
15 #
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
18 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
19 # ======================================================================
20
21 from SD import *
22
23 from SD.sd_ligrel    import sd_ligrel
24 from SD.sd_maillage  import sd_maillage
25 from SD.sd_prof_chno import sd_prof_chno
26 from SD.sd_carte     import sd_carte
27 from SD.sd_xfem      import sd_modele_xfem
28 from SD.sd_l_table   import sd_l_table
29
30
31
32 class sd_modele(AsBase):
33 #-----------------------------
34     nomj = SDNom(fin=8)
35
36     MODELE = sd_ligrel()
37     NOEUD = Facultatif(AsVI())
38     MAILLE = Facultatif(AsVI())
39
40     # une sd_modele peut avoir une "sd_l_table" contenant des grandeurs caractéristiques de l'étude :
41     lt = Facultatif(sd_l_table(SDNom(nomj='')))
42
43     # Si le modèle vient de MODI_MODELE_XFEM :
44     xfem = Facultatif(sd_modele_xfem(SDNom(nomj='')))
45
46
47     def check_existence(self,checker) :
48         exi_liel=self.MODELE.LIEL.exists
49         exi_maille=self.MAILLE.exists
50         exi_noeud=self.NOEUD.exists
51
52         # si .LIEL => .MAILLE et .NOEUD
53         if exi_liel :
54             assert exi_maille
55             assert exi_noeud
56
57
58     def check_maillage(self,checker) :
59         # on est obligé de checker le maillage pour permettre la creation de la sd_voisinage
60         lgrf=self.MODELE.LGRF.get_stripped()
61         sd2 = sd_maillage(lgrf[0]); sd2.check(checker)
62