the FOSS computational trading platform (for non-tinas..) https://github.com/pikers/piker
Go to file
Tyler Goodlet 2f1fdaf9e5 Rework charting internals for real-time plotting
`pg.PlotCurveItem.setData()` is normally used for real-time updates to
curves and takes in a whole new array of data to graphics.
It makes sense to stick with this interface especially if
the current datum graphic will originally be drawn from tick quotes and
later filled in when bars data is available (eg. IB has this option in
TWS charts for volume). Additionally, having a data feed api where the push
process/task can write to shared memory and the UI task(s) can read from
that space is ideal. It allows for indicator and algo calculations to be
run in parallel (via actors) with initial price draw instructions
such that plotting of downstream metrics can be "pipelined" into the
chart UI's render loop. This essentially makes the chart UI async
programmable from multiple remote processes (or at least that's the
goal).

Some details:
- Only store a single ref to the source array data on the
  `LinkedSplitCharts`.  There should only be one reference since the main
  relation is **that** x-time aligned sequence.
- Add `LinkedSplitCharts.update_from_quote()` which takes in a quote
  dict and updates the OHLC array from it's contents.
- Add `ChartPlotWidget.update_from_array()` method to trigger graphics
  updates per chart with consideration for overlay curves.
2020-10-02 12:13:28 -04:00
.github/workflows Add github actions CI; thanks @guilledk! 2020-10-02 10:40:25 -04:00
piker Rework charting internals for real-time plotting 2020-10-02 12:13:28 -04:00
tests Create a blank config if none exists 2019-03-18 00:04:34 -04:00
.gitignore Initial commit 2018-01-15 22:58:02 -05:00
.travis.yml Deploy flag is no longer supported I guess? 2019-03-17 23:09:08 -04:00
LICENSE Relicense to AGPLv3 2020-06-16 00:12:19 -04:00
MANIFEST.in Extend install docs 2018-02-15 13:33:53 -05:00
Pipfile Use qt5 and trio guest mode 2020-10-02 12:13:27 -04:00
Pipfile.lock Bump psutil from 5.6.5 to 5.6.6 2020-03-12 18:31:45 +00:00
README.rst Who needs it ;P 2020-09-01 14:05:31 -04:00
requirements.txt Switch to asyncio support branch in tractor 2020-10-02 10:40:50 -04:00
setup.py Update version and deps 2020-09-01 13:25:40 -04:00

README.rst

piker

Trading gear for hackers.

travis

piker is an attempt at a pro-grade, broker agnostic, next-gen FOSS toolset for real-time trading and financial analysis targetted at hardcore Linux users.

It tries to use as much bleeding edge tech as possible including (but not limited to):

  • Python 3.7+ for glue and business logic
  • trio for async
  • tractor as the underlying actor model
  • marketstore for historical and real-time tick data persistence and sharing
  • techtonicdb for L2 book storage
  • Qt for pristine high performance UIs

Focus and Features:

  • 100% federated: running your code on your hardware with your broker's data feeds, privately, is the point (this is not a web-based I don't know how to run my own system project).
  • Asset class, broker, exchange agnostic.
  • Built on a highly reliable structured concurrent actor model with built in async streaming and scalability protocols allowing for a distributed architecture from the ground up.
  • Privacy: your orders, indicators, algos are all run client side and are shared only with the (groups of) traders you specify.
  • Production grade, highly attractive native UIs that feel and fit like a proper pair of skinny jeans; only meant to be used with a proper tiling window manager (no, we are not ignorant enough to roll our own).
  • Sophisticated charting capable of processing large data sets in real-time while sanely displaying complex models and strategy systems.
  • Built-in support for hipstery indicators and studies that you probably haven't heard of but that the authors know generate alpha when paired with the right strategies.
  • Emphasis on collaboration through sharing of data, ideas, and processing power. We will not host your code in the cloud nor ask you to participate in any lame "alpha competitions".
  • Adoption is very low priority, especially if you're not an experienced trader; the system is not built for sale it is built for people.
  • No, we will never have a "corporation friendly license"; if you intend to use this code base we must know about it.

Fitting with these tenets, we're always open to new framework suggestions and ideas.

Building the best looking, most reliable, keyboard friendly trading platform is the dream. Feel free to pipe in with your ideas and quiffs.

Install

piker is currently under heavy pre-alpha development and as such should be cloned from this repo and hacked on directly.

A couple bleeding edge components are being used atm pertaining to async ports of libraries for use with trio.

Before installing make sure you have pipenv and have installed python3.7 as well as kivy source build dependencies since currently there's reliance on an async development branch.

kivy dependencies

On Archlinux you need the following dependencies:

pacman -S python-docutils gstreamer sdl2_ttf sdl2_mixer sdl2_image xclip

To manually install the async branch of kivy from github do (though this should be done as part of the pipenv install below):

pipenv install -e 'git+git://github.com/matham/kivy.git@async-loop#egg=kivy'

For a development install:

git clone git@github.com:pikers/piker.git
cd piker
pipenv install --pre -e .
pipenv shell

Broker Support

For live data feeds the only fully functional broker at the moment is Questrade. Eventual support is in the works for IB, TD Ameritrade and IEX. If you want your broker supported and they have an API let us know.

Play with some UIs

To start the real-time index monitor with the questrade backend:

piker -l info monitor indexes

If you want to see super granular price changes, increase the broker quote query rate with -r:

piker monitor indexes -r 10

It is also possible to run the broker data feed micro service as a daemon:

pikerd -l info

Then start the client app as normal:

piker monitor indexes