FEM Shear of a Composite Block/ru

Введение
В этом уроке мы анализируем деформацию сдвига композитного блока, состоящего из жесткого ядра, встроенного в мягкую матрицу. Он демонстрирует использование BooleanFragments и CompoundFilter для создания твердых тел для блока и матрицы из двух концентрических кубов. Этот рабочий процесс гарантирует, что для блока и окружающей матрицы могут быть определены отдельные MeshRegions, материалы и граничные условия. Чтобы выбрать внутренние регионы, мы используем макроса Маркуса Говорка (https://github.com/drhooves/SelectionTools). Результаты CalculiX ясно показывают влияние жесткого ядра на реакцию композитного блока.

Геометрия
Сначала мы создаем два концентрических куба, один размер 10 мм, а другой размер 5 мм. Это сделано в верстаке "Part". По умолчанию куб размещается в начале координат [0, 0, 0], поэтому меньший куб необходимо уменьшить и сместить, изменив настройки на вкладке «Данные» панели свойств. Чтобы сделать ядро ​​видимым, прозрачность внешнего блока установлена ​​на 50 на вкладке «Вид» панели свойств. Результат показан ниже.



Затем выделите два блока в дереве и создайте объект BooleanFragments (Деталь → Разделить → Boolean Fragments). В Окне свойств, на вкладке Данные, измените Mode на CompSolid. Теперь выделите BooleanFragments в дереве объектов и создайте CompoundFilter (Деталь → Соединить → Фильтр соединений).



Mesh и Mesh Regions
В верстаке FEM мы создаем контейнер анализа. Он будет содержать все определения, необходимые для анализа через CalculiX и его результатов. Обратите внимание, что этот контейнер анализа необходимо активировать (щелкните правой кнопкой мыши и выберите «Активировать анализ») каждый раз при повторной загрузке файла или после переключения обратно с других анализов. Чтобы начать процесс создания сетки, выделите CompoundFilter в дереве объектов и активируйте диалоговое окно создания сетки «Mesh → Сетка МКЭ из фигуры генерируемая построителем Gmsh». Выйдите из диалогового окна, нажав ОК.

Теперь в дереве объектов создан объект Mesh. Выделите этот объект и создайте объект Mesh Region через «Mesh → Область сетки МКЭ». Откройте диалоговое окно для этой Mesh Region, дважды щелкнув и отметив переключатель для Твердотельный объект. Затем нажмите кнопку «Добавить ссылку» и выберите объект CompoundFilter в графическом окне. Это должно добавить ссылку на «CompoundFilter: Solid1» в список объектов области сетки. Наконец, укажите максимальный размер элемента для этой области (5 мм в текущем анализе). Выйдите из диалогового окна, нажав ОК.



Затем создайте новый объект Mesh, как указано выше, и используйте макрос выделения (быстрые клавиши S, E), чтобы выбрать объект Cube_Core в графическом окне. На этот раз в списке ссылок должно быть указано «CompoundFilter: Solid2», как показано ниже. Мы выбрали максимальный размер элемента 1 мм.

Примечание1: для выбора «CompoundFilter: Solid2» необходимо выбрать одну из его граней.

Примечание 2. Если у вас возникли трудности с выделением «CompoundFilter: Solid2», это может быть связано с тем, что вы забыли установить для режима BooleanFragments значение CompSolid.



Назначение материала
Материал назначается областям сетки МКЭ через объект SolidMaterial. В этом уроке мы назначаем два материала; один для матрицы и один для ядра.

Start by selecting the CompoundFilter in the object tree. Then create a SolidMaterial object via menu option "Model → FEM material for solid". Open the dialog and tick the radio button for Solid, press "Add Reference" and select the CompoundFilter object from the Graphical Window. The reference list should now show "CompoundFilter:Solid1", as before. We assign ABS material to the Matrix, with a Young's modules approximately 1% that of steel.



Repeat the above procedure for the Core ("CompoundFilter:Solid2") with the help of the selection macro. This time we assign CalculiX-Steel, which is much stiffer than the ABS material for the Matrix.

Sliding Support
To create a "Simple Shear" condition for the composite block the deformations at the boundaries need to be unconstrained. To achieve this, the block is placed on a sliding support. This leaves three degrees of freedom in the plane of the support (2 translations and a rotation) and those will be constrained later. (Note: as the plane prevents warping of the face, it still induces a minor constraint, which could be eliminated by a different choice of boundary conditions). To create a sliding boundary condition add a FemConstraintDisplacement object (Model → Mechanical Constraints → Constraint displacement). With the dialog box open first select the face to which the boundary conditions is to be applied and then click the Add button. As the block is allowed to slide in the x-y plane, only the "Fixed" radio button for "Displacement z" is selected and the other radio buttons are all left as "Free".



Fixed Nodes
To prevent rigid body motion in the plane of sliding, three independent degrees of freedom need to be eliminated. To achieve this, one vertex in the plane of sliding is constrained in x and y direction (eliminating 2 degrees of freedom) and one vertex is fixed in the x direction (eliminating the last degree of freedom). For this purpose two additional FemConstraintDisplacement objects are created and the result is shown below.



Shear Forces
The final step in the Analysis definition is the application of loads. To create a Simple Shear condition, a set of shear loads is applied as shown below. Each load is chosen as 1000 N and considering the directions of application, force and moment equilibrium is achieved for all translation and rotional degrees of freedom. In FC this requires addition of four FemConstraintForce objects (Model → Mechanical Constraints → Constraint force) - one for each face. With the dialog box open first press the Add Reference button and then select the face to which the boundary condition is to be applied (Note: this is a different sequence than with FemConstraintDisplacement). By default, this creates a set of forces perpendicular to the face (i.e. a normal force). To change this to a shear force, press the direction button and select a cube edge that runs in the desired direction. If the resulting force points in opposite direction of what is required, then select the radio button for "Reverse direction".



CalculiX Analysis
Now all mesh regions, material and boundary conditions have been defined we are ready to analyse the deformation of the block with CalculiX. Activate the Analysis by right clicking "Activate analysis", open the CalculiX dialog by double clicking the CalculiXccxTools object and select a directory for the temporary files created by both FC and CCX. Write CCX Input file and check for any warning or error messages.



After that the analysis can be started by pressing the RunCalculiX button. If all goes well, the CCX output window should show the following messages.



CalculiX Results
Upon completion of the analysis double click the "CalculiX_static_results" object and select the "Abs displacement" option. The maximum displacement of ~ 0.08mm will show up in the relevant output box. As the maximum displacement is relatively small compared to the dimensions of the block (<1% of the block size), the displacements need to be scaled up. This can be done under the heading "Displacement" by ticking the "Show" radio button and scaling the displacement by a factor of -say- 20. The maximum displacement will now be exaggerated to approximately 20% of the box size. After closing the dialog window, the deformed mesh can be made visible again by highlighting the Result_mesh object and pressing the space bar.



To investigate the deformation of the core we have to slice the block. This can be done by creating a clip filter. To activate this functionality, we first need to create a "post processing pipeline" by highlighting the "CalculiX_static_results" object and choosing "Results → Post Pipeline from Result" from the menu. Next, with the Pipeline selected create a Warp Filter (Results → Warp filter), set Vector=Displacement and Value=20 to scale the displacement and Display Mode = "Surface with Edges", Coloring Field = "Displacement", Vector = "Magnitude" to show colored displacement contours. Press Apply and OK. As a final step add a Clip Filter (Results → Clip filter) and create a plane with origin [5.0,2.5,5.0] and normal [0,1,0], i.e. at a core face with normal in the y-direction. Tick the "Cut Cells" radio button to create a flat surface. As before set Display Mode = "Surface with Edges", Coloring Field = "Displacement", Vector = "Magnitude" to show colored displacement contours. Press Apply and OK. Finally switch the Warp Filter to invisible to only show the cut block.



From the result it is clear that the core remains largely undeformed and helps to resist the deformation of the soft matrix (compare the shear angle of the blue colored part to that of the green colored part). What it also highlights though is that under Simple Shear conditions the faces of the composite block do warp, implying that the sliding boundary condition at the base of the cube does provide an undue constraint.

Further work
The following challenges may be interesting to take up as a further exercise:

1) Correct for the undue constraint imposed by the sliding boundary condition

2) Try and create contact boundary conditions between the core and the matrix to see if separation occurs

The FC file for this tutorial is attached below as a starting point.

https://forum.freecadweb.org/viewtopic.php?f=18&t=26517&start=20

Повеселись !