Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/msrocka/autoprox
generates bridge processes in openLCA
https://github.com/msrocka/autoprox
life-cycle-assessment openlca tooling
Last synced: about 2 months ago
JSON representation
generates bridge processes in openLCA
- Host: GitHub
- URL: https://github.com/msrocka/autoprox
- Owner: msrocka
- License: mit
- Created: 2019-11-12T15:16:15.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2019-11-14T07:22:44.000Z (about 5 years ago)
- Last Synced: 2024-06-11T16:19:56.963Z (8 months ago)
- Topics: life-cycle-assessment, openlca, tooling
- Language: Kotlin
- Homepage:
- Size: 146 KB
- Stars: 2
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# autoprox
`autoprox` automatically generates bridge processes as described in
[Ingwersen et al. 2018](https://www.ncbi.nlm.nih.gov/pmc/articles/PMC6463304/)
directly in [openLCA](https://github.com/GreenDelta/olca-app).
For a process `p` in a database with a set of background processes `Q`,
`autoprox` generates a set of bridge processes `B` that connect the product
inputs and waste outputs of `p` with corresponding product outputs and waste
inputs provided by the processes in `Q`. This is done by a
[Generator](src/main/kotlin/autoprox/Generator.kt) that takes the ID of the
process `p` and [Matcher](src/main/kotlin/autoprox/Matcher.kt) `M` as input.
For a product input or waste output `fp` of `p` that does not yet have a
provider process in `Q`, the matcher `M` generates a set of flow-score pairs
for the product outputs and waste inputs `fq` with a provider process in `Q`:```
M: fp -> {(fq, sq) | fq in Q, sq in [0, 1]}
```The generator selects then the top matching flows of `fq` with the following
rule where `epsilon` can be configured:```
abs(1.0 - (sq_i / max(sq))) <= epsilon
```A bridge process `b` is then generated that has a corresponding exchange for
each of these matching product outputs or waste inputs. The quantitative
reference of `b` is set to one unit of `fp` and the amount of a matching flow
`fq_i` is set to:```
sq_i^2 / (sum(sq) * max(sq))
```Only flows are currently selected that have the same reference flow property
as `fp` so that every amount in `b` has the same unit. The name of `b` is
set to the name of the reference flow with a `_bridge:` prefix and all processes
of `B` are stored in the `_bridge` category so that it is easy to identify
(and delete) them:![](images/the_bridge_category.png)
For `p`, it should be then possible to create a product system that uses the
generated bridge processes `B` to connect `p` with `Q`:![](images/product_system_of_p.png)
## Implemented matchers
### The `BigramsDiceMatcher`
This matcher extracts the [bigrams](https://en.wikipedia.org/wiki/Bigram) from
the words of the names of the flows that are compared and computes the
[Sørensen–Dice coefficient](https://en.wikipedia.org/wiki/S%C3%B8rensen%E2%80%93Dice_coefficient)
of these sets of bigrams. It is fast and simple and gives good results for
flow names that are relatively specific:![](images/asphalt_dice.png)
However, flow names in LCA names often contain terms like `at plant` or
`production mix` that will lead to imprecise results using this matcher
without a filter:![](images/concrete_dice.png)
### The `InfoContentMatcher`
The `InfoContentMatcher` computes the information content `I(w)` of a word `w`
as:```
I(w) = |w| * e^(-alpha * freq(w))
````|w|` is the number of characters of `w` and `freq(w)` the absolute frequency of
`w` in the flow names of `fq`. With this, long words that are less frequent get
a higher weight than terms like `at plant` when calculating the similarity
between two flow names. This fixes the `concrete` example above:![](images/concrete_info.png)
However, words that have a high information content can describe completely
different things:![](images/shaker_screen_info.png)
### The `WordNetPathMatcher`
This matcher calculates the similarities between flow names based on the
information content of the contained words as described above and a semantic
similarity score that is calculated as the path distance between two words
in [WordNet](https://wordnet.princeton.edu). It uses the
[WS4j](https://code.google.com/archive/p/ws4j) API to calculate this
distance. The WordNet database that comes with WS4j is maybe a bit
outdated. Also, technical terms that are common in LCA databases are often not
present in WordNet. This is why this matcher currently does not give much
better results than the `InfoContentMatcher`. However, combining lexical
matching, corpus statistics, and semantic similarities could in principal
give good results (see e.g. [this paper](https://arxiv.org/pdf/1802.05667.pdf)).## Running / building from source
The easiest way to run this project is to load it into a current version
of [IntelliJ IDEA](https://www.jetbrains.com/idea/) (e.g. the open source
community version). Adopt the process ID of `p` and the databases path
in the [main function](src/main/kotlin/autoprox/Main.kt) and run it. In order
to use the `WordNetPathMatcher` you need to setup the WS4j database as described
below.### WS4j
WS4j is an archived Google Code project and a bit complicated to set up (see
below) and is compatible with a relative old version of WordNet. An alternative
could be [JWI](http://projects.csail.mit.edu/jwi/) which supports to load
a current WordNet database from a folder (just download and extract the
[WordNet database files](http://wordnetcode.princeton.edu/3.0/WNdb-3.0.tar.gz)
to that folder):```kotlin
val wordNetPath = "C:/Users/ms/Downloads/WNdb-3.0/dict"
val dict = RAMDictionary(File(wordNetPath), ILoadPolicy.NO_LOAD)
dict.open()
val idxWord = dict.getIndexWord("asphalt", POS.NOUN)
if (idxWord != null) {
val word = dict.getWord(idxWord.wordIDs[0])
val relSynsets = word.synset.relatedSynsets
...
}
```However, WS4j provides a lot of features and
[algorithms](http://ws4jdemo.appspot.com) that can be used easily while JWI
provides a more low level API (but with a nice
[tutorial](http://projects.csail.mit.edu/jwi/download.php?f=edu.mit.jwi_2.4.0_manual.pdf)).WS4j is an archived project
on [Google Code](https://code.google.com/archive/p/ws4j) but there is also a
[Github clone available](https://github.com/Sciss/ws4j) which seems to be the
version that is published in the Maven central repository. In order to run WS4j,
you need to put the configuration files
[jawjaw.conf and similarity.conf](https://github.com/Sciss/ws4j/tree/master/config)
and the database file `wnjpn.db` into the class-path. The `wnjpn.db` file can
be extracted from the distribution packages from the
[WS4j Google Code download pages](https://code.google.com/archive/p/ws4j/downloads).