Contrib:KeesWouters/prestressmodal
Contents
Modal analysis of a cylinder under prestress
under construction .... not finished yet
To start with, this contribution mainly focuses on the use of Salome and Code Aster, not on the results and the mechanical justifications of the code that has been used. So no guarantee that the results will be correct up to the fifth decimal place, which they are not. I do hope though that this information is useful. For me it has been, because I had to think about some commands and look through the documentation and learn from that. In case of mistakes, errors and the like, please notify me, or better, you are invited to correct them yourself. Enjoy.
As usual, the files that define the geometry, mesh and command files can be found at the end of this contribution.
Defining the properties of the cylinder
Geometry of the cylinder
The mdoel is constructed by extrusion cq piping from a circle with diameter 4 mm. The extrusion is defined along a path along the z axis, defined by six points *). The main commands of the python script are:
- define points: pz1 = geompy.MakeVertex(0.00, 0, 1)
- define circle: Circle = geompy.MakeCircle(centre, vector, radius)
- define path: Curve = geompy.MakePolyline([null, pz1, pz2, pz3, pz4, pz5 ])
- define cylinder: Pipe = geompy.MakePipe(Circle, Curve)
*) I used six points to do some experiments with the Pipe command. Of course, here is not necessary to use six points.
For applying boundary conditions and loads and use the shell elements later in the command file of Code Aster, we define the top and bottom circumference of the cylinder and the cylinder area:
- Surfin = geompy.CreateGroup(Pipe, geompy.ShapeType["FACE"])
- geompy.UnionIDs(Surfin, [25, 20, 15, 10, 3])
- Pipe = geompy.GetMainShape(Surfin)
- Ctop = geompy.CreateGroup(Pipe, geompy.ShapeType["EDGE"])
- geompy.UnionIDs(Ctop, [29])
- Pipe = geompy.GetMainShape(Ctop)
- Cbot = geompy.CreateGroup(Pipe, geompy.ShapeType["EDGE"])
- geompy.UnionIDs(Cbot, [8])
- Pipe = geompy.GetMainShape(Cbot)
The mesh of the cylinder
The mesh is define in a python script. It is generated by NetGen 1D_2D. By allowing quadrangles, a regular mesh with only this type of elements occur. Further options are: maxsize is 0.075, optimise, fineness is 3 and use second order, that is needed for coque_3d elements. Note the these quadratic quadrangles (quad8) need to be adapted to quad9 elements to be compatible with coque_elements in the command file.
The names of the axial end of the circumference and shell area of the cylinder are denoted by Cbot, Ctop and Surfin.
The load and boundary conditions of the cylinder
The load and boundary conditions are defined in the Code Aster command file. The boundary conditions are at Ctop:
- restrict displacements and rotations dx=dy=dz=drx=dry=drz=0 -->
- DDL_IMPO=(_F(GROUP_MA=('Cbot'),DX=0.0,DY=0.0,DZ=0.0,DRX=0.0,...),...
- restrict displacements and rotations dx=dy=drx=dry=drz=0 except dz -->
- DDL_IMPO=(...._F(GROUP_MA=('Ctop'),DX=0.0,DY=0.0,DRX=0.0,...),...
The load on the construction is an axial line force, total force is 7399.515 N -->
- dcyl = 4.00 # diameter of cylinder
- pie = math.pi
- Lcyl = pie*dcyl # circumference of the cylinder
- Fax = 7399.515
- Fclamp=AFFE_CHAR_MECA(...,FORCE_ARETE=_F(GROUP_MA='Ctop',FZ=+Fax/Lcyl,),);
Material properties of the beam
The beam consists of steel.
- steel=DEFI_MATERIAU(ELAS=_F(E=2.100e5,NU=0.28,RHO=0.007850),);
General procedure during the solution process
We will compare the modal behaviour of the unloaded and loaded cylinder. For the unloaded cylinder the standard modal analysis will be performed:
- determine stiffness matrix Smech and
- determine mass matrix Mmass
- carry out a modal analysis (Smech + lambda*Mmass)x = 0
For the pre stressed cylinder a modified modal analysis will be performed. The stiffness matrix is now given by the sum of the element stiffness matrix and geometrical stiffness matrix: Stiff = [Smech + Sgeom]:
- determine stiffness matrix Smech
- determine geometrical stiffness matrix Sgeom
- determine mass matrix Mmass
- carry out a modal analysis ([Smech + Sgeom] + lambda*Mmass)x = 0
Determining the geometrical stiffness matrix is exactly the same as in a buckling analysis. Details for the calculating the geometrical stiffness matrix can be found here: buckling analysis.
Modal analysis of the unloaded structure
Commands for modal analysis of the unloaded structure
The element stiffness matrix can be calculated by the following commands:
Maybe for testing the results, the static analysis can be carried out, though it is not really needed here.
- optional: perform static analysis [MECA_STATIQUE]
- determine stiffness matrix Smech [CALC_MATR_ELEM]
- determine mass matrix Mmass [CALC_MATR_ELEM]
Then, for the eigenvector calculation, the stiffness and mass matrices need to be correctly ordered according to the dofs (ddl) of the system, so
- determine ordering nddl [NUME_DDL]
- determine ordered SAmech [ASSE_MATRICE] and
- determine ordered SAmass [ASSE_MATRICE]
- perform eigenvalue analysis on SAmech and SAmass [MODE_ITER_SIMULT]
- project the results [PROJ_CHAMP] suitable for post processing in Salome (coque_3d --> quad8)
# for testing only
result=MECA_STATIQUE(MODELE=modelc,CHAM_MATER=matprops,
                    CARA_ELEM=shellch,EXCIT=_F(CHARGE=clamp,),);
# determine stiffness matrix of the structure and DDL vector
Smech = CALC_MATR_ELEM(OPTION = 'RIGI_MECA',
                                 MODELE = modelc,
                                 CARA_ELEM=shellch,
                                 CHARGE = clamp,
                                 CHAM_MATER = matprops,);
Mmass = CALC_MATR_ELEM(OPTION = 'MASS_MECA',
                                 MODELE = modelc,
                                 CHAM_MATER = matprops,
                                 CARA_ELEM = shellch,
                                 CHARGE = clamp,);
nddl = NUME_DDL(MATR_RIGI=Smech); SAmech = ASSE_MATRICE(NUME_DDL=nddl,MATR_ELEM=Smech,); MAmass = ASSE_MATRICE(NUME_DDL=nddl,MATR_ELEM=Mmass,);
Rmodes=MODE_ITER_SIMULT(MATR_A=SAmech,
                        MATR_B=MAmass,
                        TYPE_RESU='DYNAMIQUE',
                        METHODE='SORENSEN',
                        CALC_FREQ=_F(OPTION='PLUS_PETITE',NMAX_FREQ=6,),);
SALmodes=PROJ_CHAMP(RESULTAT=Rmodes,
                    MODELE_1=modelc,
                    MODELE_2=modinit,);
IMPR_RESU(FORMAT='MED',UNITE=21,
          RESU=_F(MAILLAGE=meshinit,
          RESULTAT=SALmodes,
          NOM_CHAM='DEPL',),);
Numerical values of the eigenvalues of the unloaded structure
The eigenvalues can be obtained from the mess file. For the unloaded case, the six smallest eigenvalues are:
   NUMERO    FREQUENCE (HZ)    NORME D'ERREUR
        1      9.57306E+01       3.17056E-11
        2      9.57306E+01       3.14144E-11
        3      1.13379E+02       2.33041E-11
        4      1.13379E+02       2.30014E-11
        5      1.22476E+02       2.36309E-11
        6      1.22476E+02       1.96973E-11
NORME D'ERREUR MOYENNE:  0.25459E-10
The first modal shape of the unloaded structure
The picture below denote the first modal shape at 95 Hz at different view points.



