Skip to content
Tim Paine edited this page Feb 7, 2024 · 36 revisions

csp ("Composable Stream Processing") is a functional-like reactive language that makes time-series stream processing simple to do.  The main reactive engine is a C++ based engine which has been exposed to python ( other languages may optionally be extended in future versions ). csp applications define a connected graph of components using a declarative language (which is essentially python).  Once a graph is constructed it can be run using the C++ engine. Graphs are composed of some number of "input" adapters, a set of connected calculation "nodes" and at the end sent off to "output" adapters. Inputs as well as the engine can be seamlessly run in simulation mode using historical input adapters or in realtime mode using realtime input adapters.

Contents

Contributing

Contributions are welcome on this project. We distribute under the terms of the Apache 2.0 license.

For bug reports or small feature requests, please open an issue on our issues page.

For questions or to discuss larger changes or features, please use our discussions page.

For contributions, please see our developer documentation. We have help wanted and good first issue tags on our issues page, so these are a great place to start.

Roadmap

We do not have a formal roadmap, but we're happy to discuss features, improvements, new adapters, etc, in our discussions area. Here are some high level items we hope to accomplish in the next few months:

  • Redis Pub/Sub Adapter with Redis-plus-plus
  • uWebsockets adapter
  • Slack Adapter with python-slack-sdk
  • csp-gateway: Application development framework, built with FastAPI and Perspective. This is a library we have built internally at Point72 on top of csp that we hope to open source later in 2024.
  • Interactive graph viewer, both standalone and viewable in Jupyter (with something like ipydagred3)
  • Sympy integration via lambdify
Clone this wiki locally