Skip to content

QuantConnect/Lean.Brokerages.TradingTechnologies

Repository files navigation

header-cheetah

     

Introduction

This repository hosts the Trading Technologies Brokerage Plugin Integration with the QuantConnect LEAN Algorithmic Trading Engine. LEAN is a brokerage agnostic operating system for quantitative finance. Thanks to open-source plugins such as this LEAN can route strategies to almost any market.

LEAN is maintained primarily by QuantConnect, a US based technology company hosting a cloud algorithmic trading platform. QuantConnect has successfully hosted more than 200,000 live algorithms since 2015, and trades more than $1B volume per month.

About Trading Technologies

introduction

Trading Technologies (TT) was founded by Gary Kemp in 1994 with the goal to create professional trading software, infrastructure, and data solutions for a wide variety of users. TT provides access to trading Futures, Options, and Crypto. TT also provides a charting platform, infrastructure services, and risk management tools. TT is not actually a brokerage. The firm is a brokerage router with access to more than 30 execution destinations.

For more information about the TT brokerage, see the QuantConnect-Trading Technologies Integration Page.

Using the Brokerage Plugin

Deploying Trading Technologies with VSCode User Interace

You can deploy using a visual interface in the QuantConnect cloud. For instructions, see the QuantConnect-Trading Technologies Integration Page.

deploy-tt

In the QuantConnect Cloud Platform, you can harness the QuantConnect Live Data Feed. For most users, this is substantially cheaper and easier than self-hosting.

Deploying Trading Technologies with LEAN CLI

Follow these steps to start local live trading with the Trading Technologies brokerage:

  1. Open a terminal in your CLI root directory.

  2. Run lean live "<projectName>" to start a live deployment wizard for the project in ./<projectName> and then enter the brokerage number.

    $ lean live "My Project"
    Select a brokerage:
    1) Paper Trading
    2) Interactive Brokers
    3) Tradier
    4) OANDA
    5) Bitfinex
    6) Coinbase Pro
    7) Binance
    8) Zerodha
    9) Samco
    10) Terminal Link
    11) Atreyu
    12) Trading Technologies
    13) Kraken
    14) FTX 
    Enter an option: 
    
  3. Enter the number of the organization that has a subscription for the Trading Technologies module.

    $ lean live "My Project"
    Select the organization with the Trading Technologies module subscription:
    1) Organization 1
    2) Organization 2
    3) Organization 3
    Enter an option: 1
    
  4. Enter your Trading Technologies credentials.

    $ lean live "My Project"
    User name: john
    Session password: ****************       
    Account name: jane
    
  5. Enter the REST configuration

    $ lean live "My Project"
    REST app key: my-rest-app-key
    REST app secret: ******************
    REST environment: my-environment
    
  6. Enter the market data configuration.

    $ lean live "My Project"
    Market data sender comp id:
    Market data target comp id:
    Market data host:
    Market data port:
    
  7. Enter the order routing configuration.

    $ lean live "My Project"
    Order routing sender comp id:
    Order routing target comp id:
    Order routing host:
    Order routing port:
    
  8. Enter whether FIX messages must be logged.

    $ lean live "My Project"
    Log FIX messages (yes/no): yes
    
  9. Enter the number of the data feed to use and then follow the steps required for the data connection.

    $ lean live "My Project"
    Select a data feed:
    1) Interactive Brokers
    2) Tradier
    3) Oanda
    4) Bitfinex
    5) Coinbase Pro
    6) Binance
    7) Zerodha
    8) Samco
    9) Terminal Link
    10) Trading Technologies
    11) Kraken
    12) FTX
    13) IQFeed
    14) Polygon Data Feed
    15) Custom data only
    To enter multiple options, separate them with comma.:
    

    If you select IQFeed, see IQFeed for set up instructions.
    If you select Polygon Data Feed, see Polygon for set up instructions.

  10. View the result in the <projectName>/live/<timestamp> directory. Results are stored in real-time in JSON format. You can save results to a different directory by providing the --output <path> option in step 2.

If you already have a live environment configured in your Lean configuration file, you can skip the interactive wizard by providing the --environment <value> option in step 2. The value of this option must be the name of an environment which has live-mode set to true.

Account Types

Tradier supports cash and margin accounts.

Order Types and Asset Classes

The following table describes the available order types for each asset class that Tradier supports:

Order Type Futures
MarketOrder Yes
LimitOrder Yes
StopMarketOrder Yes
StopLimitOrder Yes

Downloading Data

For local deployment, the algorithm needs to download the following datasets:

Brokerage Model

Lean models the brokerage behavior for backtesting purposes. The margin model is used in live trading to avoid placing orders that will be rejected due to insufficient buying power.

You can set the Brokerage Model with the following statements

SetBrokerageModel(BrokerageName.TradingTechnologies, AccountType.Cash);
SetBrokerageModel(BrokerageName.TradingTechnologies, AccountType.Margin);

Read Documentation

Fees

We model the order fees of TT, which are $0. To check the latest fees, see the Pricing page on the TT website.

Margin

We model buying power and margin calls to ensure your algorithm stays within the margin requirements and only submits valid orders to TT in live trading.

Read Documentation

Buying Power

The DefaultBrokerageModel allows up to 1x leverage on Futures trades.

Margin Calls

Regulation T margin rules apply. When the amount of margin remaining in your portfolio drops below 5% of the total portfolio value, you receive a warning. When the amount of margin remaining in your portfolio drops to zero or goes negative, the portfolio sorts the generated margin call orders by their unrealized profit and executes each order synchronously until your portfolio is within the margin requirements.

Slippage

Orders through TT do not experience slippage in backtests. In paper trading and live trading, your orders may experience slippage.

Fills

We fill market orders immediately and completely in backtests. In live trading, if the quantity of your market orders exceeds the quantity available at the top of the order book, your orders are filled according to what is available in the order book.

Deposits and Withdraws

You can deposit and withdraw cash from your brokerage account while you run an algorithm that's connected to the account. We sync the algorithm's cash holdings with the cash holdings in your brokerage account every day at 7:45 AM Eastern Time (ET).

     

whats-lean

     

LEAN Engine is an open-source algorithmic trading engine built for easy strategy research, backtesting, and live trading. We integrate with common data providers and brokerages, so you can quickly deploy algorithmic trading strategies.

The core of the LEAN Engine is written in C#, but it operates seamlessly on Linux, Mac and Windows operating systems. To use it, you can write algorithms in Python 3.8 or C#. QuantConnect maintains the LEAN project and uses it to drive the web-based algorithmic trading platform on the website.

Contributions

Contributions are warmly very welcomed but we ask you to read the existing code to see how it is formatted, commented and ensure contributions match the existing style. All code submissions must include accompanying tests. Please see the contributor guide lines.

Code of Conduct

We ask that our users adhere to the community code of conduct to ensure QuantConnect remains a safe, healthy environment for high quality quantitative trading discussions.

License Model

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.