]> SALOME platform Git repositories - tools/eficas.git/blob - Aster/Cata/cataSTA10/SD/sd_macr_elem_dyna.py
Salome HOME
Modif V6_4_°
[tools/eficas.git] / Aster / Cata / cataSTA10 / SD / sd_macr_elem_dyna.py
1 #@ MODIF sd_macr_elem_dyna SD  DATE 22/09/2008   AUTEUR ANDRIAM H.ANDRIAMBOLOLONA 
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 from SD.sd_util import *
23 from SD.sd_nume_ddl_gd import sd_nume_ddl_gd
24
25
26 class sd_macr_elem_dyna_m(AsBase):
27 #----------------------------------
28     nomj = SDNom(fin=18)
29     DESC = AsVI   (SDNom(nomj='_DESC'),lonmax=3)
30     REFE = AsVK24 (SDNom(nomj='_REFE'),lonmax=2)
31     VALE = AsObject (SDNom(nomj='_VALE'),type=Parmi('C','R',),) 
32
33     def check_macr_elem_dyna_m_1(self,checker):
34         vale=self.VALE.get()
35         if not vale : return  # si Facultatif()
36
37         sdu_tous_compris(self.DESC,checker,vmin=1)
38         nbdef=self.DESC.get()[1]
39         sdu_compare(self.VALE,checker,len(vale),'==',(nbdef*(nbdef+1))/2,'LONMAX(VALE)')
40
41
42 class sd_macr_elem_dyna(AsBase):
43 #-------------------------------
44     nomj = SDNom(fin=8)
45
46     # description géométrique et topolique :
47     DESM = AsVI(lonmax=10)
48     REFM = AsVK8()
49     LINO = AsVI()
50     CONX = Facultatif(AsVI())
51
52     # rigidité, masse, amortissement condensés :
53     nume     = sd_nume_ddl_gd(SDNom(nomj=''))
54
55     MAEL_RAID = sd_macr_elem_dyna_m()
56     MAEL_MASS = sd_macr_elem_dyna_m()
57     MAEL_AMOR = Facultatif(sd_macr_elem_dyna_m())
58
59     MAEL_INER_VALE = AsVR()
60     MAEL_INER_REFE = AsVK24(lonmax=2, )
61
62     MAEL_DESC      = AsVI(lonmax=3, )
63     MAEL_REFE      = AsVK24(lonmax=2, )
64
65
66
67     def check_macr_elem_dyna_1(self,checker):
68         nbdef=self.MAEL_MASS.DESC.get()[1]
69         sdu_compare(self.MAEL_INER_VALE, checker,len(self.MAEL_INER_VALE.get()),'==',3*nbdef,'LONMAX(MAEL_INER_VALE)')
70