1 #@ MODIF sd_ligrel SD DATE 10/07/2007 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.
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.
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 # ======================================================================
23 class sd_ligrel(AsBase):
26 LGRF = AsVK8(lonmax=1, docu=Parmi('ACOU', 'MECA', 'THER'), )
27 NBNO = AsVI(lonmax=1,)
30 # AU_MOINS_UN : LIEL, SSSA
31 # LIEL : il existe des éléments finis
32 # SSSA : il existe des sous-structures statiques
33 LIEL = Facultatif(AsColl( acces='NU', stockage='CONTIG', modelong='VARIABLE', type='I', ))
34 SSSA = Facultatif(AsVI())
35 # ENSEMBLE : LIEL, REPE
36 REPE = Facultatif(AsVI())
38 # si mailles tardives :
39 NEMA = Facultatif(AsColl( acces='NU', stockage='CONTIG', modelong='VARIABLE', type='I', ))
41 PRNS = Facultatif(AsVI())
42 LGNS = Facultatif(AsVI())
46 # retourne True si la SD semble exister.
47 return self.LGRF.exists
50 def check_presence(self,checker):
51 if not self.exists() : return
52 exi_liel=self.LIEL.exists
53 exi_sssa=self.SSSA.exists
54 exi_repe=self.REPE.exists
55 exi_nema=self.NEMA.exists
56 exi_prns=self.PRNS.exists
57 exi_lgns=self.LGNS.exists
59 # AU_MOINS_UN : .LIEL, .SSSA
60 assert exi_liel or exi_sssa
62 # SI .LIEL AU_MOINS_UN : .REPE, .NEMA
64 assert exi_repe or exi_nema
67 if exi_repe : assert exi_liel
70 if exi_nema : assert exi_liel
72 # noeuds tardifs => .PRNS .LGNS et .NEMA
73 nb_no_tard= self.NBNO.get()[0]
78 assert self.LGNS.lonmax >= nb_no_tard # .LGNS est surdimensionné
79 nbec= self.PRNS.lonmax / nb_no_tard
80 assert self.PRNS.lonmax == nb_no_tard * nbec , (nbec, nb_no_tard)
81 assert nbec >= 1 and nbec < 10 , nbec