kdb+ Algo Control
Download Pulse
Add kdb+ Server Connection
To add a connection goto Connections->"Add Data Connection" and fill in your details.
You can try clicking test to see if the connection works before adding it.
data:image/s3,"s3://crabby-images/bff3d/bff3d0deb34fb297b15eab33e530ba27f83b9903" alt="Pulse connecting to kdb+ database"
Populating the Tables
data:image/s3,"s3://crabby-images/45993/45993e19cb15d6e2330de949350b4d6246f8af70" alt="SQL Editor Page"
- Go to the SQL Editor
- Make sure your data source is selected
- Enter your SQL query
- Click
Run All
or press ctrl+E
Add and Edit Dashboard
- On the dashboards listing page, click add
- Click on the newly created dashboard to go into it. Either click on edit or toggle design mode once in the dashboard.
Add Algo Table
- Click
Table
to add that component - Make sure your kdb+ data source is selected
- Select the refresh rate.
Every 1s
- Enter your SQL query
select from algos
click save or press ctrl+E - For styling, I have set pager to
none
. - and assigned the
TAG
formatter to the name and variant columns.
data:image/s3,"s3://crabby-images/8ecbc/8ecbc97d6ca5312127af302ce77cdd4c14c8d938" alt="Select Algo Trading Table"
Add Start/Stop Buttons
- Click
User Form
to add that component - Click
Add Button Icon
to add a button to the form. - Add an
Event Handler
to the button. - Set the kdb+ data source.
- Set the code to:
stopAll[]
to call the function. - Perform similar steps again to call
startAll[]
with a Start button.
data:image/s3,"s3://crabby-images/d1821/d1821eb52b736bf29fe5c969cca5b56e8c0cf6b2" alt="Select Algo Trading Table"
Add Right Click Menu Options
We want to add a right-click menu to the table, that allows starting and stopping individual algos.
To do this, select the grid component and scroll down on the right-hand side editor panel, expand the interactive tab and click Add Event Handler
.
data:image/s3,"s3://crabby-images/2eb17/2eb174b87e81fe719a54ece456a215254650fed0" alt="Add Right Click Menu Options"
- Click
Add Event Handler
. - Set the Trigger to
Menu
. - Set the Name to
STOP
, this controls what the menu option is named. - Set kdb+ as the data source that will recieve the call when an event is triggered.
- Set the code to:
setStatus[`${{e.variant}};`Stopped]
.
The{{e}}
object here is a dictionary that has an entry for every row in the table.
If you wanted you could just send {{e}} and kdb+ would receive a dictionary but we only need the variant column so we will send that casted to symbol. - Perform the steps again, this time calling the menu option Start with code:
setStatus[`${{e.variant}};`Running]
.
data:image/s3,"s3://crabby-images/14aa7/14aa77b856095f6c5028e5396994983887941cad" alt="Add kdb Right Click Menu"
You can now right-click on the table and select Start/Stop for individual Algos.
data:image/s3,"s3://crabby-images/b8c02/b8c023c232af18dc581f632ccfd736b480c24cfd" alt="Activating Right Click Menu"
Notice that the table returned from calling setStatus is dsiplayed as a popup message. When there is one row, it will show the full text, when there are more it may present a summary.
data:image/s3,"s3://crabby-images/1fd32/1fd3271a9c572941630da1298e8cec09201a15a5" alt="Popup Message"
Complete
Congratulations, if you have followed along, you have now created a fully interactive Data App.
The power of variables allows creating even more advanced interactivity, in the screenshot below you can see
Algo limits being set using a text field and the right click menu has a google
entry that opens a new browser window while using
the {{e}} variable to open a specific page relevant to that algo. Something for you to try in future perhaps. Our links below have more information.
data:image/s3,"s3://crabby-images/dc8c7/dc8c756d0fda5465b958e58a2416d42f59810eab" alt="Algo Contents"
Thanks for watching our demo. Please download Pulse to give it a try for yourself.