Skip to main content

TALi++ - Incremental Technical Analysis Library

Project description

TALIpp - Incremental Technical Analysis Library

talipp (or tali++) is a Python library implementing financial indicators for technical analysis. The distinctive feature of the library is its incremental computation which fits extremely well real-time applications or applications with iterative input in general.

Unlike existing libraries for technical analysis which typically have to work on the whole input vector in order to calculate new values of indicators, talipp due to its incremental architecture calculates new indicators' values exclusively based on the delta input data. That implies, among others, it requires O(1) time to produce new values in comparison to O(n) (or worse) required by other libraries.

Supported incremental operations include:

  • appending new values to the input
  • updating the last input value
  • removing arbitrary number of the input values

Besides the already mentioned superior time complexity for delta input operations, talipp's incremental approach immediately offers other interesting features for free, such as indicator chaining or building new indicators combined from other indicators. See section with examples to get an idea.

Incremental nature of talipp naturally excels in applications with frequent CUD operations but it can be used for charting, back-testing, ... as any other existing library.

Last but not least, talipp is a very young project and therefore open to any suggestions of amending the API to users' liking. You are encouraged to come up with proposals.


What's new in version 1.3.0

  • new indicators: Chande Kroll Stop, Choppiness Index, Commodity Channel Index, Coppock Curve, Mean Deviation

For the full history of changes see CHANGELOG.


List of incremental indicators

talipp currently provides below set of indicators. If your favourite indicator is missing, then create a ticket via GitHub Issues and there is a good chance that it will be included in the future version of the library.

  • Accumulation/Distribution (ADL)
  • Aroon
  • Average Directional Index (ADX)
  • Average True Range (ATR)
  • Awesome Oscillator (AO)
  • Balance of Power (BOP)
  • Bollinger Bands (BB)
  • Chaikin Oscillator
  • Chande Kroll Stop
  • Choppiness Index (CHOP)
  • Coppock Curve
  • Commodity Channel Index (CCI)
  • Donchian Channel (DC)
  • Ichimoku Kinko Hyo
  • Keltner Channel (KC)
  • Know Sure Thing (KST)
  • Mass Index
  • Mean Deviation
  • Moving Average (ALMA, SMA, SMMA, DEMA, EMA, HMA, KAMA, TEMA, VWMA, WMA)
  • Moving Average Convergence Divergence (MACD)
  • On-balance Volume (OBV), Smoothed On-balance Volume (SOBV)
  • Parabolic SAR
  • Pivots High/Low
  • Rate of Change (ROC)
  • Relative strength index (RSI)
  • SFX TOR
  • Standard Deviation
  • Stochastic Oscillator
  • Stochastic RSI
  • TRIX
  • True Strength Index (TSI)
  • Ultimate Oscillator (UO)

Installation

pip install talipp

In case you want to install the latest version from the repo, use

pip install git+https://github.com/nardew/talipp.git@master

Examples

Consult examples folder to see usage of every single indicator included in the library. To get the basic look and feel of the API, see below.

from talipp.indicators import EMA, SMA, Stoch
from talipp.ohlcv import OHLCVFactory

# EMA indicator ([float] -> [float])
ema = EMA(period = 3, input_values = [1, 3, 5, 7, 9, 2, 4, 6, 8, 10])

# treat indicators as any other list
print(f'EMA(3): {ema}') # [3.0, 5.0, 7.0, 4.5, 4.25, 5.125, 6.5625, 8.28125]
print(f'Last EMA value: {ema[-1]}') # 8.28125

# append a new input value incrementally
ema.add_input_value(11)
print(f'EMA after adding a new value:      {ema}') # [3.0, 5.0, 7.0, 4.5, 4.25, 5.125, 6.5625, 8.28125, 9.640625]

# change the last added value
ema.update_input_value(15)
print(f'EMA after updating the last value: {ema}') # [3.0, 5.0, 7.0, 4.5, 4.25, 5.125, 6.5625, 8.28125, 11.640625]

# change the last added value again
ema.update_input_value(18)
print(f'EMA after updating the last value: {ema}') # [3.0, 5.0, 7.0, 4.5, 4.25, 5.125, 6.5625, 8.28125, 13.140625]

