HOME

TheInfoList



OR:

OpenMDAO is an open-source high-performance computing platform for systems analysis and multidisciplinary optimization written in the
Python Python may refer to: Snakes * Pythonidae, a family of nonvenomous snakes found in Africa, Asia, and Australia ** ''Python'' (genus), a genus of Pythonidae found in Africa and Asia * Python (mythology), a mythical serpent Computing * Python (pro ...
programming language. The OpenMDAO project is primarily focused on supporting gradient based optimization with analytic derivatives to allow you to explore large design spaces with hundreds or thousands of design variables, but the framework also has a number of parallel computing features that can work with gradient-free optimization, mixed-integer nonlinear programming, and traditional design space exploration. The OpenMDAO framework is designed to aid in linking together separate pieces of software for the purpose of combined analyses. It allows users to combine analysis tools (or design codes) from multiple disciplines, at multiple levels of fidelity, and to manage the interaction between them. OpenMDAO is specifically designed to manage the dataflow (the actual data) and the workflow (what code is run when) in conjunction with optimization algorithms and other advanced solution techniques. J. S. Gray, J. T. Hwang, J. R. R. A. Martins, K. T. Moore, and B. A. Naylor
OpenMDAO: An open- source framework for multidisciplinary design, analysis, and optimization.
Structural and Multidisciplinary Optimization, 2019
doi:10.1007/s00158-019-02211-z.
/ref> The development of OpenMDAO is led out of the
NASA Glenn Research Center NASA John H. Glenn Research Center at Lewis Field is a NASA center within the cities of Brook Park and Cleveland between Cleveland Hopkins International Airport and the Rocky River Reservation of Cleveland Metroparks, with a subsidiary facilit ...
.


Features

* Library of built-in solvers and optimizers * Tools for
metamodeling A metamodel or surrogate model is a model of a model, and metamodeling is the process of generating such metamodels. Thus metamodeling or meta-modeling is the analysis, construction and development of the frames, rules, constraints, models and ...
* Data recording capabilities * Support for analytic derivatives * Support for high-performance computer clusters and
distributed computing A distributed system is a system whose components are located on different computer network, networked computers, which communicate and coordinate their actions by message passing, passing messages to one another from any system. Distributed com ...
* Extensible plugin library


Applications

NASA The National Aeronautics and Space Administration (NASA ) is an independent agency of the US federal government responsible for the civil space program, aeronautics research, and space research. NASA was established in 1958, succeeding t ...
’s motivation in supporting the OpenMDAO project stems from the demands of unconventional aircraft concepts like Turbo-Electric
distributed propulsion In aeronautics, Distributed propulsion is an arrangement in which the propulsive and related air flows are distributed over the aerodynamic surfaces of an aircraft. The purpose is to improve the craft's aerodynamic, propulsive and/or structural ...
. Although NASA’s focus is on analyzing aerospace applications, the framework itself is general and is not specific to any discipline.


Framework structure

OpenMDAO is designed to separate the flow of information (dataflow) from the process in which analyses are executed (workflow). It does that by using four specific constructs: Component, Assembly, Driver, and Workflow. The construction of system models begins with wrapping (or writing from scratch) various analysis codes as Components. A group of components is linked together inside an Assembly, specifying the dataflow between them. Once the dataflow is in place, one can select specific Drivers (optimizers, solvers, design of experiments, etc.) and set up a Workflow to determine exactly how the problem should be solved. OpenMDAO also includes a web-browser-based graphical user interface (GUI) for visual construction, execution, and optimization of models.


See also

*
ModelCenter ModelCenter, developed by Phoenix Integration, is a software package that aids in the design and optimization of systems. It enables users to conduct trade studies, as well as optimize designs. It interfaces with other popular modeling tools, in ...
*
Simulink Simulink is a MATLAB-based graphical programming environment for modeling, simulating and analyzing multidomain dynamical systems. Its primary interface is a graphical block diagramming tool and a customizable set of block libraries. It offers t ...
*
Multidisciplinary design optimization Multi-disciplinary design optimization (MDO) is a field of engineering that uses optimization methods to solve design problems incorporating a number of disciplines. It is also known as multidisciplinary system design optimization (MSDO), and Multi ...


External links

*


Notes

{{reflist Mathematical optimization software Free software programmed in Python Cross-platform software Software using the Apache license