726
edits
(40 intermediate revisions by 8 users not shown) | |||
Line 10: | Line 10: | ||
With Order Confirmation selected, each time that one or more orders are generated, a '''New Order''' dialog box displaying the orders will appear in the center of the desktop. To confirm order transmission, click '''Transmit Orders''', and to prevent order transmission, click '''Ignore Orders'''. | With Order Confirmation selected, each time that one or more orders are generated, a '''New Order''' dialog box displaying the orders will appear in the center of the desktop. To confirm order transmission, click '''Transmit Orders''', and to prevent order transmission, click '''Ignore Orders'''. | ||
* When more than one order is displayed in the '''New Order''' dialog box, it is not possible to transmit one order and ignore another; | * When more than one order is displayed in the '''New Order''' dialog box, it is not possible to transmit one order and ignore another; either all of the orders are transmitted, or all of the orders are ignored. | ||
* If neither '''Transmit Orders''' or '''Ignore Orders''' is selected before a new Market order or set of Market orders is generated, or before a new bar is started, the previous order or set of orders is ignored and not sent to the execution gateway. | * If neither '''Transmit Orders''' or '''Ignore Orders''' is selected before a new Market order or set of Market orders is generated, or before a new bar is started, the previous order or set of orders is ignored and not sent to the execution gateway. | ||
Line 18: | Line 18: | ||
=== Replace to Market Partially Filled Orders === | === Replace to Market Partially Filled Orders === | ||
<div style="background-color: #E3FBE5;">'''Note''': Since Multicharts 11 Beta 1 this option has been replaced with the [[Auto_Trading#Partially_Filled_Orders_Replacement|"Partially Filled Orders Replacement"]] controls.</div> | |||
When this option is turned on, the unfilled part of partially filled price order will be cancelled and the remainder will be converted into market order only when the order is no longer generated by the strategy or the set of orders generated by the strategy changes. It means if conditions for order generation are met on the next | When this option is turned on, the unfilled part of partially filled price order will be cancelled and the remainder will be converted into market order only when the order is no longer generated by the strategy or the set of orders generated by the strategy changes. It means if conditions for order generation are met on the next calculation, the unfilled part of the order will not be converted into market one, it will be sent as original order but with number of remained unfilled contracts. | ||
<br> | <br> | ||
Line 32: | Line 32: | ||
=== Optimize Order Flow === | === Optimize Order Flow === | ||
If One-Cancel-Others group is emulated in MultiCharts the situation when more than one order is filled is possible | If One-Cancel-Others group is emulated in MultiCharts the situation when more than one order is filled is possible. | ||
One Cancels Other (OCO) orders are the price orders sent in a group. When any of OCO orders is filled or partially filled, the system cancels or reduces size of other orders in this OCO-group. | One Cancels Other (OCO) orders are the price orders sent in a group. When any of OCO orders is filled or partially filled, the system cancels or reduces size of other orders in this OCO-group. | ||
Line 61: | Line 61: | ||
<br> | <br> | ||
=== Cancel Market Orders | === Cancel Expired Market Orders After X Seconds === | ||
Market orders that were not filled within the specified time (30 seconds by default) will be canceled. | |||
<div style="background-color: #E5F6FF;">'''Example''': | <div style="background-color: #E5F6FF;">'''Example''': Default 30 second timeout is set;<br>12:00:00 Strategy Calculation at close of bar # 51 - place market order to buy at open of next bar;<br>12:00:01 Strategy Calculation at open of bar # 52 - market order to buy is placed at broker;<br>12:00:10 Strategy Calculation at close of bar # 52 - no market order to buy at open of next bar should be placed;<br> Default 30 second countdown starts:<br>12:00:40 - market order is cancelled.</div> | ||
<br> | <br> | ||
Line 73: | Line 73: | ||
<br> | <br> | ||
=== Stop auto | === Stop auto trading if final status of an order is not received === | ||
There is a possibility of a situation when broker's API loses the order and does not send the status for it at all or sends it with a big delay. | There is a possibility of a situation when broker's API loses the order and does not send the status for it at all or sends it with a big delay. | ||
MultiCharts waits for the order status for 60 seconds by default (60 seconds between MultiCharts asking for the order status and receiving or not receiving the order status). If no feedback is provided for the order within 60 seconds by the broker - this order is considered to be cancelled/no longer present at the broker. In such situation the message '''“Didn’t receive final status for order”''' appears in the Order and Position Tracker window Logs tab. If the order was cancelled but the order generation conditions are still valid in the code – the signal generates the order and sends it to the broker again while the order generation conditions are met in the code. If the previous order (lost by the API/not sent to MC) is still active – an overfill is possible. | MultiCharts waits for the order status for 60 seconds by default (60 seconds between MultiCharts asking for the order status and receiving or not receiving the order status). If no feedback is provided for the order within 60 seconds by the broker - this order is considered to be cancelled/no longer present at the broker. In such situation the message '''“Didn’t receive final status for order”''' appears in the Order and Position Tracker window Logs tab. If the order was cancelled but the order generation conditions are still valid in the code – the signal generates the order and sends it to the broker again while the order generation conditions are met in the code. If the previous order (lost by the API/not sent to MC) is still active – an overfill is possible. | ||
When this option is enabled the auto | When this option is enabled the auto trading will be automatically turned off once the final status for an order sent by this strategy is not received. This option does not manage the open position/active orders. By default this option is disabled. | ||
<br> | <br> | ||
=== Stop auto | === Stop auto trading after X rejected orders === | ||
When enabled the auto | When enabled the auto trading will be automatically turned off after the specified number of the strategy orders is rejected. By default this option is disabled. | ||
<br> | <br> | ||
=== | === Price Order Emulation === | ||
Since '''MultiCharts 12''' it is possible to switch between native and emulated Stop, Limit and Stop-Limit orders in both auto trading and manual trading. This feature requires realtime data subscription on your broker account. When a Stop/Limit order is emulated - once the Stop/Limit price level is reached by the corresponding Ask/Bid or Trade prices, a market/limit order is sent to the broker correspondingly. When a Stop-Limit order is emulated - once the Stop price level is reached by the corresponding Ask/Bid or Trade prices, a Limit order is sent to the broker. In case Stop, Limit and/or Stop-Limit order emulation is enabled - the emulated OCO group is used, disregard the broker profile/auto trading broker plugin settings. | |||
To enable the Stop, Limit or Stop-Limit order emulation for automated trading select '''Emulate locally using Bid/Ask''' or '''Emulate locally using Trade''' from the dropdown list next to the corresponding order type. Leave the settings to '''Use native''' if using price order emulation is undesirable. | |||
In order to apply the changes one needs to disconnect the broker profile and reconnect it. | |||
<br> | <br> | ||
=== | === Self-Adaptive Trading === | ||
Check the Enable box to run periodic re-optimization of the strategy on new data. | |||
See the [[Self-Adaptive Trading]] page for more info. | |||
=== Unfilled Strategy Order Replacement === | === Unfilled Strategy Order Replacement === | ||
With the help of these options one can have unexecuted entry/exit price orders converted into market orders when the specified timeout is exceeded or upon bar close. | With the help of these options one can have unexecuted entry/exit price orders converted into market orders when the specified timeout is exceeded or upon bar close. | ||
The timer is launched depending on the option “Get | The timer is launched depending on the option “Get Real-Time Data from” and the mode of auto trading. | ||
* when set to “Broker”, the timer starts when the price at the broker touches the order’s price; | In '''SA''' mode: | ||
* when set to “Chart”, the timer starts when the order price is hit on a chart. | * when set to “Broker”, the timer starts when the '''price at the broker''' touches the order’s price; | ||
* when set to “Chart”, the timer starts when the order price is hit '''on a chart'''. | |||
Operation of these options depends on the [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]]: | Operation of these options depends on the [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]]: | ||
# IOG disabled - if the timer has started but the bar closed faster than timeout exceeded, then the price order is converted into a market order without waiting for the timeout to exceed; | # IOG disabled - if the timer has started but the bar closed faster than timeout exceeded, then the price order is converted into a market order without waiting for the timeout to exceed; | ||
#IOG enabled - each new tick is considered to be bar close. If the order’s price is touched and new tick comes in – the price order will be converted into market order at once without waiting for the timeout to exceed. | #IOG enabled - each new tick is considered to be bar close. If the order’s price is touched and new tick comes in – the price order will be converted into market order at once without waiting for the timeout to exceed. | ||
<div style="background-color: #E3FBE5;">'''Note''': If the order price is not hit at broker/chart then the order will not be converted.</div> | <div style="background-color: #E3FBE5;">'''Note''': If the order price is not hit at broker/chart then the order will not be converted.</div> | ||
<br> | |||
In '''AA''' mode conversion will start when an order is filled on a chart. | |||
The conversion algorithm is the following: | |||
# The Auto trading engine system receives an order filling event on the chart. | |||
#* If an identical order is now placed on the broker, the timer for conversion is launched. | |||
#* If this order is not placed on the broker yet, MultiCharts remembers that on this bar it is necessary to convert this particular order. | |||
# The Auto Trading engine places an order that needs conversion. The timer for conversion is launched. | |||
=== Partially Filled Orders Replacement === | |||
<div style="background-color: #E3FBE5;">'''Note''': Available since Multicharts 11 Beta 1, replaces “Replace to Market Partially Filled Orders” option.</div> | |||
When these options are enabled the unfilled part of partially filled price order will be cancelled and the remainder will be converted into a market order when the specified timeout is exceeded, or upon bar close. The timer is launched on the first partial fill event. | |||
<div style="background-color: #E3FBE5;">'''Note''': When timeout is set to 0, the order will be cancelled and replaced with a market order once partial fill event occurs.</div> | |||
<br> | <br> | ||
Line 120: | Line 131: | ||
# When Market Position Changes. | # When Market Position Changes. | ||
# When an Order is Filled. | # When an Order is Filled. | ||
# When an Order is Rejected. | |||
<div style="background-color: #E3FBE5;">'''Note''': Without enabled [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]] the strategy will be recalculated, but it will place '''no new''' orders intrabar because of this setting.</div> | <div style="background-color: #E3FBE5;">'''Note''': Without enabled [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]] the strategy will be recalculated, but it will place '''no new''' orders intrabar because of this setting.</div> | ||
<div style="background-color: #E3FBE5;">'''Note 2''': If strategy generates '''both entry and exit orders at the same time when there is no market position opened''', only the entry order will be sent. When the market position is opened, the exit orders will be placed intrabar even without enabled [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]], no matter if this feature is used or not.</div> | <div style="background-color: #E3FBE5;">'''Note 2''': If strategy generates '''both entry and exit orders at the same time when there is no market position opened''', only the entry order will be sent. When the market position is opened, the exit orders will be placed intrabar even without enabled [[Signal Settings#Intra-Bar Order Generation|Intra-Bar Order Generation (IOG)]], no matter if this feature is used or not.</div> | ||
Line 126: | Line 138: | ||
=== Get Real-Time Data from === | === Get Real-Time Data from === | ||
This option affects special orders monitoring and defining the moment to convert price orders into market ones. | This option affects special orders monitoring and defining the moment to convert price orders into market ones. | ||
<div style="background-color: #E3FBE5;">'''Note''': Special trailing stop order ('' | <div style="background-color: #E3FBE5;">'''Note''': Special trailing stop order (''SetDollarTrailing'') will be calculated based on the distance from the entry price order to the real-time price. The entry price is defined by the broker. In MC this price is the real price of order fill. It doesn't depend on trading mode or the source of real time.<br>''i_OpenEquity'', ''OpenPositionProfit'' keywords are not affected by this option, they are always calculated from chart prices.</div> | ||
<div style="background-color: #E5F6FF;">'''Example''': | <div style="background-color: #E5F6FF;">'''Example''': | ||
Auto trading mode is Async. (see [[Understanding Automated Trade Execution]]), Get Real-Time from Chart is selected, there is an executed entry and a trailing stop is sent. The trailing order price is calculated based on the entry order fill price at the broker and the real-time price from the chart.</div> | |||
# From Broker: Asks and Bids are taken from the connected broker. | # From Broker: Asks and Bids are taken from the connected broker.<div style="background-color: #E3FBE5;">'''Note''': '''From Broker''' option is not available for asynchronous mode [AA]</div> | ||
# From Chart: depends on the BackTesting Mode:<BR> | # From Chart: depends on the BackTesting Mode:<BR> | ||
::a) If it is Classic Backtesting, then the data is taken from the data series 1;<BR> | ::a) If it is Classic Backtesting, then the data is taken from the data series 1;<BR> | ||
Line 139: | Line 151: | ||
=== Mode Selection === | === Mode Selection === | ||
* In '''synchronous''' mode '''[SA]''' one can see the same open market position and active orders on the chart as at broker. All orders generated by historical calculation during are wiped out from the chart when auto execution is turned on. Executed order is displayed only if it has been executed at broker and the final status of the order has been received by MultiCharts. To use synchronous mode for auto trading select '''Entries/Exits are based on the execution confirmation by the broker (Sync)'''<br> <div style="background-color: #E3FBE5;">'''Note''': Chart market position and broker market position are in synch only if no more than one chart is auto trading without any manual orders on a particular symbol connected a particular broker account, assuming that at the moment the automation was turned the broker market position was flat or, if it was not flat at broker, assigned manually on start of auto trading in MC to match it (see [[#Assign_the_Initial_Market_Position_at_the_Broker_Settings|Assign the Initial Market Position at the Broker Settings]]). If more than 1 chart is auto trading in [SA] mode and/or manual trading is used as the same time on the same symbol at broker, chart can easily get out of synch. To learn more, see [[Trading from Multiple Charts on One Instrument]].</div><br> | * In '''synchronous''' mode '''[SA]''' one can see the same open market position and active orders on the chart as at broker. All orders generated by historical calculation during Backtesting are wiped out from the chart when auto execution is turned on. Executed order is displayed only if it has been executed at broker and the final status of the order has been received by MultiCharts. To use synchronous mode for auto trading select '''Entries/Exits are based on the execution confirmation by the broker (Sync)'''<br> <div style="background-color: #E3FBE5;">'''Note''': Chart market position and broker market position are in synch only if no more than one chart is auto trading without any manual orders on a particular symbol connected to a particular broker account, assuming that at the moment the automation was turned the broker market position was flat or, if it was not flat at broker, assigned manually on start of auto trading in MC to match it (see [[#Assign_the_Initial_Market_Position_at_the_Broker_Settings|Assign the Initial Market Position at the Broker Settings]]). If more than 1 chart is auto trading in [SA] mode and/or manual trading is used as the same time on the same symbol at broker, chart can easily get out of synch. To learn more, see [[Trading from Multiple Charts on One Instrument]].</div><br> | ||
* In ''' asynchronous ''' mode ''' [AA] ''' the strategy on the chart starts auto trading based on the historically calculated orders and open position, displaying all generated by the script orders on chart even if an order was not executed at broker. In AA strategy on chart acts separately from broker.<br>To use asynchronous mode for auto trading select '''Entries/Exits are independent of the execution status at the broker (Async)''' | * In ''' asynchronous ''' mode ''' [AA] ''' the strategy on the chart starts auto trading based on the historically calculated orders and open position, displaying all generated by the script orders on chart even if an order was not executed at broker. In AA strategy on chart acts separately from broker.<br>To use asynchronous mode for auto trading select '''Entries/Exits are independent of the execution status at the broker (Async)''' | ||
Line 145: | Line 157: | ||
====Understanding Strategy Calculation in Different Modes==== | ====Understanding Strategy Calculation in Different Modes==== | ||
There are 3 separate market positions when strategy is auto | There are 3 separate market positions when strategy is auto trading in MultiCharts: | ||
# '''Broker position'''. This is '''net position for a traded security at your broker account''' that takes into consideration all trades. It can be seen on [[Order and Position Tracker#Open Positions Tab| Open Positions tab of Order and Position Tracker]]. | # '''Broker position'''. This is '''net position for a traded security at your broker account''' that takes into consideration all trades. It can be seen on [[Order and Position Tracker#Open Positions Tab| Open Positions tab of Order and Position Tracker]]. | ||
# '''Auto | # '''Auto trading engine position'''. This is '''inner position of the strategy on a specific chart''' calculated by the software. It can be seen on [[Order and Position Tracker#Strategy Positions tab| Strategy Positions tab of Order and Position Tracker]]. | ||
# '''Chart position'''. This is the '''position generated by orders visually executed on chart'''. It has nothing to do with open position horizontal drawing shown when you open [[Chart Trading]] panel. | # '''Chart position'''. This is the '''position generated by orders visually executed on chart'''. It has nothing to do with open position horizontal drawing shown when you open [[Chart Trading]] panel. | ||
When you auto trade '''in SA (sync. mode) the 2 and 3 are the same''', what | When you auto trade '''in SA (sync. mode) the 2 and 3 are the same''', what you see on the chart is synchronized with auto trading engine. When '''you use AA (async. mode), you may have to deal with 3 different positions''': what you have on broker, what you see on chart, what MC thinks it is. | ||
====Market Position Checking Keywords==== | ====Market Position Checking Keywords==== | ||
# [[MarketPosition_at_Broker]]. Returns '''broker position'''. | # [[MarketPosition_at_Broker]]. Returns '''broker position'''. | ||
# [[MarketPosition_at_Broker_for_The_Strategy]]. Returns MC '''auto | # [[MarketPosition_at_Broker_for_The_Strategy]]. Returns MC '''auto trading engine position'''. | ||
# [[MarketPosition]]. Returns '''chart position''' (only direction). | # [[MarketPosition]]. Returns '''chart position''' (only direction). | ||
<br> | <br> | ||
===Assign | ===Assign Initial Market Position to Strategy=== | ||
When auto trading is turned on, a strategy starts working with a specific market position.<br> | |||
Depending on the mode of auto trading, this position can vary. In [SA] mode it is always flat on chart when you turn it on, but in [AA] mode it can be short, flat or long, depending on backtesting trades (to learn more see [[#Mode_Selection|Mode Selection]]).<br> | |||
This option allows to control the initial market position for the strategy to start calculation and order generation with when you turn on auto trading. | |||
The available options are: | |||
* | :* '''Flat ''' - the initial position will be flat.<br> <div style="background-color: #E3FBE5;">'''Example''': According to your backtesting, the current position is 1 contract long and your real broker position is 1 contract short. With this option you will have +1 on your chart, flat for auto trading engine within the software and -1 short at broker, when the automation is turned on. </div> | ||
:* '''From Chart''' - the initial position will be the same as the position on the chart. | |||
:* '''From Broker''' - the initial position will be the same as the actual position at the broker when automation is enabled. | |||
:* '''Always show dialog window''' - to get the dialog every time the automation is enabled, no matter what the strategy position is at that moment.<br> <div style="background-color: #E3FBE5;">'''Note''': It is extremely important for [SA] mode, because it is always flat when automation is turned on in [SA].</div> | |||
:* '''Show dialog window only if market position on chart is different from broker''' - to get the dialog when the chart and broker positions do not match. | |||
=== Set TIF for order types === | |||
* | Select the '''Time in Force (TIF)''' for each order type: | ||
* Market | |||
* Limit | |||
* Stop | |||
* Stop-Limit | |||
< | |||
These controls work as a dropdown list with all TIFs supported in MultiCharts: | |||
* Default (corresponds to the value from the broker plugin settings) | |||
* DAY | |||
* GTC | |||
* GTD (includes the additional control to select the number of days) | |||
* IOC | |||
* FOK | |||
* AON | |||
The list depends on what TIFs are supported by the broker. | |||
The selected TIF values will be used to send orders into the broker plugin. | |||
If the selected TIF is not supported by a broker profile, the value from the [https://www.multicharts.com/trading-software/index.php?title=Auto_Trading#Select_Broker_Plug-in broker plugin settings] will be taken. | |||
<div style="background-color: #E3FBE5;">'''Notes''': | |||
# Some brokers may change TIF on their end – MultiCharts doest not regulate it. | |||
# The described behaviour is ''not applicable'' to backtesting. | |||
</div> | |||
===Select Broker Plug-in=== | ===Select Broker Plug-in=== | ||
Line 217: | Line 250: | ||
* Any strategy parameters are changed | * Any strategy parameters are changed | ||
* Any Auto Trading parameters are changed | * Any Auto Trading parameters are changed | ||
* Connectivity between MultiCharts and the execution gateway has been lost and the disconnection time exceeded the specified acceptable level. | * Connectivity between MultiCharts and the execution gateway has been lost and the disconnection time (of the broker profile) exceeded the specified acceptable level. | ||
* [[Auto_Trading#Stop_auto-trading_if_final_status_of_an_order_is_not_received|"Stop auto trading if final status of an order is not received"]] option has come into effect | |||
* [[Auto_Trading#Stop_auto-trading_after_X_rejected_orders|"Stop auto trading after X rejected orders"]] option has come into effect | |||
* You have got a [[Fail-Watch and Trading System Warnings]] alert | |||
<br> | |||
=== Pending Order Cancellation upon Termination of Auto Trading === | === Pending Order Cancellation upon Termination of Auto Trading === | ||