Description
Active subspaces are part of an emerging set of tools for discovering low-dimensional structure in a given function of several variables. Interesting applications arise in deterministic computer simulations of complex physical systems, where the function is the map from the physical model's input parameters to its output quantity of interest. The active subspace is the span of particular directions in the input parameter space; perturbing the inputs along these active directions changes the output more, on average, than perturbing the inputs orthogonally to the active directions. By focusing on the model's response along active directions and ignoring the relatively inactive directions, we reduce the dimension for parameter studies---such as optimization and integration---that are essential to engineering tasks such as design and uncertainty quantification.
This library contains Python tools for discovering and exploiting a given model's active subspace. The user may provide a function handle to a complex model or its gradient with respect to the input parameters. Alternatively, the user may provide a set of input/output pairs from a previously executed set of runs (e.g., a Monte Carlo or Latin hypercube study). Essential classes and methods are documented; see documentation below. We also provide a set of Jupyter notebooks that demonstrate how to apply the code to a given model.
To see active subspace in action on real science and engineering applications, see the Active Subspaces Data Sets repository, which contains several Jupyter notebooks applying the methods to study input/output relationships in complex models.
Testing
We are using Travis CI for continuous integration testing. You can check out the current status here.
To run tests locally:
> python test.py
Requirements and Dependencies
- numpy
- scipy, >= 0.15.0
- matplotlib
- Gurobi is an optional dependency. The same functionality is accomplished with SciPy's optimize package, albeit less accurately (particularly in the quadratic programs).
If you wish to use Gurobi, you will need to install it separately by following the instructions contained in their quick-start guides for Windows, Linux, or Mac. To test your installation of Gurobi, start a python interpreter and execute the command import gurobipy
. If there is no import exception, the active subspaces library will be able to use Gurobi.
We had some initial trouble getting the Gurobi Python interface working with Enthought Python; Gurobi formally supports as subset of Python distributions, and Enthought is not one of them. However, we were able to get the interface working by following instructions in this thread.
Installation
To install the active subspaces package, open the terminal/command line and clone the repository with the command
git clone https://github.com/paulcon/active_subspaces.git
Navigate into the active_subspaces
folder (where the setup.py
file is located) and run the command
python setup.py install
You should now be able to import the active subspaces library in Python scripts and interpreters with the command import active_subspaces
.
This method was tested on Windows 7 Professional, and Ubuntu 14.04 LTS, and Mac OSX El Capitan with the Enthought Python distribution (Python 2.7.11, NumPy 1.10.4, SciPy 0.17.0, and matplotlib 1.5.1).
Usage
For detailed examples of usage and results, see the Jupyter notebooks contained in the tutorials
directory, the [active subspaces website]
(http://activesubspaces.org/applications/), and the Active Subspaces Data Sets repo.
The core class is the Subspaces class contained in the subspaces.py
file. An instance of this class can compute the active subspace with a variety of methods that take either an array of gradients or input/output pairs. It contains the estimated eigenvalues (and bootstrap ranges), subspace errors (and bootstrap ranges), eigenvalues, and an array of the eigenvectors defining the active subspace. The utils/plotters.py
file contains functions to plot these quantities and produce summary plots that show model output against the first 1 or 2 active variables. The utils/response_surfaces.py
file contains classes for polynomial and radial-basis approximations that can be trained with input/output pairs. Both classes can predict the value and gradient at input points and have a coefficient of determination (R-squared) value that measures goodness-of-fit. The integrals.py
and optimizers.py
files contain functions for integrating and optimizing functions of the active variables; these rely on classes from the domains.py
file.
Documentation
Documentation can be found on ReadTheDocs.
Community Guidelines
To contribute to this project, please follow these steps. Thanks to Marco Tezzele for providing this helpful template.
Submitting a patch
- Open a new issue describing the bug to fix or feature to add. Even if you think it's relatively minor, it's helpful to know what people are working on.
- Follow the normal process of forking the project, and set up a new branch to work in. It's important that each group of changes be done in separate branches to ensure that a pull request only includes the commits related to that bug or feature.
- Significant changes should be accompanied by tests. The project already has good test coverage, so look at some of the existing tests if you're unsure how to go about it.
- Push the commits to your fork and submit a pull request. Please, remember to rebase properly in order to maintain a clean, linear git history.
If you have questions or feedback, contact Paul Constantine.
Acknowledgments
This material is based upon work supported by the U.S. Department of Energy Office of Science, Office of Advanced Scientific Computing Research, Applied Mathematics program under Award Number DE-SC-0011077.