Difference between revisions of "Contrib:KeesWouters/partition"

From CAELinuxWiki
Jump to: navigation, search
('''Defining a construction with four bodies in Salome''')
m (Download the files)
 
(118 intermediate revisions by 3 users not shown)
Line 1: Line 1:
=='''Defining a construction with four bodies in Salome'''==
+
* [[Contrib:KeesWouters]]<br/><br/>
 +
=='''Fuse, partition and compound of a structure'''==
 +
When you need to apply different material properties to different parts of a mesh created by Salome, you can make a compound of these parts. This has the feature that every ''compound'' can be meshed independently from others. The disadvantage might be the absence of interaction between the contact areas of each part. In the FE analysis by Code Aster this can be countered in various ways, eg. by applying ''contact'' conditions between the contact planes.
  
The construction consists of a shoe box, a plate on top of it and two cylinders inside the top plate. In total four different bodies are created by partitioning the main body. Each body can have different materials applied to it in the C-Aster command file.
+
When all parts need to be ''glued'' together at the contact areas, you can opt for a different approach: first ''fuse'' the parts and later on divide or ''partition'' the parts. Then in the resulting mesh the contact areas between adjacent parts share the same nodes. All the parts are connected together in this way.
 +
 
 +
Creating a ''compound'' in Salome is straight forward, just hit the ''compound'' button, enter a name for the compound and select the various parts you like to add in the compound.<br/>Creating a ''fuse'' and a ''partition'' are detailed below.
 +
 
 +
=='''Defining a construction with four bodies in Salome'''==
 +
The construction consists of a shoe box, a plate on top of it and two cylinders inside the top plate. In total four different bodies are created by partitioning the main body. For each body it is possible to set different material properties in the C-Aster command file.
  
 
[[Image:Kw_part400.jpg]]  * [[Image:Kw_part400t.jpg]]
 
[[Image:Kw_part400.jpg]]  * [[Image:Kw_part400t.jpg]]
 +
 +
=='''General definition of the construction with Salome'''==
 +
First a solid block is defined by the geompy.MakeBoxDXDYDZ(3,5,2). The internal block to cut away a apart of this block is defined by the four outside nodes. Four lines are linked between these nodes and a face is defined by the four lines. Extruding the face up to 1.8 mm high then defines a solid block. After the extrusion a '''shoe box''' remains. The wall thickness is 0.2 mm.
 +
 +
On top of this shoe box a top plate is defined. It outer dimensions are 0.2 mm less than the shoe box and height is 0.8 mm.
 +
 +
Inside the top plate two cylinders are defined, radii 0.7 and 0.5 and height 1.0 mm. These two cylinders consist of one solid only within Salome because they are defined at once using the two axial areas of the cylinders.
 +
 +
==='''Fusing the parts'''===
 +
Now all parts are defined and we can fuse the three parts together. This is necessary if we want a mesh that is 'glued' together between the various parts. So we fuse:
 +
* Fshoecyl  <-- shoebox and cylinders and use the result together with top plate
 +
* Fassembl <-- Fshoecyl and Btop
 +
 +
Now one solid part exists. To be able to apply different material properties to the various parts, we need to partition them.
 +
 +
==='''Partitioning the parts'''===
 +
In order to partition the parts we need to define the ''boundaries'' between the parts. For 3D components these are 2D entities, eg. planes.
 +
* We define a plane P12 that coincides with the top plane of the shoe box. It divides the shoebox on the one hand and the top plate and cylinders on the other hand. We generate a centre point, a vector in z direction and define a size for this plane: P12 = geompy.MakePlane('''centre_point, direction_vector, plane_size'''). Make sure that the size '''plane_size''' is large enough to cover the whole top plane of the shoe box. If this is not the case, Salome does not partition the bottom and top parts. If any part of the two pieces remain in contact, eg. because the dividing plane is too small, partition does not take place.
 +
* Between the cylinders and the top plate the areas of cylinders can be used as a boundary between these parts. Again, make sure that the height of the area is large enough to cover the cylinders, otherwise Salome does not generate the partitions.
 +
 +
: [[Image:kw_surface.jpg]]
 +
 +
The partition can be calculated by MakePartition. The first argument is the fused body (Fassembl), the second argument are the dividing planes determined above. It is possible to define multiple dividing planes, so the partition can be made in one go: <br/>
 +
: Partit=geompy.MakePartition([Fassembl],[P12,PCyl1,PCyl2],[],[],geompy.ShapeType["SOLID"],0,[],0)
 +
 +
Most of the work has been done. We still need to create the groups under the entity Partit by CreateGroup(), UnionIDs() and GetMainShape(). See the attached Python script at the end for more details.
 +
 +
==='''Partitioning within Salome GUI'''===
 +
In Salome GUI, assuming that the fuse and the three dividing planes P12, PCyl1 and PCyl2 are already created, proceed as follows to make the partitioning:
 +
* select ''Geometry'' module
 +
