The present disclosure is directed, in general, to a topology optimization framework that is able to account for design-dependent load and boundary conditions. The technology described herein is particularly well-suited for, but not limited to, additive manufacturing and other similar fabrication methods.
Topology optimization has gained popularity recently in generating new designs, given its flexibility in generating freeform designs, which can potentially offer superior product performance and cost reduction. The advancement in additive manufacturing technology has also enabled the production of very complex shapes. Currently, most topology optimization solvers used for design often involve a single type of physics (structural analysis is the most common type), and also only involve simplified loads and boundary conditions (i.e., these conditions are not expected to change with the design). However, for the performance of a lot of products, other types of physics are often involved, such as heat transfer and fluid flow. For example, in aerodynamic components, the structure is often surrounded by a fluid that also exerts both structural (e.g., pressure load) and thermal loads (e.g., heat flux) to the structure. Therefore, in addition to mechanical performance requirements, the design needs to be able to account for the product's thermal performance (e.g., minimum thermal load, maximum allowable temperature constraint).
There are a number of challenges to extend topology optimization to more complex problems. For example, combustion engine applications often necessitate the inclusion of thermal analysis in topology optimization. However, this is not straightforward, as the optimization not only needs to account for the conduction of the internal structure of the object, but also convection of the solid to a surrounding fluid, which is dependent on the surface area of the solid. Moreover, this surface is constantly evolving with the optimization. In addition to heat transfer, the pressure load exerted on the structure by the fluid also depends on the surface area of the structure. This often requires the inclusion of computational fluid dynamics, in addition to structural and heat conduction analysis, to accurately account for the effect of the surrounding fluid with changing fluid-structure interface. However, it drastically increases the complexity and also computational cost to perform the optimization.
Other challenges include applying design boundary-dependent loads and boundary conditions in topology optimization. In many topology optimization problems, the boundary conditions are defined on the void-solid boundary of the domain. This boundary is often fuzzy, not well-defined and is expected to change during each iteration. Therefore, it is not straight-forward to apply these conditions as the shape of the design may change drastically from one iteration to the other. In terms of loading conditions, design-dependent loads add additional complexity to the problem. For example, in structural compliance minimization problems, centrifugal and thermal loads are often design dependent. The addition of material reduces the compliance by adding stiffness to the structure; at the same time, it also means more materials are present to withstand more centrifugal load and potentially also more thermal load, increasing the compliance further. Such complexity of conflicting load effects can add complexity to the problem and causes convergence issues.
Embodiments of the present invention address and overcome one or more of the above shortcomings and drawbacks, by providing methods, systems, and apparatuses related to topology optimization framework that is able to account for design-dependent load and boundary conditions.
According to some embodiments, a system includes a meshing module, one or more physics solvers, one or more sensitivity computation modules, and one or more optimizer modules. The meshing module generates a mesh of a design domain corresponding to an object to be manufactured. The physics solvers each generate physical field variables and objective values based on the mesh and boundary conditions specified on solid-void boundaries of the design domain. The sensitivity computation modules compute a sensitivity field based on the mesh and the physical field variables. The optimizer modules generate an updated design comprising new design variables by executing an optimization of the design domain based on the sensitivity field and the objective values. The physics solvers, the sensitivity computation modules, and the optimizer modules are iteratively executed until convergence to generate a final design based on the new design variables generated by the optimizer modules.
According to other embodiments, a method includes generating a mesh of a design domain and performing a design process over a plurality of iterations. The design process comprises the following elements. One or more physics solvers are used to generate one or more physical field variables and one or more objective values based on the mesh and one or more boundary conditions specified on solid-void boundaries of the design domain. One or more sensitivity computation modules are used to compute a sensitivity field based on the mesh and the physical field variables. One or more optimizer modules are used to generate an updated design comprising one or more new design variables by executing an optimization of the design domain based on the sensitivity field and the objective values. Following the design process, a final version of the updated design is presented.
In some embodiments, an article of manufacture for performing topology optimization comprises a non-transitory, tangible computer-readable medium holding computer-executable instructions for performing the aforementioned method.
Additional features and advantages of the invention will be made apparent from the following detailed description of illustrative embodiments that proceeds with reference to the accompanying drawings.
The foregoing and other aspects of the present invention are best understood from the following detailed description when read in connection with the accompanying drawings. For the purpose of illustrating the invention, there are shown in the drawings embodiments that are presently preferred, it being understood, however, that the invention is not limited to the specific instrumentalities disclosed. Included in the drawings are the following Figures:
Systems, methods, and apparatuses are described herein which relate generally to a framework for topology optimization that is able to account for design-dependent load and boundary conditions, for multi-physics applications. This framework is designed as a “plug-n-play” system that can be readily configured with different physics-based models to solve a variety of design problems. Thus, for example, the framework discussed herein may be used to perform topology optimization using a single type of physics model (e.g., structural only, thermal only, flow only) or a combination of physics models (e.g., structural-thermal, structural-flow, thermal-flow). Moreover, the framework can be readily adapted to support additional physics models (acoustics, electromagnetics, etc.) as needed to support design development.
Topology optimization typically determines the distribution of two material states/types (e.g., distribution of solid and void within a domain) within the defined design space. The topology optimization solver assumes a design variable of material definition that ranges from 0 to 1 (later referred as density factor). For different physics applications, this factor may have different definitions. Additionally, it will be used in the optimization algorithm to modify the design based on the computed sensitivity. For instance, in structural topology optimization, when the density factor value is 1, it means that particular region is solid (having material density and property of solid). If it is 0, it means that that region is void (having material density close to zero). Typical material properties include Young's modulus and thermal conductivity. For other problems, different material properties may be defined as a function of the design variable. For example, in conjugate heat transfer, design variable of 1 refers to solid material properties and design variable of 0 denotes fluid material properties. For the intermediate density factor values, the relationship between density factor and material properties will be interpolated by a material interpolation scheme chosen by the user (e.g., Solid Isotropic Material with Penalization, Rational Approximation of Material Properties). One typical objective of topology optimization problems is to minimize compliance, but this framework can also apply to other types of objectives, and also multiple numbers of objectives and constraints.
This approach can be applied to 2D or 3D topology optimization, that can handle requirements of different types of physics (e.g., structural and thermal), either single physics or multi-physics. It also allows the application of both design-dependent loads and boundary conditions. The framework discussed herein is flexible so that when different physics are included, the tool will automatically interpret the density factors for the different physics accordingly.
The Data Layer 105 handles analysis data used in performing topology optimization. In the example of
The Data Layer 105 is where topology optimization is triggered and iterated. The Data Layer 105 serves as the backbone to communicate with different analysis components (i.e., Solvers 110, Sensitivity Computation of Physics Modules 115, and Optimizers 120). For example, in some embodiments, the Data Layer 105 includes one or more application programming interfaces (APIs) that allow analysis components to access and update the analysis data. In network-based architectures, a Representational State Transfer (REST) design may be used to access and manipulate the analysis data at the Data Layer 105.
In some embodiments, the Data Layer 105 also includes utilities to automate operations on the mesh, boundary conditions, and analysis data. For example, when automatically detecting mesh regions, the design variable for the topology optimization domain can range from 0 to 1. For the clearance mesh regions (e.g., the region interfacing between moving and stationary components), the design variable is always 0, meaning no material is allowed to be added. Conversely, for the contact mesh region (e.g., region that is in contact with surrounding structures), the design variable is always 1, meaning there will always be material added at those regions.
The Solvers 110 include one or more physics solvers. Each solver obtains input data from the Data Layer 105, performs physics analysis (e.g., finite element analysis for structural, heat transfer, etc.), and provides the outputs of the analysis to the Data Layer 105.
The Sensitivity Computation of Physics Modules 115 uses one or more plug-ins to compute sensitivity of physics variables with respect to design variables. For different physics and objectives, different sensitivity computation modules may be used.
The Optimizers 120 use the objective values, the sensitivity field and the current design variables stored at the Data Layer 105, to compute new design variable fields. The specific optimizer(s) employed may be selected by the user for specific use cases.
The framework shown in
The framework shown in
As a pre-processing step, the initial boundary condition is defined. The initial setup comprises an initial design, with its associated boundary conditions (e.g., pressure, heat transfer coefficients) specified on its solid-void boundaries. Next, thresholding is applied to the density factor to identify boundaries. At each iteration, the entire design domain contains elements that have varying density factors. There are no clear design boundaries. Therefore, a density factor threshold (which can be specified by the user), is specified (e.g., 0.5). For elements with density factors larger than the threshold (e.g., ≥0.5), they will be regarded as solid. Elements with density factors lower that the threshold (e.g., <0.5) may be regarded as void.
During steps 305-335, as shown in
Starting at step 305, the boundary/loading conditions (e.g., flow pressure, heat transfer coefficients) in contact with design constraints are stored. The stored boundary/loading conditions are those that do not require flood-filling (e.g., boundary conditions in contact with surrounding structures). The design constraints may include, for example, e.g., clearance and contact regions of the design space. At step 310, the boundary/loading conditions are flood filled from initial design to design space external boundaries. Next, at step 315 the boundary/loading conditions are stored on the design space external boundaries. This saves the spatial variation of the boundary condition that is similar to the initial design.
The design is updated at step 320 based on the new boundary/loading conditions. At step 325, the boundary conditions (saved at step 315) are flood-filled onto the solid-void boundaries of the updated design, based on the threshold of density factor (i.e., do not flood-fill into region which density factor is larger than the threshold). Next, at step 330, the boundary/loading conditions that were stored at step 305 are applied back to the design. Other boundary/loading conditions may also be applied (e.g., centrifugal load. Then, at step 335, a physics simulation is used to compute field variables (e.g., temperature, displacement, etc.). Based on the results, sensitivity, new objective value(s) and convergence are computed. Steps 320-335 are repeated if convergence criteria were not met.
To illustrate how the spatial variation of the initial design was saved,
While flood-fill can potentially be a powerful approach to approximate boundary conditions on design-dependent boundary/loading conditions, it might not be robust through the topology optimization. Especially during the initial iterations of topology optimization the solid-void boundaries are not well defined yet. Pre-mature flood-fill can cause the boundary conditions to be mapped on these fuzzy boundaries, altering the solution and resulting in oscillation of the solution.
To improve the robustness and reduce the oscillation due to the flood-filling of the boundary/loading conditions, we applied a technique to slowly increase the density factor threshold during the optimization. It involves starting with a lower density factor threshold such that most elements are considered as solid at the beginning; and the boundary/loading conditions would not involve much. Then, gradually increase the density factor threshold to larger value once the design stabilizes (reached local convergence). This allows the holes (topology) to stabilize first based on boundary-independent load/boundary conditions before flood-filing these conditions into these holes.
This approach is outlined in the following steps. The user first initializes the following parameters: initial value of density factor threshold (e.g., 0.2), the maximum value of density factor threshold (e.g., 0.8), and the delta of density factor threshold (e.g., 0.1). This means that density factor threshold will increase from 0.2, 0.3, 0.4 . . . till it reaches 0.8, throughout the topology optimization. The, topology is performed over a plurality of iterations. For each iteration, if the change in objective (e.g., compliance) is within some user-defined convergence criteria (e.g., 1% of the initial value), and a predetermined number of iterations (e.g., 15) have passed since the previous threshold update, then the density factor threshold is increased by pre-determined delta (i.e. 0.1), until threshold is equal to a desired max threshold value (i.e. 0.8). This allows gradual increase in density factor threshold and a more stable solution with boundary-dependent loads/BCs.
As noted above, the other challenge related to design-dependent load and boundary conditions is the complication of having conflicting sensitivity involved in the objective function. For instance, in structural compliance minimization, with design-independent load, structural compliance can be reduced by adding material because the sensitivity of the compliance with respect to the design variable (density factor) is negative. In this context, the topology can be formulated as in
However, for certain design-dependent load (e.g., centrifugal loads and thermal loads), adding more material can increase structural compliance because adding more material will increase the material that is subjected to thermal load and centrifugal loads. As a result, sensitivity is formulated as shown in
Therefore, to improve the convergence of objective with conflicting sensitivities, a special material interpolation scheme may be utilized. First of all, instead of the typical solid isotropic material penalization scheme, the rational approximation of material properties (RAMP) method is being used. This has been demonstrated to be useful in improving convergence in problems with thermoelastic loads. In addition to using RAMP for material interpolation, some embodiments utilize an approach to improve convergence by gradually increasing the RAMP penalization factor to reduce the amount of intermediate density factor values in final design. This reduces oscillatory behavior of the solution to improve the convergence of the final design.
The topology optimization framework disclosed herein provides various benefits over conventional solutions. For example, the flood-filling of boundary-dependent loads and boundary conditions results in significant saving of computational cost and complexity. Additionally, the disclosed framework provides the ability to include multiple physics solvers to be included in topology optimization, enabling designing for more complex problems. Moreover, the framework allows users to select different optimizers suitable for different problems irrespective of the physic solver used, resulting in more design flexibility and potential time savings during execution. Time savings are also realized by the improved convergence of the disclosed framework, which ensures that less time is required to achieve a final design.
Parallel portions of a deep learning application may be executed on the architecture 700 as “device kernels” or simply “kernels.” A kernel comprises parameterized code configured to perform a particular function. The parallel computing platform is configured to execute these kernels in an optimal manner across the architecture 700 based on parameters, settings, and other selections provided by the user. Additionally, in some embodiments, the parallel computing platform may include additional functionality to allow for automatic processing of kernels in an optimal manner with minimal input provided by the user.
The processing required for each kernel is performed by a grid of thread blocks (described in greater detail below). Using concurrent kernel execution, streams, and synchronization with lightweight events, the architecture 700 of
The device 710 includes one or more thread blocks 730 which represent the computation unit of the device 710. The term thread block refers to a group of threads that can cooperate via shared memory and synchronize their execution to coordinate memory accesses. For example, in
Continuing with reference to
Each thread can have one or more levels of memory access. For example, in the architecture 700 of
The embodiments of the present disclosure may be implemented with any combination of hardware and software. For example, aside from parallel processing architecture presented in
Unless stated otherwise as apparent from the following discussion, it will be appreciated that terms such as “applying,” “generating,” “identifying,” “determining,” “processing,” “computing,” “selecting,” or the like may refer to the actions and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (e.g., electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices. Embodiments of the methods described herein may be implemented using computer software. If written in a programming language conforming to a recognized standard, sequences of instructions designed to implement the methods can be compiled for execution on a variety of hardware platforms and for interface to a variety of operating systems. In addition, embodiments of the present invention are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement embodiments of the present invention.
An executable application, as used herein, comprises code or machine readable instructions for conditioning the processor to implement predetermined functions, such as those of an operating system, a context data acquisition system or other information processing system, for example, in response to user command or input. An executable procedure is a segment of code or machine readable instruction, sub-routine, or other distinct section of code or portion of an executable application for performing one or more particular processes. These processes may include receiving input data and/or parameters, performing operations on received input data and/or performing functions in response to received input parameters, and providing resulting output data and/or parameters.
A “graphical user interface” (GUI), as used herein, comprises one or more display images, generated by a display processor and enabling user interaction with a processor or other device and associated data acquisition and processing functions. The GUI also includes an executable procedure or executable application. The executable procedure or executable application conditions the display processor to generate signals representing the GUI display images. These signals are supplied to a display device which displays the image for viewing by the user. The processor, under control of an executable procedure or executable application, manipulates the GUI display images in response to signals received from the input devices. In this way, the user may interact with the display image using the input devices, enabling user interaction with the processor or other device.
The functions and process steps herein may be performed automatically or wholly or partially in response to user command. An activity (including a step) performed automatically is performed in response to one or more executable instructions or device operation without user direct initiation of the activity.
The system and processes of the figures are not exclusive. Other systems, processes and menus may be derived in accordance with the principles of the invention to accomplish the same objectives. Although this invention has been described with reference to particular embodiments, it is to be understood that the embodiments and variations shown and described herein are for illustration purposes only. Modifications to the current design may be implemented by those skilled in the art, without departing from the scope of the invention. As described herein, the various systems, subsystems, agents, managers and processes can be implemented using hardware components, software components, and/or combinations thereof. No claim element herein is to be construed under the provisions of 35 U.S.C. 112(f) unless the element is expressly recited using the phrase “means for”.
This application is the US National Stage of International Application No. PCT/US2019/022010 filed 13 Mar. 2019, and claims the benefit thereof. The International Application claims the benefit of U.S. Provisional Application No. U.S. 62/643,778 filed 16 Mar. 2018. All of the applications are incorporated by reference herein in their entirety.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2019/022010 | 3/13/2019 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62643778 | Mar 2018 | US |