Skip to main content

A simpler library for the alapaca trade api

Project description

cira

Cira algorithmic trading made easy. A Façade library for simpler interaction with alpaca-trade-API from Alpaca Markets.

Cira is available on pip. Please give it a star if you like it!

drawing

GitHub stars GitHub forks Tweet

GitHub PyPI PyPI - Python Version PyPI - Downloads

The name cira is a miss spelling of the word for a baby alpaca cria and because this is a simple and small lib I thought it would be a perfect fit.

Axel Gard is main developer for cira.

Getting Started

If you are new to cira checkout the tutorial. Or checkout an example.

Installation

You can install it using pip.

pip install cira

Usage

Since the Alpaca trade API need a API key, you need to generate your own key at alpaca markets website. If you want to play around with it you can try paper trading (recommended for beginners). I recommend keep it in a JSON file which cira needs the path to. You can also set the variables directly or use an environment variable, see the wiki for diffrent the ways. However, it is recommended that you store it in a file just make sure not to upload that file on any public repositories.

You can set the Alpaca keys directly

import cira

cira.auth.APCA_API_KEY_ID = "my key" 
cira.auth.APCA_API_SECRET_KEY = "my secret key"

stock = cira.Stock("TSLA")
stock.buy(1) # buy 1 TSLA stock on alpaca 
stock.sell(1) # sell 1 TSLA stock on alpaca 

For interactons with alpaca you can:

portfolio = cira.Portfolio() # methods for your portfolio
exchange = cira.Exchange() # methods for exchange
stock = cira.Stock("TSLA") # a class for one stock
crypto = cira.Cryptocurrency("BTC/USD") # method for one cryptocurrency 

DEMO, no keys needed

Crypto market data can be accessed without any alpaca keys. So there for you can try cira out with out needing to get alpaca keys. To put you model in production where you buy and sell you will need alpaca keys.

Needs cira>=3.2.2.

import cira
from datetime import datetime
import matplotlib.pyplot as plt

assert not cira.auth.check_keys() # No keys are needed

SYMBOL = "BTC/USD"
ast = cira.Cryptocurrency(SYMBOL)

print(f"The current asking price for {SYMBOL} is {ast.price()}")


# alpaca only have BTC data from 2021 and forward 
data = ast.historical_data_df(datetime(2021, 1, 1), datetime.now().date())
print(data.head())

# All of strategies and backtesting works with out keys as well. 
strat = cira.strategy.Randomness()
cira.strategy.back_test_against_buy_and_hold(strat, data, data["open"].to_frame(), 100_000).plot()
plt.savefig('./result.png')

you can find more examples on the examples repo and the wiki/tutorial for even more information.

Cira Stratergies

Cira have also support for strategies.
An full example of how to use the strategy is example/linear.

With strategies you can run a cira backtests.

from cira.strategy import Strategy
import numpy as np
import pandas as pd

class MyStrat(Strategy):
    def __init__(self) -> None:
        super().__init__(name="MyStrat")

    def iterate(self, feature_data: pd.DataFrame, prices: pd.DataFrame, portfolio: np.ndarray, cash:float) -> np.ndarray:
        # this mehod will be called for each row of data in the backtest 
        # the function should return the change of your portfolio. 
        # -1 means sell one stock, 0 means hold, 1 means buy one stock
        return np.array([ portfolio_change_as_int_or_float ]) 

Backtest

If your model is put into a strategy you can run a backtest on you own data. This is a backtest using some of the included strategy in cira. You can run a backtest aginst multiple strategies using the same data, this requires however that all features for all models are in the given data to the backtest. You should of course add your own strategy, but as an example.

import cira
from datetime import datetime
import matplotlib.pyplot as plt

assert not cira.auth.check_keys() # back testing against crypto do not need keys 

SYMBOL = "ETH/USD"
ast = cira.Cryptocurrency(SYMBOL)

data = ast.historical_data_df(datetime(2021, 1, 1), datetime.now().date())

strats = [
            cira.strategy.ByAndHold(),
            cira.strategy.DollarCostAveraging(0.8),
            cira.strategy.Randomness(-100, 100, seed=None, use_float=True),
            # add your own strategy and compare your model against other models
        ]
cira.strategy.multi_strategy_backtest(strats, data, data["open"].to_frame(), 100_000).plot()
plt.savefig("./result.png")

If you want more full example of how to use the backtest checkout multiassets and linear.

Things to checkout

Wiki and docs

To see what more you can do check out the wiki.

Want the old version?

For backwards compatibility I made sure to fork cira in to cira-classic and cira-classic is also available on pypi with pip.

If you find bug plz let me know with a issue. If you know how to solve the problem then you can of course make a pull request and I will take a look at it.

Have a question?

If you have a question about cira, want to share what you built with cira or want to talk to others using cira, you can checkout the discussions page or make issue if that is more fitting.

History of cira

I was interested in using the Alpaca trade API for building a quantitative paper trader. The project is available here.
However after working on this for alomst a year (off and on) I realized that I had alomst build a small library for using the Alpaca API. So I thought that I would make this into a real library so that you can get started with quantitative paper trading as well.

Development

If you want to help develop cira you are more then welcome to do so. Feel free to make a pull request or issue. To install cira with all the dev req.

git clone git@github.com:AxelGard/cira.git
cd cira/
git checkout develop

and know you need to

python3 -m venv env
source env/bin/activate
pip install -e .
pip install -r requirements.txt

Run tests using pytest. Ensure that you are in the cira dir. But you will need a new key. This key should not only be used for testing or if you don't mind if all of the assets in the portfolio being sold.

pytest -rP

Coding style

I'm trying to follow the pep8 standard notation. I try to make the library to be so intuitive as possible for easy of use.

I enforce black formater when you commit code, by pre-commit githooks to keep it some what well formated.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cira-3.3.0.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

cira-3.3.0-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file cira-3.3.0.tar.gz.

File metadata

  • Download URL: cira-3.3.0.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.4

File hashes

Hashes for cira-3.3.0.tar.gz
Algorithm Hash digest
SHA256 126d2d8cfa460af45bcab519c242fce433207212f0ebcc38de80e6fe9145b13f
MD5 395a3e8f8d1a8637affb3c0729a83832
BLAKE2b-256 5b4610759272ec83f0c6c474c1a4df412ceafb674fc9b89103ba585f47171d8d

See more details on using hashes here.

File details

Details for the file cira-3.3.0-py3-none-any.whl.

File metadata

  • Download URL: cira-3.3.0-py3-none-any.whl
  • Upload date:
  • Size: 18.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.4

File hashes

Hashes for cira-3.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 212fadc16e83bd62fcf1c738174e8fac0d90e83ec14202951d4293509a72b53d
MD5 7b4f63d3a019234341d4a8024e600342
BLAKE2b-256 1cf09f3af48a7056a6d5fdff1e0c37979663f1831fd125e28a23ecb3ecb19fc0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page