* Select ''Operations --> Partition'' from the main menu and right click
 +
* tick first partition posibility (thick red line to divide the square in the centre)
 +
* enter valid  name for result name of partition ('Partit' in this example)
 +
* in the ''partition'' part select: <br/>
 +
''objects'': the part (fuse) you like to partition (Fassemble)<br/>
 +
''tool object'': left click P12, control left click PCyl1 and PCyl2 to get 3_objects<br/>
 +
''reconstruction limit'': keep ''solid'' because we need solids (volumes) as results
 +
* ''apply and close''
 +
 +
Now the fuse Fassemble has been divided into its four solids. The four solids, however, are not yet available in the partition Partit. We need to create a group within the partition. So create the partitioned group:
 +
* from the main menu: ''New Entity --> Group --> Create'' and select
 +
* shape type: tick block, group name ''BPshoe'' by ''select all'', ''remove'' and ''add'' the appropriate volumes, ''apply'' and
 +
* repeat for remaining volumes BPtop, BPcyl1 and BPcyl2
 +
* ''apply and close''
 +
 +
==='''Result of the partitioning - grouping'''===
 +
In the object browser the following tree is now visible:
 +
[[Image:Kw_partit.png]]
 +
 +
Under the partition Partit the fuse Fassembl is given, together with the three dividing surfaces: P12, Pcyl1 and Pcyl2. The partitions BPshoe, BPtop, BPcyl1 and BPcyl2 are defined and available to be transfered to the mesh and to Code Aster. Different material properties can be given to them.
 +
 +
Note the now four partions are available, because the two cylinders are now separated by the partition operation.
 +
 +
Of course there are many ways to create the fuses and the partition. This is one way that works for me. Hope that this is useful for you as well. And, pls do not hesitate to add improvements here ;-)
 +
 +
=='''FE Analysis of the construction'''==
 +
In the Python script the geometry described above is given, together with a meshing part. Also adding the previously defined blocks are added as groups in the mesh. A CA command file for calculating the resonance frequencies of the free floating construction is given. All that needs to be done is export the mesh file, update the ASTK file and run C-Aster. <br/>
 +
 +
The material properties are not realistic.
 +
 +
'''Note'''<br/>Since the quantities in the command file are not ISO, but use {[mm], [N], [s] and [tonne]} the total mass of the construction is given in [tonne]. The value given in the output file is 2.7e-8 [tonne] = 27 [mg] (see next chapter).
 +
 +
=='''The lowest resonance modes'''==
 +
The first and second resonance frequencies at 37 and 44 kHz. The last picture of mode 3 also shows the mesh of the construction. <br/><br/>
 +
: [[Image:kw_kop4_mode1.png]]  :  [[Image:kw_kop4_mode2.png]] : [[Image:kw_kop4_mode3w.png]] <br/><br/>
 +
 +
=='''Download the files'''==
 +
 +
: [[Media:kw_kop.zip]]<br/>
 +
: [[Media:kw_kop_update_dec2012.zip]]
 +
 +
Update december 2012 has smaller mesh size and automatic saving of med-file by ''inspect'' module of Python (for my own convenience). Note that it does take longer run times, though mesh size can easily be adapted in the script.
 +
 +
The zip contains:
 +
* geom_meshx.py (Python file for generating geometry and mesh in Salome)
 +
* kop3.comm (Code Aster command file)
 +
* kop3.export and kop3.astk files (astk files)
 +
 +
: Hope this is useful.
 +
: june 2009 -
 +
: update december 2012 - Kees

Latest revision as of 20:53, 27 August 2013

Fuse, partition and compound of a structure

When you need to apply different material properties to different parts of a mesh created by Salome, you can make a compound of these parts. This has the feature that every compound can be meshed independently from others. The disadvantage might be the absence of interaction between the contact areas of each part. In the FE analysis by Code Aster this can be countered in various ways, eg. by applying contact conditions between the contact planes.

When all parts need to be glued together at the contact areas, you can opt for a different approach: first fuse the parts and later on divide or partition the parts. Then in the resulting mesh the contact areas between adjacent parts share the same nodes. All the parts are connected together in this way.

Creating a compound in Salome is straight forward, just hit the compound button, enter a name for the compound and select the various parts you like to add in the compound.
Creating a fuse and a partition are detailed below.

Defining a construction with four bodies in Salome

The construction consists of a shoe box, a plate on top of it and two cylinders inside the top plate. In total four different bodies are created by partitioning the main body. For each body it is possible to set different material properties in the C-Aster command file.

Kw part400.jpg * Kw part400t.jpg

General definition of the construction with Salome

First a solid block is defined by the geompy.MakeBoxDXDYDZ(3,5,2). The internal block to cut away a apart of this block is defined by the four outside nodes. Four lines are linked between these nodes and a face is defined by the four lines. Extruding the face up to 1.8 mm high then defines a solid block. After the extrusion a shoe box remains. The wall thickness is 0.2 mm.

