- Update
matrix_utils
dependency
- Add
CachingLCA
class which saves supply vector calculations
- Allow
MethodConfig
as an input toMultiLCA
- Add
MethodConfig
to__init__.py
for better UX
- Fix #108:
MultiLCA
normalizes and weights in all combinations
- Bump dependencies as upstream has breaking changes
- Fix #105:
MultiLCA
class returning identical results under iteration
- #101: Convert
technosphere_matrix
tocsr
when usingpypardiso
for speed boost on repeated calculations. - #104: Explicitly set array-size in MultiLCA's
lci_calculation()
. Solves bug with a single functional unit passed toMultiLCA
.
The new MultiLCA
implementation support efficient calculation of multiple functional units, impact categories, normalizations, and weightings, and supports advanced features of bw_processign
datapackages across the complete calculation chain, including scenarios and correlated uncertainty. It also adds usability improvements compared to previous implementations.
To perform a MultiLCA
, you first need to define your configuration. There is a pydantic
validator MethodConfig
to make sure it is constructed correctly; see its docs for more info.
Here is an example MultiLCA
calculation in action:
import bw2data as bd
import bw2io as bi
# All the LCI and LCIA data exist in the current project
functional_units = {
"γ": {bd.get_node(name="foo").id: 1},
"ε": {bd.get_node(name="bar").id: 2},
"ζ": {bd.get_node(name="baz").id: 3},
}
config = {
"impact_categories": [
("first", "categ."),
("second", "categ."),
],
"normalizations": {
("am I normal?",): [
("first", "categ."),
("second", "categ."),
]
},
"weightings": {("heavy", "weight"): [("am I normal?",)]},
}
data_objs = bd.get_multilca_data_objs(functional_units=functional_units, method_config=config)
mlca = MultiLCA(demands=functional_units, method_config=config, data_objs=data_objs)
mlca.lci()
mlca.lcia()
mlca.normalize()
mlca.weight()
mlca.scores
>>> {
(("heavy", "weight"), ("am I normal?",), ('first', 'categ.'), 'γ'): 190.31896453011996,
(("heavy", "weight"), ("am I normal?",), ('first', 'categ.'), 'ε'): 42.504568745060126,
(("heavy", "weight"), ("am I normal?",), ('first', 'categ.'), 'ζ'): 431.9104810103497,
(("heavy", "weight"), ("am I normal?",), ('second', 'categ.'), 'γ'): 1205.2506281852936,
(("heavy", "weight"), ("am I normal?",), ('second', 'categ.'), 'ε'): 269.17264029471556,
(("heavy", "weight"), ("am I normal?",), ('second', 'categ.'), 'ζ'): 5614.00396766416
}
One big change compared to previous implementations is the labelling of matrices and results, which is used across the MultiLCA
class.
The MultiLCA
class can be used for both static and Monte Carlo calculations. You can configure which types of uncertainty to use where with selective_use
. See the MultiLCA
class docs for more information.
Here is an example of a selective use config. In this case, assuming use_distributions=False
was passed to the MultiLCA
constructor, on the characterization and weighting matrices would draw from the probability distribution information provided.
{
"characterization_matrix": {"use_distributions": True},
"weighting_matrix": {"use_distributions": True},
}
Gotcha: In MultiLCA
, you need to use the selective use flags characterization_matrix
, normalization_matrix
, and weighting_matrix
, even though all three of these are dictionaries, and called characterization_matrices
, normalization_matrices
, and weighting_matrices
. This is because selective use flags can also be used in the base LCA
class, and use the same code. The flags apply to all impact categories, normalizations, and weightings; You would need to write a custom subclass to turn on certain forms of uncertainty only for selected impact categories.
Result matrices (characterized_inventories
, normalized_inventories
, weighted_inventories
) are all dictionaries, with each combination of functional unit and impact category/normalization/weighting possible as described in the MethodConfig
. The values in this dictionary are sparse matrices with the same dimensions as the inventory
, namely biosphere flows (rows) by processes (columns).
- Removed graph traversal completely - use bw_graph_tools instead.
- Migrate from
fs
tofsspec
- Start using
@
for matrix multiplication - Removed
MonteCarloLCA
(normal LCA class can do Monte Carlo) and addedIterativeLCA
(different solving strategy) - Fix miscellaneous deprecated API calls
- Fix #78: Allow for selective use of distributions or arrays depending on matrix label
- Fix #77: Prevent multiple
remap_inventory_dicts
calls - Fix #71: Poor error message when no LCIA data is supplied
- Documentation improvements
- Switch packaging to
pyproject.toml
Never happened, can't prove anything :)
- Packaging updates
- CI workflow updates
- Merge #65: Add PyPI and conda-forge badge
- Fix hidden dependency on
bw2data
- Add some backwards compatiblity methods
- Merged PR #63 Multifunctional graph traversal
- Changed
GraphTraversal
toAssumedDiagonalGraphTraversal
.GraphTraversal
still exists as a proxy but raises aDeprecationWarning
- Add
LCA.to_dataframe
, based on work by Ben Portner
- #61 wrap_functional_unit missing from multi_lca.py
- MultiLCA is useable again
- Add
LCA.keep_first_iteration
to make iteration simpler
- Add an optional warning on LCA instantiation if excluding resources (arrays or distributions) which could be useful
- Add function stubs to be used by subclasses on iteration
- Fix a bug in
switch_method
if given abw2data
method tuuple instead of a list of datapackages.
- Add
invert_technosphere_matrix
with algo from @haasad - Fix
switch_method
,switch_normalization
,switch_weighting
Compatibility changes:
LCA.score
will return weighted or normalized score, if weighting or normalization has been performedLCA.weighting
will now trigger a deprecation warning. Switch to.weight
instead.LCA.redo_lci
deprecated in favor ofLCA.lci(demand)
;LCA.redo_lcia
deprecated in favor ofLCA.lcia(demand)
- Fix for constructing characterization matrices with semi-regionalized impact categories
- More 2.5 work and fixes
Version 2.0 brings a number of large changes, while maintaining backwards compatibility (except for dropping Py2). The net result of these changes is to prepare for a future where data management is separated from calculations, and where working with large, complicated models is much easier.
Before 2.0 is released, the following features will be added:
- Presamples will be adapted to use
bw_processing
- Logging will be taken seriously :)
LCA results to dataframes
The structure of this library has been simplified, as the LCA
class can now perform static, stochastic (Monte Carlo), iterative (scenario-based), and single-matrix LCA calculations. Matrix building has been moved to the matrix_utils library.
Removing the Python 2 compatibility layer allows for much cleaner and more compact code, and the use of some components from the in-development Brightway version 3 libraries. Compatible with bw2data
version 4.0.
LCA.rebuild_*_matrix
methods are removed. See the TODO notebook for alternatives.DirectSolvingMixin
andDirectSolvingMonteCarloLCA
are removed, direct solving is now the defaultComparativeMonteCarlo
is removed, useMultiLCA(use_distributions=True)
insteadSingleMatrixLCA
is remove, useLCA
instead. It allows for empty biosphere matrices.
Mapping dictionaries map the database identifiers to row and column indices. In 2.5, these mapping dictionaries are only created on demand; avoiding their creation saves a bit of time and memory.
Added a new class (DictionaryManager
) and made it simpler reverse, remap, and get the original dictionaries inside an LCA
. Here is an example:
LCA.dicts.biosphere[x]
>> y
LCA.dicts.biosphere.original # if remapped with activity keys
LCA.dicts.biosphere.reversed[y] # (generated on demand)
>> x
The dictionaries in a conventional LCA are:
- LCA.dicts.product
- LCA.dicts.activity
- LCA.dicts.biosphere
.LCA.reverse_dict
is removed; all reversed dictionaries are available at LCA.dicts.{name}.reversed
In 2.5, these mapping dictionaries are not automatically "remapped" to the (database name, activity code)
keys. You will need to call .remap_inventory_dicts()
after doing an inventory calculation to get mapping dictionaries in this format.
It is easier to have everything in the same mode of operation. This also allows for the use of arrays, distributions, interfaces, etc. in weighting. Implemented in new SingleValueDiagonalMatrix
class.
We now use bw_processing to load processed arrays. bw_processing
has separate files for the technosphere and biosphere arrays, and explicit indication of . Therefore, the TechnosphereBiosphereMatrixBuilder
is no longer necessary, and is removed.
bw2data
is now an optional install, and even if available only a single utility function is used to prepare input data. bw2calc
is primarily intended to be used as an independent library.
The existing input specification is still there, but this release also adds the ability to specify input arguments compatible with Brightway version 3. Previously, we would write LCA({some demand}, method=foo)
- this requires bw2calc
to use bw2data
to figure out the dependent databases of the functional unit in some demand
, and then to get the file paths of all the necessary files for both the inventory and impact assessment. The new syntax is LCA({some demand}, data_objs)
, where some demand
is already integer IDs, and data_objects
is a lists of data packages (either in memory or on the filesystem).
bw2data
has a helper function to prepare arguments in the new syntax: prepare_lca_inputs
.
This new input syntax, with consistent column labels for all structured arrays, removes the need for IndependentLCAMixin
. This is deleted, and the methods get_vector
, get_vector_metadata
, and set_vector
are added.
More tests were identified, and undefined behaviour is now specified. For example, the previous matrix builders assumed that the values in the provided row or column dictionaries were sequential integers starting from zero - this assumption is now relaxed, and we allow this dictionary values to start with an offset. There are also tests and documentation on what happens under various cases when drop_missing
is False
, but missing values are present.
- Replace
.todense
with.toarray
to satisfy changes in Scipy API - Add
atol
parameter to iterative solver to satisfy changes in Scipy API - Fix regression in 1.7.7 which raises errors when no new
demand
was present (PR #6)
- Add check to make sure not all arrays are empty during matrix construction
- Allow numpy loading pickled data
Switch lca.demand
when running .redo_lci
or .redo_lcia
. Thanks Aleksandra Kim!
Fixed #25: Sort array filepaths when loading. Thanks Pedro Anchieta!
Merged Pull Request #4 to directly pass Numpy or byte arrays instead of filepaths. Thanks Jan Machacek!
- Improved support for independent LCA calculations (i.e. without Brightway2 databases, only processed arrays)
- Added ability to calculate LCAs in a single matrix (for BONSAI)
Updated Monte Carlo for upstream presamples changes
Merged Pull Request #3 to fix some attributes in graph traversals. Thanks Bernhard Steubing!
Compatibility with presamples
release version
Add compatibility with bw_presamples
Really fix bug in seed generation for pooled Monte Carlo calculations
- JOSS submission
- Fix bug in MultiMonteCarlo
- Add some logging to support presamples in the future
Fix license text
Simplify indexing
Replace bw2speedups
indexing with numpy array trickiness which is ~5 times faster
Remove non-ascii characters from license text, because setuptools
- Restructure imports to not depend on
bw2data
- Use
io.open
insetup.py
Specify encoding of license file
Bugfix for broken import statement
Merge pull request from Adrian Haas to enable Pardiso solver usage when available.
- Added utility functions for
load_calculation_package
andsave_calculation_package
for independent LCAs and cloud computing. - Compatibility with
bw2data
2.3
Fixed bugs where RNG and technosphere matrix builder would change values in arrays meant to be static
Fix bugs and add tests for ParameterVectorLCA
Changed ParameterVectorLCA
: Can no longer be called, split off rebuild_all
into a separate method, added tests.
Better test coverage and Windows comaptibility
- FEATURE: Add class and mixin for Monte Carlo using direct solvers
- CHANGE: Move tests to root directory and add Monte Carlo tests
- CHANGE: Consistent use of
__next__
andnext()
so that all Monte Carlo iterator classes are Py2/3 compatible and programmed the same way.ParameterVectorLCA.next()
will no longer work on Python 3; instead, callnext(ParameterVectorLCA)
. When providing a new vector, call the class itself (after it is instantiated):pv = ParameterVectorLCA(args); pv(new_vector)
.
- CHANGE:Updates for bw2data 2.2
- BUGFIX: Correctly handle regionalized CFs in site-generic calculations
- FEATURE: Add contribution methods to LCA classes
BUGFIX: Correctly handle project names in multiprocess calculations
BUGFIX: switch_*
was seriously broken due to new handling of processed arrays filepaths
- Feature: Py3 compatibility
- FEATURE: Independent LCAs which don't rely on bw2data and the brightway2 ecosystem
- Feature: Add
DenseLCA
- FEATURE: Added
switch_*
andto_dataframe
methods to LCA class - FEATURE: Allow graph traversal to skip links in static databases
- BUGFIX: Terminate multiprocessing pools after calculations
- CHANGE: Load data automatically in Monte Carlo
- CHANGE: Automatically clean dirty databases before starting calculations
Plus lots of small bugfixes, and compatibility with projects
.
CHANGE: Split activities and products
BUGFIX: Don't require substitution in TYPE_DICTIONARY
.
- FEATURE: Properly handle
substitution
type exchanges - CHANGE: Compatible with bw2data version 2
- BUGFIX: Fix handling of nested dependent databases
- CHANGE: Better documentation for most code.
- BUGFIX: Graph traversal handles most coproducts, and raises sensible errors when it can't.
FEATURE: Changes in MatrixBuilder should make normal static LCA calculations about three times faster.
Update dependencies.
BREAKING CHANGE: Use Database.filename
for processed data. Requires update to bw2data version 0.16 or greater.
- BREAKING CHANGE: LCA.fix_dictionaries now sets/uses
_mapped_dict
to determine iffix_dictionaries
has been called. - BUGFIX: LCA.build_demand_array doesn't break if
fix_dictionaries
has been called.
BREAKING CHANGE: Matrix builder will only include parameter array rows that are correctly mapped, instead of raising an error when unmapped rows occur. This behaviour can be turned off by passing drop_missing=False
.
BUGFIX: Change column names in method matrix building to be consistent with bw2data
0.11
- BREAKING CHANGE: Graph traversal was reworked, and some functionality for interpreting the output was moved to
bw2analyzer
. - BREAKING CHANGE: Deleted
SimpleRegionalizedLCA
class. Regionalization will be provided in bw2regional. - BREAKING CHANGE: Deleted initial sensitivity work, moved for now to branch, as it was not yet usable.
- FEATURE: Much better and more thorough documentation.
- FEATURE: Improved testing and test coverage