With the Advanced User Settings the optimisation parameters can be influenced even further than the options Strut Density and Shape Quality. Furthermore, a few unsupported options are available using the Advanced User Settings like Restart, Usage usage of a Startspaceand activate automatic Non-Design Growthduring the optimisationaminimum Thickness.
The Advanced User Settings can be added to a Scenario by right clicking on this and selecting the option as shown in the picture below.
...
The appearing text field can be used to add Advanced User Commands to the current Generative Design Scenario.
Restart, Usage of a Start Space & Influencing the
...
number of iterations
To influence the Strut Density optimisation parameterseven further, changes of the number of iterations , Event Safety Coefficient and number of resolution levels can be made. These settings overwrite the selection of the Strut Densityand the Shape Quality as they are only default settings for the ones described here. The table gives an overview of the default settings:
Input Commands | Explanation |
---|---|
schedule.level.0.iterationCount = |
8 schedule.level.1.iterationCount = |
8 schedule.level.2.iterationCount = |
8 schedule.level.3.iterationCount = |
Specify how many iterations are calculated at which resolution level. Note that convergence should be achieved at each level.
Default settings medium: 19, 20, 20, 5
Default settings sparse: 15, 40, 4, 5
Default settings dense: 9, 10, 40, 5
8 schedule.level.4.iterationCount = 17 schedule.level. |
5. |
iterationCount = |
schedule.level.2.eventSafetyCoefficient = 0.9
schedule.level.3.eventSafetyCoefficient = 1
Scaling factor for all events' safety factor.
Default settings medium: 0.3, 0.4, 0.9, 1
Default settings sparse: 0.6, 0.9, 0.95, 1
Default settings dense: 0.1, 0.25, 0.5, 115 | Specify how many iterations are calculated at which resolution level. |
The software uses four six resolution levels from coarse to fine (level 0: coarse - level 35: fine). The number behind the level indicates the number of iterations calculated on this resolution level. To remove or skip a resolution level the value can be set to 0. Moreover, the Event Safety Coefficient for each resolution level can be changed. This coefficient is a scaling factor for the safety factor. More information about the safety factor, stress, failure criteria and resolution here.
To set up these additional parameters, the Input Commands (left side of the table) need to be added to the optimisation model in the Advanced User Settings Text Fieldtext field. In the picture below an example is shown. By adding these Advanced User Settings, the first (coarse) resolution level will be skipped and the optimisation starts directly at the second level. You might want to add more iterations to the remaining levels to give the optimisation the chance to reduce the material accordingly and reach a convergence in each level. Especially level 2 can use more iterations in this case.
...
Restart (Start Space)
With the Advanced User Settings a Restart is possible. A Start Space needs to be chosen with which the optimisation will re/start.
...
A Start Space can be marked as a Non-Design Space, thus the Start Space cannot be removed during the optimisation and will be part of the final design. Therefore, the following command need to be added as well:
geometry.StartCandidate.path = StartCandidate.stl |
...
All areas applied with a boundary condition are automatically Interfaces. With an Interface the surface will grow a little bit beyond the Design Space boundaries to ensure a trouble-free and clean intersection. It is also possible to detect all Non-Design Space surfaces which are at the same time Design Space limits and let them grow automatically. This option results in a different connection between the Design Space and the Non-Design Spaces/Interfaces. Both results can be viewed here.
If the connection of the automatic Non-Design Growth is preferred, it can be activated with the following command:
...
configuration.autodetection.positiveNonDesignDirection = true
Sometimes this can lead to issues which are described here.
...
Soft Symmetry
The soft symmetry is activated per default. It influences the design generation so that the part is symmetric in all three dimensions if they were symmetric in the respective dimension to begin with. This is achieved for geometrical symmetrical design spaces even without symmetric LBCs and the hard symmetry constraint.
...
This governs how far the optimization value of two symmetric elements is allowed to differ while still being considered equivalent. In theory any value works: the higher the value the more zealously the algorithm will try to keep Soft Symmetry, possibly degrading the quality of the produced geometry compared to a non-symmetric one. The default value is 1e-41.
Attempt Soft Symmetry:
Whether or not Soft Symmetry is attempted at all can be (de)activated here.
...
Specifies how many asymmetric voxels elements are sufficient for the "dynamic" setting of attemptSoftSymmetry to turn off soft symmetry. Values between 0 and 1 are allowed, where the number represents the proportion of voxels.
The default settings can be changed with the following commands:
configuration.equivalenceDelta = 1e- |
---|
1 configuration.attemptSoftSymmetry = dynamic configuration.softSymmetryThreshold = 0.3 |
---|
Overhang Angle - Support Reduction
By default an overhang surface is determined if the angle falls below 45° in relation to the baseplate. This angle can be changed with the following command:
45° | schedule.prefabricated.wallAngle=45° |
Minimum Thickness (Experimental Function):
Minimum thickness of a wall, strut or rib and in general all other resulting shapes. Specified in world units (the default is meters!).
configuration.minThickness= 0.002 |
---|
Frequency Optimisation
By default the first 10 eigenmodes are considered to an upper frequency limit of 3 times the frequency target. This can be modified with the following commands:
event.Event_2.frequencyMax=4500 event.Event_2.frequencyCount=10 |
If the Frequency Constraint is higher than the first calculated Eigenfrequency of the whole Design Space in the first Iteration, this can lead to the case that no material will be reduced. This can be resolved by reducing the Frequency Constraint or by entering the following command to the Advanced User Settings:
schedule.iterations.~.operator.optloop_loop_analysis_Event-2_extractLocalFailures.useMetricGoalFactor=1 |
It has been found that comparable heavy point masses can cause that the optimisation does not achieve the Frequency Constraint. To address this the impact value can be set up to a value greater than 1. This can be done with the following Advanced User Settings command:
event.Event_2.impact=1.5 |
Info |
---|
Event_2 has to be replaced with the name of the frequency event. |
RBE2 (rigid connector) can be used as a connection type for a Point Mass, but the RBE2 connection won’t be considered in a static load case. This can occur if a Point Mass is added in combination with acceleration.
pointMass.PointMassInertia_Point_Mass_1.type=RBE2 |
You might also be interested in these tutorials:
...