On top of this shoe box a top plate is defined. It outer dimensions are 0.2 mm less than the shoe box and height is 0.8 mm.

Inside the top plate two cylinders are defined, radii 0.7 and 0.5 and height 1.0 mm. These two cylinders consist of one solid only within Salome because they are defined at once using the two axial areas of the cylinders.

Fusing the parts

Now all parts are defined and we can fuse the three parts together. This is necessary if we want a mesh that is 'glued' together between the various parts. So we fuse:

  • Fshoecyl <-- shoebox and cylinders and use the result together with top plate
  • Fassembl <-- Fshoecyl and Btop

Now one solid part exists. To be able to apply different material properties to the various parts, we need to partition them.

Partitioning the parts

In order to partition the parts we need to define the boundaries between the parts. For 3D components these are 2D entities, eg. planes.

  • We define a plane P12 that coincides with the top plane of the shoe box. It divides the shoebox on the one hand and the top plate and cylinders on the other hand. We generate a centre point, a vector in z direction and define a size for this plane: P12 = geompy.MakePlane(centre_point, direction_vector, plane_size). Make sure that the size plane_size is large enough to cover the whole top plane of the shoe box. If this is not the case, Salome does not partition the bottom and top parts. If any part of the two pieces remain in contact, eg. because the dividing plane is too small, partition does not take place.
  • Between the cylinders and the top plate the areas of cylinders can be used as a boundary between these parts. Again, make sure that the height of the area is large enough to cover the cylinders, otherwise Salome does not generate the partitions.
Kw surface.jpg

The partition can be calculated by MakePartition. The first argument is the fused body (Fassembl), the second argument are the dividing planes determined above. It is possible to define multiple dividing planes, so the partition can be made in one go:

Partit=geompy.MakePartition([Fassembl],[P12,PCyl1,PCyl2],[],[],geompy.ShapeType["SOLID"],0,[],0)

Most of the work has been done. We still need to create the groups under the entity Partit by CreateGroup(), UnionIDs() and GetMainShape(). See the attached Python script at the end for more details.

Partitioning within Salome GUI

In Salome GUI, assuming that the fuse and the three dividing planes P12, PCyl1 and PCyl2 are already created, proceed as follows to make the partitioning:

  • select Geometry module
  • Select Operations --> Partition from the main menu and right click
  • tick first partition posibility (thick red line to divide the square in the centre)
  • enter valid name for result name of partition ('Partit' in this example)
  • in the partition part select:

objects: the part (fuse) you like to partition (Fassemble)
tool object: left click P12, control left click PCyl1 and PCyl2 to get 3_objects
reconstruction limit: keep solid because we need solids (volumes) as results

  • apply and close

Now the fuse Fassemble has been divided into its four solids. The four solids, however, are not yet available in the partition Partit. We need to create a group within the partition. So create the partitioned group:

  • from the main menu: New Entity --> Group --> Create and select
  • shape type: tick block, group name BPshoe by select all, remove and add the appropriate volumes, apply and
  • repeat for remaining volumes BPtop, BPcyl1 and BPcyl2
  • apply and close

Result of the partitioning - grouping

In the object browser the following tree is now visible: Kw partit.png

Under the partition Partit the fuse Fassembl is given, together with the three dividing surfaces: P12, Pcyl1 and Pcyl2. The partitions BPshoe, BPtop, BPcyl1 and BPcyl2 are defined and available to be transfered to the mesh and to Code Aster. Different material properties can be given to them.

Note the now four partions are available, because the two cylinders are now separated by the partition operation.

Of course there are many ways to create the fuses and the partition. This is one way that works for me. Hope that this is useful for you as well. And, pls do not hesitate to add improvements here ;-)

FE Analysis of the construction

In the Python script the geometry described above is given, together with a meshing part. Also adding the previously defined blocks are added as groups in the mesh. A CA command file for calculating the resonance frequencies of the free floating construction is given. All that needs to be done is export the mesh file, update the ASTK file and run C-Aster.

The material properties are not realistic.

Note
Since the quantities in the command file are not ISO, but use {[mm], [N], [s] and [tonne]} the total mass of the construction is given in [tonne]. The value given in the output file is 2.7e-8 [tonne] = 27 [mg] (see next chapter).

The lowest resonance modes

The first and second resonance frequencies at 37 and 44 kHz. The last picture of mode 3 also shows the mesh of the construction.

Kw kop4 mode1.png  : Kw kop4 mode2.png : Kw kop4 mode3w.png

Download the files

Media:kw_kop.zip
Media:kw_kop_update_dec2012.zip

Update december 2012 has smaller mesh size and automatic saving of med-file by inspect module of Python (for my own convenience). Note that it does take longer run times, though mesh size can easily be adapted in the script.

The zip contains:

  • geom_meshx.py (Python file for generating geometry and mesh in Salome)
  • kop3.comm (Code Aster command file)
  • kop3.export and kop3.astk files (astk files)
Hope this is useful.
june 2009 -
update december 2012 - Kees