# remove the last added value
ema.remove_input_value()
print(f'EMA after removing the last value: {ema}') # [3.0, 5.0, 7.0, 4.5, 4.25, 5.125, 6.5625, 8.28125]

# STOCH indicator ([OHLCV] -> [composite])
stoch = Stoch(5, 3, OHLCVFactory.from_dict({
    'high':     [5, 10, 15, 20, 25, 30, 35],
    'low':      [1, 4, 7, 10, 13, 16, 19],
    'close':    [3, 9, 8, 19, 18, 17, 19]
}))

# print result as a list of composite values for 'k' and 'd' output parameters
print(f'Stoch(5, 3) composite result: {stoch}') # [StochVal(k=70.83333333333333, d=None), StochVal(k=50.0, d=None), StochVal(k=42.857142857142854, d=54.563492063492056)]

# print result as lists per output parameters
print(f'Stoch(5, 3) decomposed result: {stoch.to_lists()}') # {'k': [70.83333333333333, 50.0, 42.857142857142854], 'd': [None, None, 54.563492063492056]} 

# Indicator chaining
sma1 = SMA(3)
sma2 = SMA(3, input_indicator = sma1)
sma3 = SMA(3, input_indicator = sma2)

sma1.add_input_value([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
print(f"SMA1: {sma1}") # [2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0]
print(f"SMA2: {sma2}") # [3.0, 4.0, 5.0, 6.0, 7.0, 8.0]
print(f"SMA3: {sma3}") # [4.0, 5.0, 6.0, 7.0]

Performance

To illustrate performance scaling of talipp we ran several tests together with the industry standard talib library and its python wrapper ta-lib. The takeaway from the comparison is following:

  • for batch processing (i.e. one-off calculation of indicators without addition of further delta values) talib is a clear winner. This is not surprising at all since it is implemented in C and it is tailored for vector calculations in one shot. talipp's incremental (i.e. not vector) calculation and features such as indicator chaining (which internally implements output listeners) must inevitably come at a cost. That being said, talipp calculates SMA for batch of 50k values incrementally still in ~200ms which is perfectly acceptable for many applications
  • where talipp clearly takes the lead is incremental calculation. Again this is well expected since talipp's CUD operations take O(1) time compared to O(n) time of talib. For 50k input the difference is as big as ~200ms vs. ~6800ms.
  • from the graphs it is apparent that talipp scales linearly with the size of the input compared to quadratic curve of talib when incremental operations are concerned. This follows from talipp's O(1) time for delta operations vs. talib's O(n).

SMA(20) TEMA(20) StochRSI(14,3,3)

Contact

  • to report issues, bugs, corrections or to propose new features use preferably Github Issues
  • for topics requiring more personal approach feel free to send an e-mail to

Support

If you like the library and you feel like you want to support its further development, enhancements and bug fixing, then it will be of great help and most appreciated if you:

  • file bugs, proposals, pull requests, ...
  • spread the word
  • donate an arbitrary tip
    • BTC: 3GJPT6H6WeuTWR2KwDSEN5qyJq95LEErzf
    • ETH: 0xC7d8673Ee1B01f6F10e40aA416a1b0A746eaBe68

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

talipp-1.3.0.tar.gz (20.3 kB view details)

Uploaded Source

Built Distribution

talipp-1.3.0-py3-none-any.whl (35.7 kB view details)

Uploaded Python 3

File details

Details for the file talipp-1.3.0.tar.gz.

File metadata

  • Download URL: talipp-1.3.0.tar.gz
  • Upload date:
  • Size: 20.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9

File hashes

Hashes for talipp-1.3.0.tar.gz
Algorithm Hash digest
SHA256 2c4f7712ad26ff4877311e596c3099021f80111e7e15559bd4919e31beabec11
MD5 618bac9e2645575bc149caa7f1958574
BLAKE2b-256 bf1e8395f0899d334dfef53db2811ba204f9d00e129ddb3cb426ad881af68004

See more details on using hashes here.

File details

Details for the file talipp-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: talipp-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 35.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9

File hashes

Hashes for talipp-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d6a705dddd843cea00c5acbb8ef7b0629e6a6ea45c2f29027039e7849016a872
MD5 933f99e316d9930fa77199c775e246d0
BLAKE2b-256 6ebf0a499aa36d25ebaa5f3535b1f12398e73c8e133f097229d2d2ec9fa83f10

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