The CQG XL Toolkit has been upgraded to include functionality to place batch orders. A batch order is a list of orders that will include the accounts, symbols, action (buy or sell), qualifiers such as market, limit or stop orders and other important details. The XL Toolkit permits the user to place the orders as parked or sent directly to the CQG Gateway. In addition, Algo Orders can be included in the batch orders. The Algo Orders and the parameters (as a CSV file) can be used. This functionality is detailed later in the post.
First, in order to use the XL Toolkit the user must contact their FCM and request the XL Toolkit enablement. You can download the XL Toolkit here. Once the XL Toolkit is installed you Logon using your trading credentials.
data:image/s3,"s3://crabby-images/5be74/5be74905c25d6aa171598391f6f84d258a6c7623" alt="Batch F1"
Notice in the image above there is a greyed out button "Place Orders." This button is used to send the orders once the spreadsheet has this function "=CQGXLPlaceOrder()" with all of the Obligatory Parameters entered. The function is a subset of the XL Toolkit's Orders and Positions functions.
Enter this function in an Excel cell:
=CQGXLPlaceOrder()
Click the "fx" parameter in the formula toolbar and this dialog opens.
data:image/s3,"s3://crabby-images/2b2ec/2b2ecd8c4c1cc598ad2acce745a1310f13845ed5" alt="Batch F2"
This table details the full list of the function arguments (not all are required):
Index |
Disambiguates identical order placement data (enter 1, 2, 3, etc.) |
Account ID |
Account ID from XL Toolkit Account Data |
Side |
Buy or Sell |
Size |
Total positive size of the order |
Instrument |
Symbol |
Type |
MKT/LMT/STP/STL |
Stop price |
For STP or STL |
Limit price |
For LMT or STL |
Duration |
DAY/GTC?GTD |
Good till date |
GTD Date (Local to the Exchange) |
Algo Strategy |
Exact Name of the Algorithmic Strategy |
Algo Parameters |
CSV File |
Speculation |
Used with contracts that require speculation type to be provided: Speculation/Arbitrage/Hedge |
Open/Close |
Used to determine open or closing a position. Open/Close/Close Yesterday |
Activate at |
Time when the order should be sent to the exchange |
Comment |
Order Comment |
Park |
Default is Park, False to not Park |
The second argument (Account ID) is found using the XL Toolkit. Select Account data and then Account ID and Account Name, From the output select the appropriate Account ID and you can reference the cell's location in the Functions Arguments dialog.
data:image/s3,"s3://crabby-images/4d4c6/4d4c639c6f68a6826e9d8a4f9ad3729c2bf15c0d" alt="Batch F3"
This sample downloadable spreadsheet with more details is available here.
data:image/s3,"s3://crabby-images/7fbf1/7fbf16cc256bfd654e26eb2c3827614fee595d49" alt="Batch F4"
Using Algo Orders from Desktop or CQG One for Batch Orders
The XL Toolkit Batch Order functionality can place Algo Orders.
data:image/s3,"s3://crabby-images/bf62e/bf62ec95a02b073c7b2121e8e58f028d8f4d629e" alt="Batch F5"
This table lists the Algo Orders and a brief description:
Name |
Algo Description |
CQG Arrivalprice |
Arrival Price |
CQG Iceberg |
Iceberg |
CQG IcePegger |
Series of Peg Orders |
CQG IceSlicer |
Exchange Iceberg Slicer |
CQG OffsetPayUp |
OffsetPayUp |
CQG OffsetTick |
Tick Order as Offset |
CQG PayUp |
Probability-Based PayUp Logic |
CQG Peg |
Join Best Levels |
CQG Riceberg |
Random-Sized Synthetic Iceberg |
CQG Roll |
Multi-Leg Arrival Price with PayUp Logic |
CQG RTWAP |
Randomized Time-Weighted Average Price |
CQG SLArrival |
Stop Limit Arrival Price |
CQG SLIceberg |
Stop Limit Synthetic Iceberg |
CQG SLSnipe |
Stop Limit Sniper |
CQG Snipe |
Liquidity-Taking Sniper |
CQG Tick |
Tick-BasedPayup Logic |
CQG TWAP |
Time-Weighted Average Price |
CQG Vola |
Volatility Order |
CQG VWAP |
Volume-Weighted Average Price |
More information detailing CQG Algos is available here.
The dialog states that the exact name of the Algo strategy must be used.
data:image/s3,"s3://crabby-images/1f83f/1f83f64b299b1200a03d8c93fba093eb136594ee" alt="Batch F6"
Algo orders have parameters which must be included in the batch order as a CSV file. The CSV file is saved to the hard drive.
data:image/s3,"s3://crabby-images/e76ea/e76ea987b211cd09ea13a03b1b532bfbbf09f18e" alt="Batch F7"
Here are the steps to creating the parameters CSV file. Basically,
- Place a parked configured Algo Order using the CQG Algo Order Ticket
- Copy the parameters from the Order information window
- Paste it into Excel and save it as a CSV file.
Therefore, open the CQG Algo Order Ticket. Log in, select "Parked" and select the Algo you want. This example is using the CQG Iceberg.
data:image/s3,"s3://crabby-images/13b4b/13b4b54d1ede63ebc1c8232d654f66bc15462fd1" alt="Batch F8"
Set the parameters for the Algo Order. Place the Parked Algo Order.
Note: Above, you can set the Start Time and the End Time as part of the Algo Order parameters. The time zone used by the Algo Orders Engine is UTC time (Coordinated Universal Time). It is converted from local time to UTC. Therefore, when using your CSV parameters file with Start and End Times the time zone to use is UTC.
data:image/s3,"s3://crabby-images/25c92/25c923e81c7152df97d941f50df9dec2579cb283" alt="Batch F9"
Select the parked order, right-click then select Order Info.
data:image/s3,"s3://crabby-images/9d992/9d9924dbf3b6fdd12317b0292b865f1be846b14e" alt="Batch F10"
The highlighted text is the parameters information used. Select copy to clipboard.
Open a blank Word document and "paste merged formatting"
data:image/s3,"s3://crabby-images/4c71d/4c71daaf2065238460be7ad7e7f504247a25cb01" alt="Batch F11"
The parameters are CQG_MaxQty 10 and CQG_MinQty 5. However, notice that Word displays the parameter name and the value on separate rows. For the Excel CSV file the parameter name has to be the first cell in a row and the parameter value has to be in the next cell in the same row.
Here are the steps in Word to format the correctly format parameters.
CQG_MaxQty
10
CQG_MinQty
5
Select the parameters and replace paragraph returns with tabs.
data:image/s3,"s3://crabby-images/2e151/2e1510d69a4c9da85549c8e4fcf4fe9cfe5cc8d8" alt="Batch F12"
Returns this:
CQG_MaxQty 10 CQG_MinQty 5
Select the above and replace the "tabs and CQG" with "paragraph returns and CQG".
data:image/s3,"s3://crabby-images/75662/75662f8eeeb83a1cf57f2277e9308e1f55a3af85" alt="Batch F13"
New formatted parameters can be C&P into Excel and saved as a CSV file.
CQG_MaxQty 10
CQG_MinQty 5
data:image/s3,"s3://crabby-images/f2cb8/f2cb8ad0fee60867755e65d72c90dc75f1029262" alt="Batch F14"
Save the file as a CSV file to the C Drive. Then enter the file's path in the cell for Algo Params.
data:image/s3,"s3://crabby-images/84d03/84d03ac712d72947bc8fa7287991f7da7b68e5b1" alt="Batch F15"
Once your spreadsheet is completed, then to send the orders in go to the XL Toolkit on the Excel Ribbon and select "Place Orders."
data:image/s3,"s3://crabby-images/e72c5/e72c5d3d03dc97230bae82f16419a2966f8ef5e0" alt="Batch F16"