Open Source Risk Engine is an open source library for calculating risk.
ORE Dashboard is a web app for viewing ORE output.
This is the technical documentation for ORE Dashboard, aimed at programmers who intend to support and enhance the app.
    1.1 Operating System
    1.2 Required Packages
    1.3 Other Packages
    2.1 Fork the git Repo
    2.2 Create a Heroku App
    2.3 Install the Heroku Toolbelt
    2.4 Initialize the App
    3.1 Create the Hierarchy Definition
    3.2 Create the Data Files
    3.3 Update the File List
    3.4 Commit to git
    4.1 Hierarchies and Trees
    4.2 Cache
    4.3 Load
    4.4 Rest Endpoints
ORE Dashboard is a Java app which is platform neutral. It was developed on Mac and Ubuntu, it should just work on Windows too.
You need to install the following before running ORE Dashboard:
- Java 1.8
- maven - dependency manager for Java
ORE Dashboard makes use of additional packages. You do not need to install these yourself, they are included in the build:
- Spark Framework (Java REST server micro-framework)
- Echarts (Javascript data-viz package)
- Bootstrap
- Font Awesome
- jQuery-Autocomplete
- FullCalendar
- Charts.js
- Bootstrap Colorpicker
- Cropper
- dataTables
- Date Range Picker for Bootstrap
- Dropzone
- easyPieChart
- ECharts
- bootstrap-wysiwyg
- Flot - Javascript plotting library for jQuery.
- gauge.js
- iCheck
- jquery.inputmask plugin
- Ion.RangeSlider
- jQuery
- jVectorMap
- moment.js
- Morris.js - pretty time-series line graphs
- jquery-nicescroll plugin
- PNotify - Awesome JavaScript notifications
- NProgress
- Pace
- Parsley
- bootstrap-progressbar
- select2
- Sidebar Transitions - simple off-canvas navigations
- Skycons - canvas based icons
- jQuery Sparklines plugin
- switchery - Turns HTML checkbox inputs into beautiful iOS style switches
- jQuery Tags Input Plugin
- Autosize - resizes text area to fit text
- validator - HTML from validator using jQuery
- jQuery Smart Wizard
- ...
This section comprises a tutorial demonstrating how to get ORE Dashboard up and running on your machine, and how to deploy it to the cloud.
Go on to the github website and fork https://github.com/OpenSourceRisk/Dashboard
Go on to the heroku website and create a new app. You can either allow heroku to generate a random name for your app, or you can pick a name yourself. For purposes of this tutorial, the heroku app is called blooming-dawn-94116.
This is a command line client that makes using the Heroku cloud environment very simple indeed. You can get by without installing it but it means that you have to compile the app locally and deploy it manually to Heroku. The Heroku CLI takes care of all the deployment and packaging straight from the GitHub repo.
Install the heroku toolbelt as explained at https://toolbelt.heroku.com/.
Open a command window. Create a directory for your work. For purposes of this tutorial, the directory is called /home/quaternion/demo
. cd into the directory:
cd /home/quaternion/demo
Clone from your new remote repo into the local directory:
git clone https://github.com/OpenSourceRisk/Dashboard.git
cd into the project directory:
cd /home/quaternion/demo/Dashboard
Set up heroku by logging in to your repo and linking the remote cloud version:
heroku login
heroku git:remote -a blooming-dawn-94116
Build the app (only necessary if you are testing on a local machine):
mvn clean package
Run the app locally (after doing the build step, above):
heroku local web
View the local instance in your browser:
Deploy the app - this pushes the code changes to the Heroku version of your git repo and deploys the app in the cloud:
git push heroku master
View the remote instance in your browser:
http://blooming-dawn-94116.herokuapp.com/
NB: You are not required to use Heroku. ORE Dashboard is a pure Java app which could be deployed to any container, e.g. JBOSS, Tomcat. Spark is simply the REST framework with a built-in Jetty web server. The web server component can be disabled very easily in code if you want to run the JAR in another container.
ORE Dashboard views data files generated by the ORE application. This section of the documentation explains how to set up the data files for use by the Dashboard.
The root directory for the data is...
/home/quaternion/demo/Dashboard/src/main/resources/data/vX
...where X is the version number of the current data set. The data files are maintained under version control. They are also packaged into the jar file. When the server starts up, it loads the data files from the jar file into memory. All of this is explained in detail below.
The data is organized into a hierarchy. The structure of the hierarchy is stored in a file which the server loads at startup:
/home/quaternion/demo/Dashboard/src/main/resources/data/vX/hierarchies.csv
This file was created by opening workbook SamplePortfolio1_TradeMapping v3.xlsx
and saving the worksheet Hierarchies
in CSV format.
Take the output from the ORE application and copy it to the root data directory, creating one subdirectory for each processing date, e.g:
/home/quaternion/demo/Dashboard/src/main/resources/data/vX/20160701
/home/quaternion/demo/Dashboard/src/main/resources/data/vX/20160702
/home/quaternion/demo/Dashboard/src/main/resources/data/vX/20160703
...
At startup, the server iterates through the above directories and loads the data into cache.
When a java application loads static data files from a jar file, there is a limitation that the app is unable to discover the contents of the data directory. The app must already know the name of a file before it can be loaded.
Therefore we maintain a list of all available data files. The server loads up this list at startup and uses it to iterate through the data files.
After making any changes to the contents of the data directory, you need to update the file list:
cd /home/quaternion/demo/Dashboard/src/main/resources
find data/vX > data/vX/dirlist.txt
All of the changes that you made above need to be committed to the git repo.
This section of the documentation provides technical information on how the data is loaded into the server memory.
Here is a partial rendering of the data structure:
The data comprises a tree. The tree is five levels deep, each level is referred to as a hierarchy: total, creditrating, counterparty, nettingset, trade.
The Dashboard implements two different modes for viewing the data:
- hierarchy: In this mode, the user selects one of the five hierarchies, and the Dashboard displays the data for all of the nodes in the selected hierarchy. For example, if the user selects hierarchy creditrating, then the Dashboard displays the data for all of the credit ratings (A, AA, AAA, B, ...).
- tree: In this mode, the user selects one of the nodes in the tree, and the Dashboard displays the data for all of the children of the selected node. For example, if the user selects node CUST_D, then the Dashboard displays the data for all of the netting sets that belong to that client (CSA_16, CSA_17, ...).
Class Cache contains a member variable of type Node, which comprises the root node of the tree. The Cache also contains a list of 5 Hierarchy objects, one for each level of the tree. Each Hierarchy object holds a list of the Nodes in the relevant level:
Class ProcessingDate encapsulates the data for a list of nodes for a given date. The list of nodes may be either:
- The children of a node
- The nodes belonging to a hierarchy
In other words:
- class Node contains a list of ProcessingDate objects to encapsulate the data for that node's children, by date.
- class Hierarchy contains a list of ProcessingDate objects to encapsulate the data for the nodes in that hierarchy, by date.
The data requirements for Nodes and Hierarchies differ slightly, this difference is captured by two subclasses of ProcessingDate:
- class ProcessingDateHierarchy encapsulates BarGraph and Xva.
- class ProcessingDateNode encapsulates BarGraph, Xva, and Exposure.
Each Node object also contains the TotalExposure data relevant to that Node (this data is independent of the processing date).
Now, let's try and put all of that together. Consider the following diagram, which zooms in on a fragment of the cache:
You can see that:
- class Node stores TotalExposure (for all dates)
- class Node stores a list of ProcessingDateNode objects
- class ProcessingDateNode stores BarGraph, Xva, and Exposure for the children of the Node
- class Hierarchy stores a list of ProcessingDateHierarchy objects
- class ProcessingDateHierarchy stores BarGraph and Xva for the nodes in the hierarchy
That's it. It's not as complicated as it seems.
Class Cache invokes class Load to copy the data from disk to memory. Class Load is functionally a part of class Cache but has been separated out for clarity. Class Load invokes setter functions in class Cache in order to populate the cache. The load is performed at startup and is invoked once per processing date. Tree-level data is attached to the Node objects, and hierarchy-level data is attached to the Hierarchy objects.
The cache implements a series of rest endpoints which serve up the data to the front end, depending on which parameters the user has entered into the browser.
A web page is provided for manual inspection of the rest endpoints. The page is not required for production use - the client accesses the rest endpoints programatically - but the page is helpful for understanding the rest API for the ORE Dashboard app.
If you are running the server locally after invoking the heroku local web
command (described above), then you should find the debugging page at the following URL:
http://localhost:5000/api/cache.html
If you have deployed the app to the cloud, then the URL should look something like:
http://blooming-dawn-94116.herokuapp.com/api/cache.html
At the time of this writing, the page above is online, and it is referred to for the rest of this section of the document.
The specification of the rest API depends upon whether we are in hierarchy view or tree view (explained previously).
This refers to the case where we display all of the nodes in one of the five levels of the tree.
In this case the path to an item in the hierarchy is always:
hierarchy/item
For example, to get to credit rating AAA:
creditrating/AAA
To get to netting set CSA_46:
nettingset/CSA_46
etc.
This refers to the case where we display all of the children of one node.
In this case there are two ways to define the path:
A) hierarchy/item
B) creditrating/counterparty/nettingset/trade
For example, to get to netting set CSA_46:
A) nettingset/CSA_46
B) A/CUST_J/CSA_46
Approach "A" is more concise.
There are two rest endpoints to return the children of a given node.
- tree - uses approach A
- tree2 - uses approach B
For example, if you want to get a list of the trades belonging to netting set CSA_46, you can do either of the following:
http://blooming-dawn-94116.herokuapp.com/api/tree/nettingset/CSA_46
http://blooming-dawn-94116.herokuapp.com/api/tree2/Total/A/CUST_J/CSA_46
Both of the above two endpoints return the same data:
[ "Trade_3336", "Trade_3409", "Trade_5450", "Trade_7805", "Trade_8268" ]
A bar graph displays the top 5 children of a given node for a given metric.
Top 5 counterparties for metric CE:
http://blooming-dawn-94116.herokuapp.com/api/bargraph/20150630/counterparty/ce
Top 5 AAA counterparties for metric CE:
http://blooming-dawn-94116.herokuapp.com/api/bargraph-tree/20150630/creditrating/AAA/ce
Note that, in the tree view for bar graphs, "Approach A" is implemented.
The donut graph displays all of the children of a given node for a given metric.
CVA for all counterparties:
http://blooming-dawn-94116.herokuapp.com/api/xva/20150630/counterparty/cva
CVA for all AAA counterparties (there is only one):
http://blooming-dawn-94116.herokuapp.com/api/xva-tree/20150630/creditrating/AAA/cva
Again the xva tree view uses "Approach A".
These are only relevant in tree view.
If the user chooses any of the 5 hierarchies from the drop down, the two line graphs should just display the root node:
http://blooming-dawn-94116.herokuapp.com/api/exposure-tree/20150630/total/Total
http://blooming-dawn-94116.herokuapp.com/api/totalexposure-tree/total/Total
Don't get confused by the "total/Total". The rest endpoints for the line graphs employ tree view, Approach A:
hierarchy/item
where hierarchy = "total" (level 0) and item = "Total" (the name of the root node).
Exposure for CUST_A:
http://blooming-dawn-94116.herokuapp.com/api/exposure-tree/20150630/counterparty/CUST_A
Total exposure for CUST_A:
http://blooming-dawn-94116.herokuapp.com/api/totalexposure-tree/counterparty/CUST_A