-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
- Adds documentation for Mass Spring Damper, Water Tank Fault Inject and Water Tank Model Swap examples - Adds new diagrams for each of the examples --------- Co-authored-by: Asti <[email protected]>
- Loading branch information
1 parent
04b6e4e
commit 3591b53
Showing
13 changed files
with
537 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,120 @@ | ||
# Water Tank Fault Injection | ||
|
||
## Overview | ||
|
||
This example shows a fault injection (FI) enabled digital twin (DT). | ||
A live DT is subjected to simulated faults received from the environment. | ||
The simulated faults is specified as part of DT configuration and can be | ||
changed for new instances of DTs. | ||
|
||
In this co-simulation based DT, a watertank case-study is used; co-simulation | ||
consists of a tank and controller. The goal of which is to keep | ||
the level of water in the tank between ```Level-1``` and ```Level-2```. | ||
The faults are injected into output of the water tank | ||
controller (**Watertankcontroller-c.fmu**) | ||
from 12 to 20 time units, such that | ||
the tank output is closed for a period of time, leading to the water level | ||
increasing in the tank beyond the desired level (```Level-2```). | ||
|
||
## Example Diagram | ||
|
||
![Water Tank System](watertank.png) | ||
|
||
## Example Structure | ||
|
||
![Water Tank Structure](dt_structure.png) | ||
|
||
## Configuration of assets | ||
|
||
This example uses two models and one tool. | ||
The specific assets used are: | ||
|
||
| Asset Type | Names of Assets | Visibility | Reuse in Other Examples | | ||
|:---|:---|:---|:---| | ||
| Models | watertankcontroller-c.fmu | Private | Yes | | ||
| | singlewatertank-20sim.fmu | Private | Yes | | ||
| Tool | maestro-2.3.0-jar-with-dependencies.jar | Common | Yes | | ||
|
||
The `multimodelFI.json` and `simulation-config.json` | ||
are two DT configuration files used for executing the digital twin. | ||
|
||
:fontawesome-solid-circle-info: The faults are defined in **wt_fault.xml**. | ||
|
||
## Lifecycle Phases | ||
|
||
| Lifecycle Phase | Completed Tasks | | ||
| -------- | ------- | | ||
| Create | Installs Java Development Kit for Maestro tool | | ||
| Execute | Produces and stores output in data/water_tank_FI/output directory| | ||
| Clean | Clears run logs and outputs | | ||
|
||
## Run the example | ||
|
||
To run the example, change your present directory. | ||
|
||
```bash | ||
cd workspace/examples/digital_twins/water_tank_FI | ||
``` | ||
|
||
If required, change the execute permission of lifecycle scripts | ||
you need to execute, for example: | ||
|
||
```bash | ||
chmod +x lifecycle/create | ||
``` | ||
|
||
Now, run the following scripts: | ||
|
||
### Create | ||
|
||
Installs Open Java Development Kit 17 and pip dependencies. | ||
The pandas and matplotlib are the pip dependencies installated. | ||
|
||
```bash | ||
lifecycle/create | ||
``` | ||
|
||
### Execute | ||
|
||
Run the co-simulation. Generates the co-simulation output.csv file | ||
at `/workspace/examples/data/water_tank_FI/output`. | ||
|
||
```bash | ||
lifecycle/execute | ||
``` | ||
|
||
### Analyze phase | ||
|
||
Process the output of co-simulation to produce a plot at: | ||
`/workspace/examples/data/water_tank_FI/output/plots/`. | ||
|
||
```bash | ||
lifecycle/analyze | ||
``` | ||
|
||
#### Examine the results | ||
|
||
The results can be found in the | ||
_workspace/examples/data/water_tank_FI/output directory_. | ||
|
||
You can also view run logs in the | ||
_workspace/examples/digital_twins/water_tank_FI_. | ||
|
||
### Terminate phase | ||
|
||
Clean up the temporary files and delete output plot | ||
|
||
```bash | ||
lifecycle/terminate | ||
``` | ||
|
||
## References | ||
|
||
More details on this case-study can be found in the paper: | ||
|
||
```txt | ||
M. Frasheri, C. Thule, H. D. Macedo, K. Lausdahl, P. G. Larsen and | ||
L. Esterle, "Fault Injecting Co-simulations for Safety," | ||
2021 5th International Conference on System Reliability and Safety (ICSRS), | ||
Palermo, Italy, 2021. | ||
``` |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.