MF8 Manual Eng
MF8 Manual Eng
MF8 Manual Eng
Contents 3
Table of Contents
Foreword 0
Part I Introduction 6
1 What
...................................................................................................................................
is MarketFeeder Pro 6
3
4 MarketFeeder Pro 8
2 Auto-Dutching
................................................................................................................................... 62
3 Auto-Greenup
................................................................................................................................... 67
1 Program
...................................................................................................................................
Logs 230
2 Trigger
...................................................................................................................................
Logs 230
3 Statement
................................................................................................................................... 231
Index 279
5
6 MarketFeeder Pro 8
1 Introduction
It combines very basic functions, such as market monitoring and back & lay bets, with the powerful
instruments of triggered betting, Auto-Greenup and Auto-Dutching.
What makes it different from other trading bots is that it gives you full freedom in configuring and
operating your trading environment. I.e. it offers many market viewing modes, various charts and
other settings and can be adjusted to specific needs. It also helps you implement unlimited betting
strategies. Basically any staking plan can be realised with MarketFeeder Pro using simple
commands in English which you key in to a convenient interface. MarketFeeder Pro can be called a
pioneer of triggered betting among BetFair bots.
The first version of MarketFeeder Pro was released in 2004, and since then it has gathered
numerous devoted users around it. The software is operating through the authorised BetFair API
channel and its security has been proven by BetFair's technicians.
2 Betting Glossary
Here are a few terms to help you understand the basics of trading with MarketFeeder Pro.
2.1 Greening Up
Greening up means placing two or more opposite bets on a selection in such a way as to generate
an equal profit regardless of the event outcome.
This operation requires that you back at a higher price and lay at a lower one (buy cheap, sell high).
This operation is a reverse of distributing loss.
See 10 facts about greening up in MarketFeeder Pro.
Greening up is a form of trading out.
You can also green up with unequal profit, specifying a P/L ratio % that is different from the default
50%.
A 100% P/L ratio means that all of the profit or loss generated from the trade-out bet will end up on
this selection:
A 0% P/L ratio, on the contrary, means that the selection will be left with zero P/L, and the entire
pool of profit/loss will be distributed among other selections.
Distributing loss with a 0% P/L ratio means, in effect, eliminating the loss.
The default P/L Ratio throughout the program settings is 50%.
2.5 Dutching
Dutching (also sometimes referred to as hedging) means placing bets of the same type (i.e. all
back or all lay) on two or more selections with an intention to generate equal profit if any of them
wins (if you are backing) or if any of the other selections wins (if you are laying).
3 Login Window
When you start MarketFeeder Pro, you are greeted with the Login Window.
It is needed to authorise you as a BetFair user. It also allows you to choose a Settings Profile to
load.
The software mode determines what data you will be working with during your session.
BetFair mode - all markets are real-time markets taking place on the exchange. You can monitor
them and place either real bets or test bets. You will need a licence for MarketFeeder Pro.
Time Machine mode - all markets are historical markets recorded and run inside Time Machine,
an utility for backtesting strategies. You will need both a licence for MarketFeeder Pro and Time
Machine.
Time Machine mode ONLY - all markets are historical markets recorded and run inside Time
Machine, an utility for backtesting strategies. You will need a special combined licence for
MarketFeeder Pro in Time Machine mode only.
You can choose to log in without using a browser, by clicking the "built-in form" link:
In this case you only have the option to enter your username and password.
If you have enabled the 2-step authentication for your account (you can do it on BetFair's website),
you will need to enter a 6-digit access code each time you log in.
You can remember the username in encrypted mode if you do not want to re-enter it every time.
If you are a resident of Romania or Sweden, please choose your country from the list:
You can run two or more copies of MF Pro, under the same username or different usernames. If you
are trying to launch an instance of the software when another instance is already running, you will
see the following message window:
Read what it says carefully and press "Yes" if you want to go ahead. When it shows the login
window, be sure to select a settings profile which you have not selected in any other running copies
of MF Pro. If you choose a profile that is already being in use, the program will not be able to
function correctly.
You might want to copy your settings for this purpose. Use the "Clone" button to make an exact
copy of your settings for the new instance of MF Pro.
4 User Interface
The MarketFeeder Pro window is divided into three main areas: Main Menu, Market List and Trader's
Area.
Additional tools and add-ons, such as Market Locator, Triggers Editor etc. can be called and opened
from the main window. See the corresponding reference for each tool of interest.
The orange sliding window contains your licence information and a link to our web site to prolong it:
Your current balance and available funds are displayed in your currency right underneath this
window. Click on the "Available Funds" link to update your funds from the server.
You can hide your available funds and exposure, for instance, if you need to make a snapshot of the
program's window. To do this, hold Alt on your keyboard and click on any of the three labels.
To see your Account Statement press the "Statement" link, and to clear your statement files, press
"Clear Statement".
Your test funds and balance are displayed next. To add or withdraw funds from your test account,
click on the "Transfer Test Funds" link.
To turn Test Mode on/off use the next link. If Test Mode is on, it will say "Test Mode is ON". The
program will ask your additional confirmation if you decide to switch it off.
To clear all test bets placed in the program (in all markets), use the "Clear Test Bets" link. It will
delete all matched and unmatched test bets from the memory.
To open the window with the currently active trigger file, press the "Triggers" link. To activate /
deactivate triggers, use the bulb button next to it.
Then you can access User Variables, Settings and Connection Monitor by pressing the
corresponding links.
To open Excel (if installed) and / or connect MarketFeeder Pro to it, press the "Excel" link.
To browse through the program's log files (that includes action log, trigger logs and statement), press
"Program Logs".
Finally, to control the tooltip hints by turning certain types of them on/off, use the button with the
Event Tree
My Markets
You can hide or show the whole area whenever you want, to increase the space available for
displaying market information.
To add many markets in one go, provided you know what kind of markets they are, use the Market
Locator add-on by pressing Market Locator.
To quickly load markets from a previously saved Market Locator search template, right-click Market
Locator and choose the necessary template. Please note: it may take some time before the
markets are found and added to your list.
The Event Tree is very similar to the Sports menu on the BetFair website.
Navigate down to the markets of your interest and add them to your list by selecting them in the
tree.
4.2.2 My Markets
This tab contains the list of markets that are currently available for monitoring and some additional
controls.
You can only monitor or place bets in the markets that are on My Markets list.
Make sure you add your markets before you start trading.
The small menu on top of the list allows you to:
open the My Markets list from a text file
save the My Markets list to a text file
display full or short names of markets
sort markets by starting time (earliest first)
sort markets alphabetically by name.
The "Import selections for auto-trading" button allows you to apply automated betting only to the
markets and selections of your choice, ignoring all others.
You can save My Markets to a text file for a later use or likewise load them from a previously saved
text file.
This is very convenient and will save you loads of time if you want to switch between lists of markets
from different sports, such as football markets or horse racing markets.
Press the pink Save market list button to save your current My Markets list to a text file. The
format of the file is as follows:
{sport id1} {market_id1}
{sport id2} {market_id2}
...
The market IDs are separated from the sport IDs with the Tab character.
If you know the IDs (they are freely available on BetFair's website for example), you can generate
this file on your own, using any text editor or Excel.
Press the blue Open market list button to open a previously saved list and load it into My Markets.
If any of the market IDs do not correspond to an existing market (or the market is already closed),
they will be ignored.
Market Actions
You can apply a bulk action to a group of selected markets. Tick the right group, e.g. "All markets"
or "Selected only" and press the button with the corresponding action name.
Start - start refreshing the chosen market group
Stop - stop refreshing the chosen market group
Settle - settle the chosen market group in Test Mode and assign winner(s) according to the Test
Mode options.
Reset - if any of the chosen market group is in a Settled state, it will be reset back to Idle (until
the next refresh when its state can change).
Delete - delete one or more selected markets.
The Delete action is different in that it will delete the markets you have actually selected with your
mouse.
Market Statuses
Popup Menu
There is a menu that comes up when you right-click on the selected markets.
The options in this menu duplicate some buttons, and there is also an option to apply default
settings to selected markets.
You can look up markets that contain selection(s) with a certain name.
These criteria can be anything from very simple ones, like markets from a certain country or
belonging to a certain sport type, to very sophisticated conditions, like name containing some
pattern, or number of selections being no less than 10 etc.
To open the Market Locator, press this button in the application window.
A default template will open in the Locator window. We have designed several most popular
templates for you to start with. You can browse through them using a drop-down list.
Choose the countries you are interested in, and then the sports and particular types of markets.
If you need additional conditions, use "Step 2 - Market Properties" to add them. You can key in the
conditions that apply to the following objects:
Market
Any Selection
All Selections
Don't forget to let the program know whether all of these conditions must be met or at least one of
them. Press "Search" once you've finished configuring the search parameters.
When the appropriate markets are found, select those you want to add to your list and press "Add to
My Markets".
Adding to My Markets
You have additional options to control how Market Locator will add the markets it has found to your
My Markets list.
Tick this box to never add markets that have been previously deleted either manually, with a trigger,
or with any other program setting. This will come handy if you search markets at certain time
intervals, and Market Locator keeps adding back some markets that you are no longer interested in.
Tick this box to make Market Locator delete all entries (and any test bets on them) from My Markets
prior to adding the new markets it has found.
You can make the program search and add markets by a specified template automatically. To do
this, configure these settings in the "Monitoring Options" tab.
To see additional information about this market, such as its rules, or the venue or withdrawn runners
(if any), press the "Market Info" button.
If, for any reason, your BetFair account is restricted and market data is refreshed with a delay, with
no selection volume available, you will see the relevant warning in that window:
Sometimes you might need to manually change the starting time of a market. To do this, click on its
starting time label and input a new time.
The default back and lay amounts define the sizes of all one-click bets in this market. The same
amounts will also be used in the Ladder interface.
One-Click Betting
You can back at the current lay price and lay at the current back price by pressing Shift + left
button of your mouse.
To place a bet at the best available price (at 1.01 for back bets and at the maximum possible price
for lay bets, according to the maximum best lay price settings), press Ctrl + left button of your
mouse on the corresponding back or lay bet button.
If you are in the Engineer Mode, you can also place a back bet with a predefined payout or a lay bet
with a predefined liability by pressing Alt + left mouse button.
If you want to turn one-click betting off for safety reasons, do it in the "Betting Options" tab of the
Settings.
Market Refresh
A market can be refreshed at two different rates before it begins (when it is in "Idle" state) and after it
turns In-Play. The minimum value you can put in these fields is 0.3, that is a market can be
refreshed once in up to 0.3 sec.
Apart from the usual sorting order of selections that BetFair offers, you can sort them by different
parameters. Click on the "Sort selections" button shown in the above picture to bring up this menu.
Choose the sorting order from the list.
To call up the Ladder interface for any chosen selection, click on that selection's name.
Selections' profit/loss figures are displayed underneath their names. If there are any matched or
unmatched bets placed on a particular selection, you can view them by clicking on its P/L labels.
For your convenience, the minimum and maximum P/L figures are highlighted.
You can change the colour and font of the betting buttons in the "Look & Feel" tab of the Settings.
Market Modes
Brief Mode
Full Mode
Race Mode
Engineer Mode
Basketball Scores
If a market belong to a basketball match, and provided you turned on the option to "Download Match
Score", you will see the current scores beneath the team list (or selection list if you are looking at
markets such as Handicap).
Football Scores
If a market belong to a football match, and provided you turned on the option to "Download Match
Score", you will see the current scores beneath the team list (or selection list if you are looking at
markets such as Correct Score or Over/Under).
Tennis Scores
If a market belong to a tennis match, and provided you turned on the options "Download Match
Score" and "Download Tennis Scores", you will see the current scores beneath the selection list.
In Brief Mode you get to see all basic information about the selections in the chosen market.
You can see the three best available prices for backing and laying. Underneath them the total
amounts offered at those prices are displayed.
If the market supports SP betting, you will also see the near and far SP, and when that market turns
In-Play, they will be replaced with the actual SP.
In between the prices you can see a small chart that by default shows the change of the back price
over time. You can configure this chart in the Chart Editor.
In this mode the top line of each selection is the same as in Brief Mode.
The bottom line, however, contains the following data:
The Race Mode is mostly convenient for viewing races, e.g. a Greyhound or horse race, especially at
In-Play.
It represents each selection as a coloured bar whose length helps you determine which runner is
currently ahead or behind.
If "silks" are available for the market, the colour of the bar will be extracted from the jockey's clothes.
Small arrows at the end of the bar show you in which direction the current back price is moving. A
red arrow indicates that the price is growing, and so the runner loses its position. A green arrow is a
sign that the price is shortening, and so the runner is gaining speed.
If available, silks data will be displayed under the bar. The order in which they appear there can be
edited in the "Monitoring Options" of the Settings.
Custom Cells
You can add up to 10 customizable cells per each selection. These cells can contain arithmetic
expressions, user and trigger variables, and functions. You can edit the formula of each variable by
clicking the corresponding value. You can also set the default formulas for these cells in Settings ->
General Options -> Edit Default Engineer Mode Values.
These cells allow you to keep an eye on some important properties and parameters of each
selection.
To copy the value in a particular cell, right-click on it and choose "Copy to Clipboard":
Fast Betting
In Engineer Mode you can place a one-click back bet with a predefined payout or a lay bet with a
predefined liability. The values of the payout and liability are set up in the header line of the market.
Press Alt + left mouse button to place a bet with the preset payout or liability.
You can place bets on all selections in the market in one go, just press either "Back all at price" or
"Lay all at price", having specified the price you want to back or lay at, next to those buttons. The
program will make bets with the default back or lay amount in this market. To bet with a fixed
payout/liability, hold Alt while pressing the "Back all" or "Lay all" buttons.
Trade out
In Engineer mode, you can quickly trade out (close open bets) an individual selection by pressing
the Trade-out button:
The figures on that button show what happens to the selection's P/L if the trade-out bet is matched:
upper figure: the P/L that the selection will have once the trade-out bet is matched. In Win
markets, this figure will be affected by bets placed on other selections. In Place markets, the
upper figure is equal or nearly equal to the lower one.
lower figure: the net winnings or losses you will get from this trade-out. When greening up, this
figure will be positive; when distributing loss -- negative.
Compare to a trade-out button in a Place market:
Press the "Trade out all" button to close all your open bets at once, by greening up or distributing
loss on all eligible selections.
You can specify the P/L Ratio% for the trade-out.
If P/L Ratio is 50%, the P/L on all selections will be equal, therefore the market P/L will not depend
on what selection wins. You will see a single figure with that P/L on the "Trade out all" button:
If P/L Ratio is different from 50%, the total market P/L will depend on what selection wins, as the
profit/loss distribution will be unequal. You will see the minimum and maximum potential P/Ls on the
"Trade out all" button:
If the minimum P/L is positive, the figure will be green, otherwise red.
When you press that button, the trade-out bets will be calculated and placed automatically, and the
resulting P/Ls will match the ones predicted:
Enter the price and amount of the bet and specify additional parameters, such as persistence.
Use up and down arrows to correct the price manually.
To quickly enter the selection's current price, click any of the three back or three lay prices in the
top of the Betting Interface:
If there are any matched bets on the selection, press Trade out to green up or distribute loss
immediately (whether it'll be profit or loss will depend on the selection's prices). Use P/L ratio % to
adjust profit/loss distribution. By default, it is 50%, i.e. P/L is distributed equally across all
selections.
After the trade-out bet is placed and matched, you should get a P/L picture very close to the 'What-
If' figures that appeared when you moved your mouse over the Trade out button:
If there are any matched bets on the selection, press Attempt to green up to place an open
(unmatched) green up bet with the desired profit. You can enter either profit % or profit ticks. Select
the necessary option from the drop-down list. Use P/L ratio % to adjust profit/loss distribution. By
default, it is 50%, i.e. P/L is distributed equally across all selections.
When you press Attempt to green up, the program will place a bet that will likely stay unmatched
for some time.
When (or if) the bet is matched, you should see the same P/L as 'What If" figures:
To completely eliminate the loss on the chosen selection by increasing the loss on all other
selections in the market, press Eliminate Loss.
To distribute the selection's extra profit (if there's a "free bet" on the selection from a previous trade-
out) equally between all selections in the market, press Distribute Profit.
If you just want to see how the market's profit or loss will change from any of the betting action
above, without placing the actual bet, move your mouse over the corresponding button to see the
"What If" P/L next to each selection's actual P/L.
The time period of each chart can be defined as a number of market refreshes (define by the
market's refresh rate) or as a fixed number of minutes.
To show / hide the Chart Editor control bar, press the push/pop button.
To apply the changes to the current selection only, press "Apply". Or to apply them to the whole
market, press "Apply to Market".
Trends
By default all charts are overlayed by a grey trend curve. The trend gives you a more accurate idea of
where the market is moving as it smoothes the data curve with its occasional peaks and slumps.
You can experiment with the smoothness level of the trend line by editing its "Smoothing"
parameter.
Tip! To get a numerical value of a selection's volume trend, use the vol_trend variable. For the
current value of a selection's last traded price trend, use lt_trend.
This area is divided into Matched Bets and Unmatched Bets panels which can be hidden if you
don't need them.
To cancel all back or lay bets in this market, use the buttons under the Unmatched Bets panel.
To clear all matched or unmatched Test bets in this market, press "Clear Test".
Note: you can force-match a Test Bet, i.e. make it "matched" and appear in the Matched Bets
panel. This feature is very useful for testing strategies where the bet has little chances to be
matched in Test Mode, but is likely to be matched in real mode. See an example below:
As you can see, the price of the bet is 2.3. In real mode, this bet would have appeared on the Back
side, and the current back price of Conquest Twister would have been 2.3, not 2.28. In Test Mode,
however, this is not possible, as your test bets cannot affect the prices the program receives from
BetFair. So you can manually, at any time you like, match this bet as if some other trader accepted
your bet my placing the bet of the opposite type.
4.3.5 Ladder
The Ladder is a very popular trading instrument giving a breakout of all prices and amounts offered for
a selection in the form of a table.
You can find many references to a ladder on bettors online forums and dedicated web sites.
You can do the usual one-click betting by clicking on the corresponding back or lay price.
If you have any unmatched bets on the selection, they will be displayed on the sides of the ladder.
To quickly change the price of a particular unmatched bet, drag-n-drop it on the cell with the desired
price value.
To navigate to the last traded price and thus see where the money is being matched right now, click
on the label with the last traded price in the header.
To trade out at selected price (if you have any open bets), click on that price in the central price
column.
Apart from doing all standard actions like placing back and lay bets, you can also make use of the
special trading buttons in the header.
To trade out (either green up or distribute the loss, in other words, close your position on the
selection), click on the trade-out button. The two amounts on that button represent the "what if P/
L" (the P/L the selection will have after you trade it out) and the actual net amount you will win or
lose from that trade-out.
To close your position with as little loss as possible (either zero or with a profit), press the "Trade out
to zero loss" button. It will place a bet that intends to either green up your bets (if the prices are
suitable) or close them with a zero profit (if the price does not allow it to be matched, the bet will
remain unmatched).
You will see two tabs for Real Bets and Test Bets. You can switch between them to see bets you
placed with real and test money.
To sort bets by time, market, type etc., press on the necessary button in the header of the table.
You will notice an interesting column titled Source which shows you the procedure that placed the
bet (if it is possible to determine it).
You can quickly jump into the market where the bet was placed by clicking on the bet row.
It consists of an area for inserting the text of the expression and a reference table where you can find
help on all trigger variables supported by MarketFeeder Pro.
5 Test Mode
Test Mode is a great opportunity to safely get started with the program. In this mode you are
operating a virtual account with virtual funds. And so you don't risk a single penny, in fact you may
have a zero BetFair account and still learn how to trade in MarketFeeder Pro.
The behaviour of Test Mode is very close to the way BetFair maintains your real bets, except that a
test bet cannot be split and matched partially. It also will always be matched if the price you offered
is available in the market, no matter what amount of money supports that price.
However, in the majority of cases Test Mode is quite realistic and efficient in trying out staking plans
and other auto-trading and simple betting functions.
All test bets in the program are markets with the label "TEST". To remove matched or unmatched
test bets from a market, use these buttons.
To clear all test bets in all markets at once, press the "Clear Test
Bets" link in the Main Menu.
To edit special settings for Test Mode, go to the Test Mode Options
tab.
You can quickly test your staking plans by settling markets in Test
Mode without waiting for BetFair to do this. This way you can place
test bets, settle them, see how your triggers behave and reset the
markets, repeating the cycle as many times as you want. See Bet
Settlement Simulator for more details.
6 SMS Service
6.1 Introduction
WDS SMS Service is a fast and convenient way to send text alerts from MF Pro to registered phone
numbers.
It keeps you updated on what's going on in the program, because you can configure it to send sms
texts as often as you want, and on your conditions.
An SMS message is a text containing up to 160 characters. You receive it on your mobile phone.
MF Pro will form this SMS based on your settings and send it on the number you'll register.
An SMS may contain roman letters from a to z in upper and lower case, digits, symbols from this
group: !?@#$%^&*()-+<>/|\.,':";_. All other characters may be transcribed or omitted.
You can send them to your own number or to a list of phone numbers that you will specify. You will
need to confirm that you own the number you have registered. If you choose to add more numbers,
we will verify them too by sending confirmation requests to all of them. Once they've been confirmed,
you can choose where to send texts: it could be only your number, only the numbers from your list
or both. So this service can act as a personal notifier or as a subscription service.
You can tell the program to send an SMS using a trigger with the action "send text to mobile". By
configuring the settings of this trigger you define the situation in which a notification should be sent.
For example, you could tell MF Pro to SMS-alert you whenever a back bet is placed and matched in
a horse race:
You can also configure the program to send you notification on a couple of standard events. See
"SMS Settings".
For more information on how the service can be activated and how to top-up your account, please
read here.
We believe that you can use MF Pro for placing bets while you are not around. For example, you
may leave it running on a home computer and go to work.
WDS SMS Service will ease your mind and hugely increase the control over the program.
You can of course use the free Email notifications, but you definitely spend at least a couple of
hours a day away from the Internet.
If you have a list of people interested in your betting advice, WDS SMS Service is ideal for sending
them your tips in real time! You just leave one copy of your MF Pro running, key in your "secret
criteria" into a trigger, and let it alert all your clients on a horse to lay or a team to back whenever the
right opportunity comes up!
They will just need to confirm that they want you to send them these tips. It is easy, safe and you
could be up and running within 20 minutes.
Go to "Settings" -> "Email & SMS Options" and press the button "Open WDS SMS Service".
If you can't see this button, make sure you have the latest version of MF Pro and reinstall the
program. If it doesn't help, contact support.
1. Just go to "Email & SMS Options" tab of the "Settings" and press the button "Open WDS SMS
Service".
It will warn you that you need to set up an account first. As you have already purchased your SMS
package, click "OK" to proceed.
2. In the "Number & Code" panel enter your telephone number. Note: the number should be 12 digits
long, and must start with your country code. For example, for UK a number could look like
440753927666, for Italy 393571120333, for Spain 347123456789 and so on. Do not enter any other
signs or spaces there.
4. In the small window that will open enter the security code that you have received on your phone.
The text should start with "Your security code is". Enter it exactly as you see it on the screen. If you
didn't receive the security code, please contact our support.
5. The program will match this code with our database records and let you know whether your
verification has succeeded.
Should you need to change your phone number, open SMS window and insert the new number into
the "Telephone number" field.
It will warn you that a new security code will be sent to that number at your expense. If you want to
proceed, press "Yes".
Then repeat the steps described in "Number Verification".
Changing code
You can change the security code to something that you can remember better. Just press the
"Change Security Code" button and enter your new code and your current code and press "OK".
Your security code will be changed immediately.
Enter the text that will be visible in the "From" field of every message. This text will be added to the
"MF-" token.
You can choose what to do if the message generated for an SMS is longer than 160 characters. It
could be truncated to fit into one message, or split into several messages each 153 characters long.
When there are ... sms left send email / separate sms / short warning inside sms
Turn this on if you want MF Pro to notify you when there is a certain number of credits left. The
program can send you an email to the address that you used when last buying credits, a separate
SMS or a short warning inside the SMS that will precede that number.
You can choose to limit the number of messages sent, even if the given criteria for sending it are
satisfied. This could be useful if you expect that these criteria could be met quite often and don't
want to run out of credits too soon.
Activate this option to have the history of your SMS messages saved in your account. You could
then browse them and check what exactly was sent to your phone and the phones of your
subscribers.
Unicode format
Some languages may contain non-Roman letters, such as uioa in Italian or αβγδε in Greek. In order
to display these (and many other) Unicode characters correctly, you need to turn this option on.
Otherwise the program will attempt to transliterate those letters, but if it doesn't succeed, the letter
may be lost.
Apart from sending SMS with a trigger, you can choose to let the program send you notification
when any of this happens:
Will send an SMS whenever there are new bets settled in your account (i.e. when your account
statement is updated with betting transactions).
Will send an SMS whenever you are trading with real money and this error comes up, which means
you don't have enough funds in your BetFair account.
Will send a text when there is new score in any of the markets you are refreshing.
This service is ideal for tipsters. Just create a trigger that checks the necessary market conditions,
set its action to "send sms" and choose "Batch list only" or "My number and Batch list". The
program will send an SMS to each phone on your list whenever the trigger gets executed!
1. Create a text file with any available text editor, for example, with a built-in Windows Notepad.
4. Press the button "Import Phone List". Specify the path to the saved file.
5. It will let you know how many numbers have been imported.
If you are adding these numbers for the first time, please be aware that EACH of them needs to be
verified before you can send them messages. This is required to prevent spam. So warn your clients
beforehand that they will receive a security key that they will need to enter on a special web page.
The URL will be given in the same SMS message. They will receive all the instructions by email.
Please note: all SMS messages will be sent to your phone list at your expense, so you will spend
your credits. You may need to charge your clients an extra for that.
Your clients will be automatically subscribed to your sms messages once they have confirmed their
numbers. Until then MF Pro will not send SMS messages to unverified numbers.
To know which numbers are verified and which not, view the "Subscribers" table in your account.
To see the history of your last messages, open SMS window and click on the link "View Account".
A web page with the history of your messages will open in a new window. It will also list the number
of credits left, the history of your payments and some additional info.
If it asks you to log in, enter your phone number and the security code.
7 Auto-Trading
Auto-Trading tools in MarketFeeder Pro are designed to calculate and place bets automatically
according to special rules.
Among the Auto-Trading functions available in the program there are:
Auto-Dutching
Auto-Greenup
Triggered Betting.
All you need to do is make a list of these selections' names, preferrably exactly as they are called at
BetFair, and put one name on each line in a simple text file.
Example:
"Denali Highway"
"Arbeo"
"Bennys Well"
The search will be case-insensitive, so you don't need to worry about capital letters.
If you want to specifically define the market to which a selection belongs (for instance, if you want to
add Match Odds from different football matches), you can add the market's name in front of the
selection in square brackets.
Once you've added all your selections, save the file where you'll be able to find it. Then press the
"Import selections for auto-trading" and select this file in the file dialog window.
The program will let you know how many selections it could identify.
All other selections will become inactive for auto-trading and will be grayed out. It essentially means
the program will ignore them when doing all auto-trading functions, such as Auto-Greenup and Auto-
Dutching, as well as triggers. You will however be able to bet on them manually.
The program is able to perform fuzzy search, i.e. approximate string matching with discrepancies of
up to 3 characters. Example:
Although the selection names in the file do not have the same spelling as on BetFair, the program
will still be able to import them as the actual names differ no more than by 3 characters ("Red"
instead of "Bed", the spaces in "Likeamonkey", etc.).
To activate fuzzy search, insert an asterisk as the first character of the line.
You can import selections by their trap numbers instead of their names, but only for Greyhound
markets and only if you enclose the trap number in ##.
If there is no dog running along the specified trap number in the given market, that market's selection
will not be imported.
If you specify the name of the market in front of the dog's trap, the program will look among the
selections of that particular race.
Example:
This will import Trap #3 from 10:27 Harl and Trap #2 from 10:43 Henl.
If you don't specify the market, then selections with that trap number will be imported for all
Greyhound markets in your list.
There is an option to reimport the selected file at the specified intervals (up to once in 0.5 sec). In
between the imports, you can change the contents of the file either manually or using any
application of your choice.
Hint: You can quickly add all necessary markets by making a similar list with parts of markets'
names, such as:
"Ascot"
"Wolv"
"Birmingham"
etc.
Then open the Market Locator, choose the country and type of sports you want to search in and key
in the following condition:
And instead of ... choose the file where you put your markets' names. Then continue the market
search procedure as usual.
You can import certain numbers or text values together with selections' names. For example, you
may want to import a maximum price at which you will place a lay bet on a selection. This too is
often a part of a tipster's service. To load such values into the program, put them on the same line
with the selection's name and separate them with a "Tab" character (or the "Tab" key on your
keyboard). Enclose any value that you want to be considered as a string value (i.e. text) in double
quotes. Examples:
"Centasia" 1 "ert"
"Ticketmaster" 13 22.6 "louise"
"Raskova" 0.00000007 "£34" 3.15 0.26
Note: put exactly one "Tab" character between the selection's name and the first value, and between
all the other values.
If your tipster gives you a file with a different separator (e.g. comma or semicolon), use any text
editor, such as Notepad, to replace those separators with the Tab symbol.
To import such file, do the same steps as described above. The program will let you know how many
values it has imported.
You can access these values through Variables referring to imported values.
The imported values will be stored even if you close the program. To clear them, delete the
corresponding market from your list and then re-add it, or import a new file
If you want to import values for some selections while keeping all other selections active for auto-
trading (i.e. if you do not want to deactivate all other selections), place this character sequence on
the last line of the text file:
#all_active#
7.2 Auto-Dutching
In a nutshell, Dutching is spreading your potential loss across a number or runners by backing or
laying more than one selection in a race or event. Dutching requires calculating a correct stake size
to place on each selection, so that the return is equal if any of them wins or the loss is equal if all of
them lose.
Ideally, you would want to include all runners in a Dutching because this way you will get a
guaranteed profit if all your bets get matched. Unfortunately this is only possible if the market is
temporarily exposed to an underround/overround book (that is, the sum of all runners' chances of
winning is less than 100% if backing or greater than 100% if laying). Such situations are, however,
very rare these days at BetFair, or they last for a very short period of time.
There are many good articles on the web that explain Dutching in details.
We also have explained the basics (and more in-depth stuff) here:
Single-Market Dutching Formulae
Cross-Market Dutching Formulae
MarketFeeder Pro can automatically search a Dutching opportunity for you, both on the back and lay
side of a market. It will then calculate and place the necessary bets according to your settings.
Choose a market where you want to try Auto-Dutching and configure its settings. They are individual
for each market, but you can also define the default ones in the program's Betting Options.
Press the Auto-Dutching settings button in the market window. Enter the desired parameters and
press Place Dutching bets.
You can either Dutch based on the maximum payout or the amount to win or lose.
The payout is the product of a bet size multiplied by its price. With Dutching, the payout is equal for
every selection you are betting on, i.e. the higher the price, the smaller the bet. If you select this
parameter, the potential profit or maximum liability of your bets may vary and will depend on the
prices of the selections you'll be betting.
The amount to win / spend allow you to define specifically how much money you want to win from
the Dutching (regardless of amount spent) or the maximum liability you want to be exposed to
(regardless of the potential profit).
The Minimum Profit % will define the level to which the book% is overround or underround.
Incidentally, this figure also determines the profitability of your Dutching. The greater it is, the more
money you will win if your bets win, but it will also mean such occasions will be more rare. You can
specify a number from 0.5 to 99. For example, with 0.5 the program will look for any Dutching
starting with 99.95% or lower on the back side and 100.05% or higher on the lay side.
Then tick which type of bets you want to look for (Back Side, Lay Side or both). Beware that if you
choose both back and lay sides and bet at the current best prices, you will likely generate
guaranteed loss.
You can choose to place bets at prices that are different from the current ones by the specified
number of ticks. This number of ticks is called price offset, and it can be positive -- for betting at
higher prices, or negative -- for betting at lower prices.
You can choose the range of selection ranks or indexes to bet on.
Ranks define how the selections' prices compare to each other. The first favourite has rank 1 and the
selection with the highest price has the maximum rank that is equal to the number of selections in
the market.
Indexes, on the other hand, define the selections' positions in the list, from top to bottom, as they
appear on BetFair.
You can enter a number, a list of number separated with a comma, e.g. "1,3,4", a range of number
separated with a hyphen, e.g. "1-5", or a combination of those, e.g. "1-3,6,7".
To give yourself time to check the results of each Dutching, it is recommended to turn on Stop after
each Dutch.
If you want the size of all bets to be adjusted to the amounts offered in the market, tick Adjust
amounts. In this case the profit may be different from the settings as bets will be automatically
resized to fit the offer. This way the chances that all bets will be matched are higher.
Finally, tick Bet In-Play if you also want to perform Auto-Dutching when a market is In-Play (though
it is riskier as prices change faster).
Auto-Dutching works equally well in win and place markets, and the settings for these types of
markets are the same.
Please note though that it is not recommended (in fact it does not make sense) to Dutch in Asian
Handicap or Total Goals markets.
7.3 Auto-Greenup
Auto-Greenup is a MarketFeeder Pro's term for performing automated trading out, or offset betting,
whereby you mean to equalise profit or loss on all selections in the market.
This is one of the most popular trading techniques, sometimes involving tens of bets placed on the
same selection in the course of a match or race. It is called a "Green-up" because it "greens up" a
market, that is makes all P/L figures positive or green.
The formula for this type of trading is very simple: to generate equal profit, the payouts of all back
bets must be equal to the payouts of all lay bets placed on the same selection. In the same time,
back bets should be priced higher than lay bets.
Example:
10*2.5 = 12.5*2.0
Your profit will always be equal to the difference between the lay and back amounts, e.g. in this case
£2.5.
This also concerns distributing your losses equal among all selections in the market. The formula
and principle are exactly the same, only you back lower than you lay, and so your loss will be equal
to the difference between the back and lay stakes. This is sometimes referred to as a "Stop Loss"
bet. In MarketFeeder Pro we call this action "distributing loss" as opposed to "greening up".
You can of course green up manually by placing back and lay bets yourself, but a simpler option
would be to use Auto-Greenup.
There are the following Auto-Greenup options available in each market.
Based on ticks — offer a price that is several ticks higher or lower than the price of the initial bet.
P/L Ratio %
Set the P/L Ratio % for profit/loss distribution.
Trailing Stop-Loss
If the Stop-Loss function is set to be "trailing", it will count the stop-loss ticks (or loss percentage) off
the best position you had since the trading started, as compared to counting it off the initial position.
So let's say you laid at 3.5, set the Stop-Loss Ticks to the value of 5 and are waiting for the price to
crawl up to at least 3.8. However, the best you had was 3.7 and then the market went in the
opposite direction. If the Stop-Loss is not trailing, the program will close your position when the price
falls to or below 3.25 (3.5 minus 5 ticks). If "Trailing Stop-Loss" is on, it will act earlier, when the
price falls to or below 3.45 (3.7 minus 5 ticks). This way you prevent losses from accumulating
before it is too late.
Bet In-Play
Turn this on if you want to perform trading when a market is In-Play.
8 Settings
MarketFeeder Pro is extensively customizable. The Settings window is divided into several subject
tabs for your convenience.
General Options
Betting Options
Monitoring Options
Stop-Loss Options
Excel Options
Logger Options
Settings Profiles
You can save certain settings configuration in separate Settings Profiles. A Settings Profile is simply
a file with all MarketFeeder Pro settings.
Your current profile is set at the start of the program, in the Login Window. All changes to the
Settings that you make while using the program are saved in that profile.
New profiles can be created in the Login Window as well. Each new profile will first have default
settings until you make some changes to the Settings.
Switching between profiles at the start of the program is very convenient if you intend to try different
ways of using MarketFeeder Pro.
You could have a separate settings profile for scalping, staking plans, betting in races or football
matched etc.
Most important messages in the program are written to the Action Log. For instance, they may
contain information about bets you placed manually or through betting functions.
Activate this option if you want to see these messages on the screen.
Keep this option turned on if you want the program to ask your permission each time it's going to do
something important, like place or cancel a bet, delete a market, activate triggers etc. It is definitely
recommended to have it turned on if you only started getting acquainted with MarketFeeder Pro.
Market Settings
Tick this if you want finished or settled markets be removed from your market list automatically. A
finished market is the one that is labelled "Finished". A settled market is a market that has been
settled, i.e. its outcome has been downloaded from BetFair or generated by the Bet Settlement
Simulator.
If the previous option is on, this option will limit the number of finished / settled markets that the
program will delete. For example, if there are 10 settled markets in your list and you turned this
option on and set it to 3 markets, then 7 markets will be deleted and 3 most recent (the ones whose
start time is the closest to the present moment) will remain. When the next market is settled, one of
the previous three will be deleted again, as the most recent three will now include the newly settled
market. This option is aimed at reducing the amount of memory that the application occupies when
there are many markets in your list.
You may choose to delete markets from your list once they turn In-Play.
This setting will clear all markets upon closing the program.
Delete all markets (essentially clear the My Markets list) at the specified moment. The time must be
entered from 00:00:01 to 23:59:59.
This can be useful if, fir example, you want to clear all old markets shortly before the start of a new
trading day, say at 8 am, and then load the new markets using Market Locator.
A record will be made to the Program Log when the time has come to clear the markets.
Turn this on if you want to see the current prices immediately as you add a new market to your list.
Show SP Prices
This setting allows you to see Far SP, Near SP and the actual SP in markets that support SP
betting.
If you choose the Engineer Mode, you will be offered to enter the default values / formulae for each
cell.
By default selections are listed in the order they appear on BetFair. If you want them to be sorted
differently, choose the preferred order from the drop-down list.
Choose whether you want to have all selections active (enabled) for auto-trading function, such as
Auto-Greenup, Auto-Dutching and Triggered Betting. If they are inactive, they will be invisible to
these functions. You will see them greyed out in the market window.
Selection Info
Normally when a market is refreshed you are given only the three best back and lay prices and the
appropriated amounts offered at those prices. If you plan to use trigger variables back_volume and
lay_volume and want to get the total amount offered for a selection on each side (which includes all
prices), you may want to turn this option on. Also, with this setting on the accuracy of POM and
WOM figures will be higher. This however will require a separate request to BetFair for each selection
and may significantly slow down the refreshing of the market.
Using this setting, you can focus only on prices with the specified minimum amount available on
offer. I.e. the prices with trifle offerings will be both ignored by triggers and hidden on the screen. The
setting will only work if you turn OFF "Retrieve all price offers". Note that in case prices with the
minimum amount you specified are not available, the exchange will still show at least one price on
both Back and Lay sides, regardless of your settings.
Please note: this option will not work in Time Machine.
Note: this setting also applies to the Ladder and the amounts displayed next to each price in the
Ladder. All offers less than the amount specified will not be shown in the Ladder.
Tick this option if you want to obtain the amount of money traded at each price for each selection.
If you choose markets to be displayed in Full Mode, you will notice three figures showing you how
the price of each selection has changed over three time periods. You can set the lengths of these
periods using this option.
Choose what type of data to show above the mini chart in Brief Mode.
The same data will also be displayed on the coloured bar in Race Mode.
Tick this to take the exchange commission into account when displaying a positive P/L figure under
a selection's name.
Choose whether you want to view a selection's digital prices or its chances for winning. You can
convert one into another using the following formula:
If you enable this option, you will see the fractional (traditional) odds in a tooltip that will come up if
you move your mouse over any betting button:
In this case you can see that the digital odds 1.74 correspond to the fractional odds of 37/50.
Account Statement
Your Account Statement must be downloaded from BetFair regularly in order to keep track of all
profit/loss generated from the settled bets you placed in your account.
This is the only way to maintain your Win/Lose History and therefore to run staking plans.
Turn this option off only if you are not interested in the history of your bets, i.e. if you don't bet with
real money or if you don't plan to use Win/Lose History variables.
Set a limit to the number of transactions the program can process. This is quite useful because a
large number of records may significantly slow down the program.
Retrieve records starting from this date / Retrieve data that are not older than ... days
Choose how deep you want to go into your account statement. If you always want to start your
staking plan from a scratch every day, it is obviously better to get the statement that is not older
than 1 day. If you want to resume a staking plan you finished yesterday, choose the necessary
number of days.
Tick this if you don't want to include commission deductions into your Win/Lose History.
Tick this if you don't want to include deposits and withdrawals into your Win/Lose History.
Available Funds
Specify how often you want to update your funds and exposure. You can choose anything from 1.0
to 1140 (19 min).
Betting
MarketFeeder Pro needs to update the list of your matched and unmatched bets from time to time to
calculate your P/L and liability. These settings define how often the updating should take place.
Set the frequency with which the bets should be downloaded from the server. In case you are in Test
Mode, this setting define how often the state of test bets will be checked (in case they need to be
matched or voided).
Tick this option if you want to have a market's bets updated simultaneously with its refresh. In this
case the bets will be updated at the same refresh rate as the market's prices, but if a market is not
being refreshed, the bets will not be available.
One-Click Betting
One-Click Betting allows you to place a bet with just one click of the mouse.
Set the default stake size for one-click back and lay bets in markets. You will be able to modify
them for each particular market. These values can be accessed through trigger variables
default_backa and default_laya.
Set the default liability for laying at SP or the default stake size for backing at SP, in those markets
that support SP betting.
Turn this on / off to enable / disable One-Click betting. When it is disabled, a left click of the mouse
on a betting button opens the Betting Interface.
Available options:
Cancelled
Kept
Matched at SP
In markets that support bet persistence this option defines how unmatched bets will be treated after
the market turns In-Play. It can be cancelled, it can remain unmatched or it can be matched at SP (if
SP is supported as well). If bet persistence is not supported, all unmatched bets will be cancelled.
For SP bets set the price limit to the current best odds
In markets that support SP betting, this options sets the price limit of all SP bets that you place with
One-Click to the current best back or lay price (depending on the type of bet). If it is not turned on,
all SP bets will be placed without price limit.
Small Bets
By turning this on, you allow MarketFeeder Pro to place bets below the acceptable minimum size
defined by the exchange. It will be done through a well-known procedure whereby an unmatched bet
equal to the minimum is first placed, then its size and price are modified and the rest is cancelled.
Please note: we do NOT recommend to have this option turned on and we will not be held
responsible for whatever consequences it will lead to (i.e. suspension of your account). Use it at your
own risk.
If "Allow small bets" is turned on, this option lets you control the way small bets are posted to
BetFair. As you probably know, there are three steps in which a small bet is placed. Firstly a
minimum sized bet is placed at the price that has the least chances to be matched, i.e. 1.01 for lay
bets and 1000 for back bets. Secondly, the size of that bet is reduced to the required amount.
Thirdly, the price of the bet is changed to the requested one.
If this option is activated, then each step is completed for all small bets you are posting to BetFair at
once. If it is deactivated, all three steps must be completed for each bet before the next bet is
placed. So here is an example:
You lay £0.4 at 2.3 and £0.65 at 7.8.
If this option is on, then the program will lay two £2 bets at 1.01, then reduce them to £0.4 at 1.01
and £0.65 at 1.01, then adjust them to £0.4 at 2.3 and £0.65 at 7.8.
If this option is off, the program will lay £2 at 1.01, reduce it to £0.4 at 1.01 and adjust it to £0.4 at
2.3. Then it will lay £2 at 1.01, reduce it to £0.65 at 1.01 and adjust it to £0.65 at 7.8.
The main difference between these approaches is the need to have enough funds to place £2 *
(number of bet) if you choose the first approach. However, this way you have better chances of those
bets matched as it may take less time to place them all on the queue on BetFair.
Set this to the maximum price you are prepared to risk when sending bets below the minimum.
E.g. if you set it at 1.1, then whenever you want to lay £0.2 at 1.2, the program will first lay £2 at 1.1,
then add £0.2, cancel the unnecessary £2 and set the odds to 1.2. This, of course, means that you
can be left with a £2 bet matched at 1.1 if the current price has become 1.1 or lower.
Place compensation bets for BACKING less than ..., LAYING less than ...
BetFair will not allow you to lay amounts that generate a very small liability (generally, below £0.01).
Therefore, a workaround is to lay slightly more and to balance the unwanted part of the lay bet with a
back bet. Use these settings to place a a compensation back bet to eliminate the extra liability. E.g.
if you back £0.5 at 2.5 and the price drops to 2.4, you cannot green up with a lay bet of £0.52,
because this bet will be rejected by BetFair and you will end up with £2.0 at 1.01. Now, if you turn
this option on, the program will lay £0.8 and back £0.29 at 2.38 to remove the liability created by
laying the extra £0.8-£0.52 = £0.28. Note that this will reduce your potential profit or increase your
potential loss (in case you trade out with a loss). But at least it will prevent you from losing all of
your bet, and it will be done automatically by the program, without losing the precious time.
When laying at "best" price, offer a price that is ... ticks above the current lay price
The term "best price" here refers to the lowest possible price available for your whole bet to be
matched. Let's say you lay £1000 at 4.5, but only £500 is available at that price. Another £400 are
offered at 4.4 and £300 are offered at 4.3. If the program is to match your whole bet, it will have to lay
£500 at 4.5, £400 at 4.4 and £100 at 4.3. Luckily this is done automatically by the exchange if you
lay at a price that is higher than the current available odds. I.e. if the program offers £1000 at 5.0, the
exchange will automatically lower down that offer to the best available prices and match all three
portions.
Thus this setting determines how high you are prepared to go above the current best price. Setting it
too low, e.g. 1 tick above the current price, may leave your bet unmatched if a market is highly
volatile (especially at In-Play), as prices will keep changing every millisecond. Setting it too high may
result in there being not enough funds to cover the liability.
When laying at "best" price, don't offer a price that is higher than ...
In addition to the previous setting, this one limits the maximum lay price the program can offer in
order to match your bet at the best odds.
This is a "safety net" setting which allows you to limit the potential loss any bet can expose you to.
The value you specify here will be the maximum possible liability for any given bet, i.e. if a back bet's
amount or lay bet's liability exceeds this value, it will not be placed.
Ignore all bets except those placed in the current MF Pro profile
If you activate this option, the program will stop seeing all bets, including bets placed with real
money, if they have not been executed from inside the currently chosen settings profile in
MarketFeeder Pro. This means that all bets placed directly on BetFair's website, inside other betting
bots or even inside MarketFeeder Pro, but under a different settings profile, will be ignored by the
program. Such external bets will not be reflected in the market P/L, shown in the interface or taken
into account in any of trigger variables. Use this option to separate different betting strategies under
different settings profiles.
Please note that this option can only hide bets that have not been settled yet. Once these bets are
added to your account statement, there is no way to distinguish them from bets placed elsewhere,
so unfortunately you will need to take extra effort to run strategies involving loss recovery or other
staking plans.
Auto-Greenup
This is a group of default settings for the Auto-Greenup tool in markets. Read the Auto-Greenup
section to get information on how each setting works.
Auto-Dutching
This is a group of default settings for the Auto-Dutching tool in markets. Read the Auto-Dutching
section to get information on how each setting works.
Banking
Stop automated betting when the total bank has reached ...
This option will stop all Auto-Greenup, Auto-Dutching and Triggered Betting if the total funds in your
balance are equal or greater than the value specified.
This option will stop all Auto-Greenup, Auto-Dutching and Triggered Betting if the total funds in your
balance dropped below the value specified.
Stop automated betting if the maximum loss in the market has reached ...
This option will stop all Auto-Greenup, Auto-Dutching and Triggered Betting in any market where the
maximum potential loss (maximum liability on any given selection) is equal or greater than the value
specified.
Triggers
This option prevents all Triggered Betting from working in a market unless the event starts within the
time specified.
Tick this to keep your computer's date and time synchronised with BetFair's.
Tick this to allow the program download data from BetFair in archived (zipped) format and then
unpack them for further use. This saves you a lot of Internet traffic but may slightly increase the load
on the CPU.
Set the maximum waiting time before a request to BetFair is dropped as timed out.
Market Refresh
Make the program start refreshing markets automatically when the specified time is left till their
scheduled start. Recommended, especially if you have more than 10 markets added to your list.
This option allows you to stop monitoring markets automatically at some point before or after their
beginning. For example, you may want to stop monitoring suspended markets that do not turn In-
Play.
This setting defines how much historical data about each market is kept in the memory of
MarketFeeder Pro. This includes all data loaded into charts, volume and last traded price trends,
history of selections' prices etc. You can't access any market information that lies outside the
specified timeframe. But don't rush to set this to a couple of hours: the amount of RAM used for
storing the associated data may eat up all your computer's resources.
Save your traffic and computer resources by using this setting to limit the number of markets or
events you want to refresh at any given time. The program will block the refresh of any market/event
beyond the set number and put it into a waiting queue, even if it is time for that market/event to be
refreshed according to the relevant monitoring options. Once you or the program stops or deletes
some market/event, those put in the queue will start refreshing automatically. The priority is given to
the market/event with the closest starting time. If the market is put in the waiting queue, you will see
the hourglass icon on its start/stop button:
Turn this on to download score data for some tennis matches (not all). If this option is off, you will
not see the score, nor will you be able to read tennis variables. When this option is on, you can see
the score, as well as current server and stroke type, underneath the selections.
Turn this option on to download the score of some football matches from a third party web source. If
available, the score will be displayed next to the market's start time.
Please note we do not guarantee the accuracy of the score, nor the continuance of this service.
Tick this box if you want to have market prices displayed exactly as they are shown on the BetFair
web site. These figures may be different from those supplied by the BetFair API. Please read more
on this here.
The default rate at which a market is refreshed before it starts. You can change this individually for
each market.
The default rate at which a market is refresh after it has started (turned In-Play). You can change this
individually for each market.
The program can automatically search for certain markets according to a template you specify. You
can use the settings below to schedule this search.
The template to search by can be edited in the Market Locator window. There are several most
popular templates that come with MarketFeeder Pro. You can create and customise your own.
If any markets are found, they will be added to the My Markets list. All default settings will be
applied to them as usually.
Charts
Horse Racing
Tick this option to load information about the status of horse racing/Greyhound markets. You can
then check it on the screen or using trigger conditions and variables.
This information may not be available for all races.
Silks are a special set of data available in some horse races. Their bits can be seen in market's Full
Mode and Race Mode. Also, they can be accessed through the corresponding trigger variables.
Keep this option turned on if you want the silks to be downloaded and displayed in horse racing
markets.
This option will enable the loading of the silks data, such as form, age, weight, etc. If you also want
to load the images of jockeys' outfits (apart from their textual description), tick Download Horse
Racing Silks images.
Tick this option if you want to download the images of jockeys' outfits. If you don't need them, then
disabling this option will significantly speed up the loading of horse racing markets.
Since silks are made of numerous parts, not all of them can fit in a market window. Choose the ones
you want to see on the screen. The yellow bits will be displayed in Full Mode and Race Mode. You
can edit their order using drag-n-drop.
Betting
Waits for the given number of seconds before actually placing or cancelling a test bet. This makes
betting in Test Mode more like betting in real mode. Betting with real money usually involves a
certain delay, depending on the server's performance, the country you're located in and some other
factors.
We recommend to activate this option if you are testing Auto-Greenup or Auto-Dutching functions.
Saves and restores all your test bets that you placed before exiting the program.
Tick this box to neither show nor include your real bets into P/L calculation when in Test Mode.
Event Results
Keep this setting on if you want markets to be settled automatically as soon as the results become
known on BetFair. This usually happens within seconds after the market is finished.
Please pay attention to the fact that this option only settles test bets and has no influence on bets
made with real money. Those will be settled on the exchange and loaded into the program in the
form of Account Statement.
If a market is still not labelled as Finished after being settled, this option makes it Finished and
stops refreshing it.
MarketFeeder Pro can act as a virtual exchange and settle markets in Test Mode by a rule you
choose. In this case one or more winners are picked by the program, not by BetFair, and all bets are
settled in accordance with those winners. The number of winner selections will be equal to the
number of winning places in the market.
Therefore, the simulated outcome most probably will not coincide with the real one, but it lets you
repeatedly test the same staking plan over and over by settling and resetting a sequence of markets.
Note that the Simulator should not be used simultaneously with "Settle markets with data loaded
from BetFair".
Let MarketFeeder Pro which rule you prefer for automated settlement of markets in Test Mode. The
available options are:
1. Random
2. By Last Price
The winners are chosen from the lowest priced selections. The Simulator considers the last traded
3. Random By Rank
The winners are chosen randomly, but preference is given to those with the lowest last traded
price. Which means favourites will tend to win more frequently than underdogs (just like in real
sports).
Manual Settling
Please note that you can also settle a market manually by pressing the Settle button.
Turn this option on to automatically settle finished markets according to the chosen rule. The
program will select the winners and calculate the profit/loss of any test bets placed in that market.
Your Test Funds will be updated appropriately, as will be all Win/Lose History Variables.
The Simulator will also randomly appoint a score to a match, such as a football match or a tennis
match. This makes sense for markets where score determines the winner, such as Total Goals
markets or Correct Score. This option allows you to specify the maximum number of goals the
Simulator can appoint to a team.
These Stop-Loss options are an additional level of risk minimisation. They allow you to match
unmatched bets at the best available prices or cancel them upon certain conditions you choose.
Choose which action you want to apply to unmatched bets - either match them (at the best available
price) or cancel them.
If less than ... mins are left till the event's start
Tick this option to match all unmatched bets at a certain time before the off.
If a bet's price is ... ticks or more away from the current price
Tick this option to match unmatched bets in case a market went in the wrong direction.
Specify the persistence of the bets you want to match (only in markets that support persistence).
Turn this option on if you want MF Pro to decorate market spreadsheets and organize their data in
bordered tables. This option will slightly increase the load on your CPU.
Tick this box if you want to add a market sheet for each market when connected to an Excel
spreadsheet. This option is turned on by default. If the box is not ticked, markets will not be added to
Excel by default.
Activate this option if you need to have the list of your current bets in a separate Excel sheet.
Don't create market sheet until it's ... min. till the off
This is a way to limit the load on your computer resources by telling MF Pro not to create an Excel
sheet for the market until a certain time is left till its beginning. If you load the whole race card and
want each market to be represented in Excel, it is not reasonable to load each of them into the
spreadsheet as soon as they are added to My Markets. If you only want the market to be added at
15 mins before the off, then set this value for this option and let MF Pro determine the right time
when the market should be loaded into Excel.
You can have transactions from your real and test Account Statement exported into a sheet with the
specified name.
Example:
Statement exported:
Add cells and formulas that you want MF Pro to automatically calculate and insert into your
spreadsheets on each refresh. Learn more about this feature in section "Custom Cells".
Load selection data from your own spreadsheets without tedious typing each selection's value
individually. Specify the range of cells you want to import and make MF Pro do it instantly.
To learn how the function works please read section "Importing Selection Data from a Sheet".
Email Settings
Configure these settings if you want MarketFeeder Pro to send you various email notifications.
Consult your network administrator or copy the settings from your mail browser.
"From" Address
Since a lot of mail gets straight into junk folders, you can specify the "From" address that all
program's messages will be sent from. Then you can configure your mail software so that it does not
mark messages coming from this address as spam.
"To" Address
Set the email address that all messages will be sent to.
Email Alerts
This is an example of a message you may get when there is a new account statement record.
Please note there is a separate trigger action "send email" that you can use independently from
these settings.
Attention! If you are using Gmail, you may need to turn on the "Access for less secure applications"
in order to let MarketFeeder Pro send mail using your credentials. Click here to turn it on for your
account.
SMS Alerts
The program can send texts to your mobile on different occasions. To make use of this wonderful
opportunity, you need to subscribe to our SMS Service and configure it.
Press the "Open WDS SMS Service" button to open the SMS Service configuration window.
You can adjust the colours and fonts of betting buttons and other parts of various betting interfaces.
Press on each square to edit the colour and font. The changes will be reflected throughout the
program.
Tick this to mark the leading selections in markets. Here is the way they will be distinguished.
Blink the market start time label starting from ... mins before the beginning
Set the time at which the "Starts at" label start blinking in the market window.
You can choose to highlight events and markets from particular countries with different colours in the
Events Tree. This is how it may look for UK markets, for example:
You can check as many countries as you like. The list comes up when you click on the "Select"
button.
You can choose the way markets (mainly races) are displayed in the Events Tree. You can view full
venue names along with additional market info (race length, market type such as Forecast etc.), or
you can stick to abbreviated names. See the difference:
This setting will affect the actual name of the market. If you are using tipsters services, you might be
better off with the long names as normally tipsters do not operate abbreviated names.
If you tick this option, the events in the "Soccer - Todays Fixtures" node of the Events Tree will be
sorted by match start time instead of their names.
Security
You can choose to have these parameters displayed in the program's title in the taskbar. It is very
convenient if you run many applications and need to keep an eye on your funds and want to know
which triggers are being executed there.
Turn this on if you want MarketFeeder Pro to send you an email message in case it has to shut
down following numerous failed attempts at re-login to BetFair. This may happen because of a
temporary break in BetFair's service or if your Internet connection is broken. You will need to
configure the Email settings as well to let the program know your mail server and credentials for
sending mail.
Sounds
Choose your own sounds to play on different occasions. Turn sound on / off by ticking / unticking
"Play sounds".
The Logger should be your go-to tool if you experience problems with triggers, such as triggers not
placing bets or placing them incorrectly.
Below are the settings you can use to adjust the Logger.
At the start of the program clear log records older than ... days
Configure this option to automatically clear all trigger logs that are older than the value specified.
You can view your logs in a default Internet browser. The Logger runs a local web server that
responds to any page requests you make in that browser. By default, the Logger listens to port
19001 if you are running one instance of MF Pro, and to 19002, 19003, etc. for all subsequent
instances you may open simultaneously.
If, for some reason, any of these ports are blocked or used by other services on your computer, you
can set the port number manually using this option.
Remember to set it to a different number in every copy of MF Pro you will be running simultaneously.
The Logger allows you to view your logs remotely. For example, if you leave your MF Pro running on
a home computer with a dedicated IP address, you can then check how the program is doing by
viewing the logs from your work computer or while commuting to work.
Alternatively, you can install MF Pro on a VPS and have access to the program's logs 24/7.
In this case, you will need to specify the IP addresses from which you want to enable access to the
logs. E.g. if you are using a VPS and the network at your work has an IP address of 192.168.0.123,
you can type in this address into this box, to be able to view your logs from your work.
Note: the 127.0.0.1 address will be added automatically, so there is no need to add it manually. This
address corresponds to your local computer, i.e. the computer where MF Pro is actually running.
Make sure you have added all the addresses you want to give access from.
If you would like to spare yourself this trouble, create an account with BetVPS!
Enter the password for viewing your logs from computers other than the one on which MF Pro is
running. When you open your browser and connect to the logs recorded in MF Pro, you will be
asked a password. If you do not enter it or enter an invalid password, you will be unable to browse
the logs.
Triggers
Keep this option on if you want the program to record log files for all triggers. Highly recommended
unless you are running out of space on your disc.
Apart from the general information on triggers' execution, you can include a detailed breakdown of all
trigger expressions involved in your triggers. If any of your trigger fields or conditions contain
variables, functions or arithmetic operators, this setting will make the program write down the results
of their evaluation. Thus you can easily spot an error or deal with cases when you are not quite sure
why a trigger is not being executed.
9 Triggered Betting
It offers you the most powerful tool for programming and testing your betting strategies and staking
plans.
The key idea behind triggered betting is that any part of your strategy can be "triggered" once certain
conditions are satisfied.
You are the one to define and formulate those conditions, as well as the markets in which the
actions are to be executed. A trigger is a set of rules for performing a certain action (or several
actions). It could be a bet, a change of bet parameters, a command to the program, a message sent
to your e-mail etc. MarketFeeder Pro has 50 actions for you to choose from!
Triggers can be defined in simple English using our special Triggers Editor. In that editor you can
create, edit and save so called "trigger files" which contain your betting scenarios.
You can then load a trigger file into MarketFeeder Pro and watch it come into action in the program,
with bets being placed automatically and ideally without your interference.
Of course it takes certain level of expertise to develop efficient triggers, but you will quickly learn with
this manual and the help of MarketFeeder Pro community.
Besides, a library of ready trigger files comes with the program, so you can play with them right
away.
As you already know, triggers must be kept in a file. It is convenient to create separate files for
different betting strategies.
Trigger Blocks
These are buttons for adding a new trigger block to the file and for pasting a block from the clipboard.
A block is a logical container for triggers. In most cases you will need only one block though, but
you may have more if one of the blocks is going to be repeated.
Use buttons in the block to enable / disable it, to add triggers or paste them from the clipboard, to
rename it or to expand / collapse its contents.
Triggers
Each trigger consists of different fields. Change the value of any field by clicking on it and either
choosing an option from a drop-down list or editing text in the Formula Builder. If a label is in bold
font, it is editable.
There must be at least one Action that a trigger executes. You can add multiple actions to the same
trigger, which means they will be performed simultaneously once the conditions are satisfied.
The conditions of a trigger are edited in a separate window in the Conditions Editor.
Conditions
The way you edit conditions is very similar to the rest of the Triggers Editor. You add condition
blocks and then conditions inside them.
A block of condition is a logical cluster of conditions combined by a logical operator OR, AND, OR
NOT or AND NOT. Blocks act very much like parentheses in mathematical formulae.
(Selection's Lay Price is less than 2.0 AND Market's Minutes since the off is greater than 0.5)
OR (Selection's Lay Matched is greater than 0 AND Selection's Back Matched is equal to 0)
Use special buttons to add, copy, paste or delete conditions and/or blocks.
Additional Controls
To change the order of elements within the same block, use drag-n-drop function moving them up
and down. This way you can also drag-n-drop a trigger from one block to another, or a trigger action
from one trigger to another.
You can print out the contents of the current trigger file in a convenient format by pressing the "Print"
button and specifying the path to a file in which you want it to be printed. The file will be opened in
your Internet browser, where you can either view it on the screen or print it out.
You can generate a protected copy of your trigger file. See "Protecting Triggers".
They are very convenient for those who want to sell their triggers or share them without disclosing
the particular trigger fields.
You can add a text memo to your protected file. Those who will open the file will be able to read the
memo, so it is reasonable to add some tips and advice on how to operate and interpret the file.
Trigger constants are the only part of the trigger file that is not protected, so you can use them to
help adjust the protected triggers. For instance, if you are protecting a staking plan, add constants
for defining the initial stake size, the length of the cycle, the maximum liability etc. This will give
additional confidence to the users of your triggers.
Note that protected triggers will generate logs on the user's disk when executed. If you are unwilling
to leave them there, don't forget to turn logging of right before you protect your triggers! (See picture
below):
If you are protecting a file with a password, anyone who knows the password will be able to open it.
Protecting a file with a software key is a more individual approach. Each MarketFeeder Pro user has
their own software key which is unique to their BetFair accounts. Therefore a file protected with this
key cannot be opened by anyone else. All you need to do to supply a protect file to a user is to find
out their software key and enter it in the corresponding field.
A software key is perfectly safe to share, it does not contain any references to a user's account
name or password. To help your clients find their key, ask them to click on this label and copy the
contents of the text field, then send them to you.
It is now possible to protect one trigger file with multiple keys and passwords in one go.
The output of such protection is a set of trigger files encrypted and protected in accordance with the
settings stored in a batch file.
To create multiple protected files, select the "Load a batch file" button and specify the path to the
batch file.
You can create a batch file in any text editor of your choice, e.g. Notepad.
On the first line of the file put the full path to the log file where the progress of batch protection will be
recorded. Example:
D:\MyLogs\mf.log
If the path does not exist, the program will attempt to create it. If you leave the line empty, no log file
will be created.
Subsequent lines contain several values separated by a tab character (\t), and each of them
corresponds to one protected trigger file. Here is the list of those values:
K or P
Security code
If K is chosen as the protection mode, then the security code must contain the software key (the
unique 32-character sequence that each copy of MF Pro has). Otherwise it must contain the
password. The password is limited to 255 characters.
Expiration date
The date of trigger file’s expiration in dd/mm/yyyy format. If you leave this empty, the file will never
expire.
Output directory
The path to a directory where the protected file will be written to. If this path does not exist, the
program will attempt to create it.
[original trigger file name] _[first 4 characters of the key]- [last 4 characters of the key]_
[expiration date if any].mft
Example: double-volume_2e7a-e9a8_20_12_2014.mft
[original trigger file name] _pwd[index of the line in the batch file]_[expiration date if
any].mft
Example: double-volume_pwd3_20_12_2014.mft
d:\Alex\log.txt
P abc 18/10/2017 d:\Alex\output
P def 19/10/2017 d:\Alex\output
K 12g8e08dee6d88792f73ee453a5e85fx 20/10/2017 d:\Alex\output
The program will ask you where you want to save the printer-friendly file. Choose a location where
you will be able to find the file.
Once you've specified the file path, MarketFeeder Pro will open the printer-friendly file in your default
Internet browser.
You must make sure that your variable's name does not coincide with any other trigger variable's
existing in MF Pro.
Please note: all arithmetic expression, formulae and variables will be evaluated prior to assigning a
value to the variable. That is, a variable will hold the final value of this expression, not the expression
itself.
Constants
Constants are variables whose values can be defined upon loading a trigger file they are stored in.
That is, a constant can be declared before any trigger starts working.
In all other aspects a constant acts exactly the same as any other variable would, i.e. you can use it
in trigger expressions and you can set and change its value with a trigger (although the word
"constant" here could be confusing).
The value of a constant can be assigned to it upon loading a trigger file, or the program can
remember the last value the constant had when you closed the program and restore that value next
time you reopen it. To choose between these options, use the drop-down menu:
Parsing Variables
If a user variable is not set, it is not parsed by the program and all references to this variables are not
replaced by its value. For example, if you are going to use a variable "myvar", but have not executed
a trigger which sets its value, then any expression containing this variable will not be evaluated
correctly:
IF(back_price>2, 5, myvar)
This will return the same expression, without any change, because myvar is not defined yet.
So be sure to set a variable before using it, either defining it in the Constants or creating a separate
trigger for this purpose.
Examples of declaring a variable correctly:
Variable Scope
Each variable has its scope which determines how a variable is interpreted by the program. The four
types of scope supported by MarketFeeder Pro are:
Globally
For instance, if a variable is defined "individually for each market", that variable will be recognised
only for the market it was set in. Its value will exist only when applied to that market.
Alternatively, if it was defined "individually for each sport", its value will be recognised in every market
belonging to that sport, e.g. in all Horse Races, but not in Soccer games.
The value of a variable with the scope "Individually for each event" can be set and checked across
different markets of the same sports event (e.g. Win and Place markets of the same horse race).
The value of a variable set in the scope "Individually for each racecourse" can be accessed across all
markets and events that take place in that racecourse/Greyhound stadium, even if they start at
different times. Use this scope, for example, to create win/loss counters within individual racecourse
to pursue separate staking plans across different venues.
Finally, a variable defined "Globally" is recognised in every market, and so has the same value in all
triggers unless you change it.
To view the value of a variable or expression, add a new row to the table.
You can create a new variable and set its value. Just add a new row, enter the name of the new
variable, right-click on it and choose "Set Value".
To view triggers in the currently loaded file, open the Active Triggers window by clicking on this link:
The window that will open lists all your trigger blocks and triggers.
If you start refreshing markets where any of these triggers can be executed, you can watch the state
of triggers in this window. You can check the latest reason why a trigger cannot be executed, as
well as the last market where it has been executed.
You can open the Triggers Editor to change the contents of the current trigger file. Once you have
modified it, the Reload button will turn red to indicate that you need to reload the file in order for the
changes to take place.
The Active Triggers window has two more settings to make keeping an eye on your triggers more
comfortable.
You can open and view the log file of a chosen trigger: just click on its name in the Active Triggers
window. A web page with the log contents will open. Select the market you are interested in from the
drop-down list in the top-right corner of the log page.
9.4 Reference
This functionality is available in the full version of MarketFeeder Pro.
This reference explains every parameter and option you may use in triggered betting.
9.4.1 Actions
There is a generous set of actions you can do using triggers in MarketFeeder Pro. Expand each of them
below to find out details and parameters used.
1. back
Match at SP
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places one back bet on each qualifying selection. The price and amount of each bet are evaluated
from the expressions in those fields. If a market supports bet persistence, unmatched bets will be
flagged according to the Action at In-Play parameter.
2. lay
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places one lay bet on each qualifying selection. The price and amount of each bet are evaluated from
the expressions in those fields. If a market supports bet persistence, unmatched bets will be flagged
according to the Action at In-Play parameter.
Cancel Options
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Finds unmatched back bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options. Then places one back bet on each qualifying selection. The price and
amount of each bet are evaluated from the expressions in those fields. If a market supports bet
persistence, unmatched bets will be flagged according to the Action at In-Play parameter.
Cancel Options
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Finds unmatched lay bets on each qualifying selection and cancels those that satisfy the conditions
in Cancel Options. Then places one lay bet on each qualifying selection. The price and amount of
each bet are evaluated from the expressions in those fields. If a market supports bet persistence,
Cancel Options
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Finds unmatched lay bets on each qualifying selection and cancels those that satisfy the conditions
in Cancel Options. Then places one back bet on each qualifying selection. The price and amount of
each bet are evaluated from the expressions in those fields. If a market supports bet persistence,
unmatched bets will be flagged according to the Action at In-Play parameter.
Cancel Options
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Finds unmatched back bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options. Then places one lay bet on each qualifying selection. The price and
amount of each bet are evaluated from the expressions in those fields. If a market supports bet
persistence, unmatched bets will be flagged according to the Action at In-Play parameter.
7. cancel back
Cancel Options
Behaviour
Finds unmatched back bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options.
8. cancel lay
Cancel Options
Behaviour
Finds unmatched lay bets on each qualifying selection and cancels those that satisfy the conditions
in Cancel Options.
9. cancel all
Cancel Options
Behaviour
Finds unmatched back and lay bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options.
P/L Ratio % Trigger The proportion of P/L the target selection will get after the
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Closes all matched bets, both back and lay, on each qualifying selection by placing one trade-out bet.
An open bet is such a bet that generates profit/loss ratio that is different from the P/L Ratio setting of
this trigger.
If there are more back open bets (their total amount multiplied by their weighted price adjusted for
ratio %) than lay bets, the trigger will place a lay bet and vice versa.
The trade-out action can be otherwise interpreted as greening up or distributing the loss regardless
of the current prices, in an attempt to equalise the profit/loss on all selections (if P/L Ratio is 50%) or
distribute it according to the ratio % specified.
Read more about trading out.
If there are no open bets, this action will do nothing until such bets appear.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
11. green up
P/L Ratio % Trigger The proportion of P/L the target selection will get after the
Expression trade-out bet is matched. Read more here.
Base Options: Defines how the price for a greenup bet is calculated. Read
more here.
Based on ticks
Based on profit
%
Offset ticks Trigger The number of ticks that the selection's price must improve
Expression by compared to the starting bet in order to qualify for a
evaluating to an greenup.
integer
Appears if you choose "Based on ticks".
Profit% Trigger The percentage of the starting bet that you intend to win with
Expression this greenup bet. If the current price allows to generate this
profit, the action will be executed.
Appears if you choose "Based on profit%".
Against last Checkbox Choose whether to green up all existing bets on this
matched bet selection or offset the price of the green-up bet against the
last matched bet only. See more here.
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places a greenup bet on each qualifying selection. The type of bet is determined by the program
based on the existing matched bets on the selection.
Read more abGreening Upout greening up.
The offset ticks or profit percentage that each selection must provide are evaluated from the
expressions in those fields. If a selection's current price cannot meet these criteria, no bet will be
placed on that selection.
If you want a different P/L Ratio % than the standard 50% (when P/L is equal across all selections),
specify it in the P/L Ratio % setting.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places one back bet on each qualifying selection so as to eliminate the loss on that selection
completely. The amount of each bet is calculated depending on the existing matched bets.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
P/L Ratio % Trigger The proportion of P/L the target selection will get after the
Expression trade-out bet is matched. Read more here.
Base Options: Defines how the price for a greenup bet is calculated. Read
more here.
Based on ticks
Based on profit
%
Stop-Loss ticks Trigger The number of ticks that the selection's price must improve
Expression by compared to the starting bet in order to qualify for a
evaluating to an distribution.
integer
Appears if you choose "Based on ticks".
Loss% Trigger The percentage of the starting bet to which the potential
Expression loss must evaluate before the distribution is triggered.
Appears if you choose "Based on profit%".
Against last Checkbox Choose whether to distribute loss from all existing bets on
matched bet this selection or offset the price of the loss-distributing bet
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places a stop-loss bet on each qualifying selection. The type of bet is determined by the program
based on the existing matched bets on the selection.
Read more about loss distribution.
The Stop-Loss ticks or loss percentage that each selection must provide are evaluated from the
expressions in those fields. If a selection's current price cannot meet these criteria, no bet will be
placed on that selection.
If you want a different P/L Ratio % than the standard 50% (when P/L is equal across all selections),
specify it in the P/L Ratio % setting.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
P/L Ratio % Trigger The proportion of P/L the target selection will get after the
Expression trade-out bet is matched. Read more here.
Base Options: Defines how the price for a greenup bet is calculated. Read
more here.
Based on ticks
Based on profit
%
Offset ticks Trigger The number of ticks by which the greenup bet will be better
Expression than the starting bet.
evaluating to an
Profit% Trigger The percentage of the starting bet that the greenup bet will
Expression intend to win.
Appears if you choose "Based on profit%".
Against last Checkbox Choose whether to green up all existing bets on this
matched bet selection or offset the price of the green-up bet against the
last matched bet only. See more here.
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places a green-up bet on each qualifying selection. The type of bet is determined by the program
based on the existing matched bets on the selection.
Read more about greening up.
The offset ticks or profit percentage are evaluated from the expressions in those fields. If a selection's
current price cannot meet these criteria at the moment, the bet will stay unmatched. The difference
between green up and attempt to green up is that the latter does not wait for the prices to be suitable
but places a greenup bet at once expecting it to be matched in future.
If you want a different P/L Ratio % than the standard 50% (when P/L is equal across all selections),
specify it in the P/L Ratio % setting.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
Cancel Checkbox If you turn this on, the trigger will first cancel any unmatched
unmatched first bets of the same type as the ones it is going to place. If
there are no unmatched bets of this type, the trigger will
proceed to placing the bets. The bets of the reverse type will
not be affected. For example, if the trigger action is about to
back, all unmatched back bets will be cancelled first.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Places one lay bet on each qualifying selection at the current lay price. The amount is calculated
according to the formula:
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
Name String The name of the variable. Cannot contain any variables or functions.
Can't be equal to any existing trigger variable's name.
Value Trigger The value of the variable. All variables and expressions inside this
Expression parameter are parsed before the variable is set.
Scope Individually for The scope of the variable, which determines where the variable's name
each sport and value will be recognised. For instance, if you choose "Individually
for each market", a separate variable with the specified name will be
Individually for
created for each market where the trigger is executed. Its value will
each event
depend on the market it is inspected in.
Individually for
Variables with the scope "Individually for each sport" have the same
each market
value in all markets belonging to the same sport.
Individually for
each
racecourse Variables with the scope "Individually for each event" will have the same
value across all markets of the same sports events. E.g., if you set
Individually
such variable in a Place market of a horse race Wolverhampton 14:00,
per selection
it will have the same value in the Win market of that same race. Equally,
Globally if you set a variable with that scope in First Half Goals 0.5 of a football
match, the variable will have exactly the same value when checked from
Correct Score of that same match. This option is very important for
cross-market betting, for example, for calculating the book% for cross-
market Dutching.
Variables with the scope "Individually per selection" may have the same
name yet different values for each selection in the market where the
trigger has been executed. To view the value of variables with such
scope, switch the market to Engineer Mode and enter the name of the
variable into one of the expression cells.
A global variable therefore exists in one copy and has the same value
in all markets.
Behaviour
Creates a user variable with the name specified and assigns it the value obtained from the
expression provided. If a variable with the same name and scope already exists in the program, its
value is replaced by the new one. Therefore, this action can create and modify user variables.
Important! The action will be executed once per each qualifying selection!
Always initialise a variable before assigning a value to it. A good way to do this is declaring the
variable's name and giving it an initial value in the Constants.
If you are not sure whether the variable has been initialised or not, add this condition to the trigger:
Price offset, ticks Trigger Specify the number of ticks by which to offset the price of
Amount to win The amount you want to win if one of the qualifying
selections wins.
spend
Otherwise the maximum amount you are prepared to lose if
none of them wins.
Adjusting Bet full Choose whether you want to place bets as per the
amounts amounts calculation of "Amount to win/lose" or whether you want the
sizes of the bets adjusted to the current offer in the market.
Adjust amounts
If "Adjust amounts" is chosen, the bets will be resized so as
to be matched by the amounts offered at the corresponding
prices. Otherwise there is some risk that they will stay
unmatched.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Performs Dutching with the specified settings by placing back bets on the qualifying selections.
Read more about Dutching.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
Price offset, ticks Trigger Specify the number of ticks by which to offset the price of
Expression each bet in the Dutching bundle. If you set it to a positive
number (or an expression that evaluates to a positive
number), the price will be increased by that number of ticks,
and if the number is negative, the price will be decreased by
this number of ticks. The book% will also be calculated
based on the new prices. Note: if the price offset is negative
with back Dutching or positive with lay Dutching, the book%
will be calculated based on the current best prices, yet the
bets will be placed at adjusted prices. Example: if you lay
with a 3 ticks offset, and the current lay price of a selection
is 2.0, the book will include 100/2.0 as the selection's
chance for winning, yet the bet will be submitted at the price
of 2.06. This will ensure a higher chance of matching the
bet.
Amount to win The amount you want to win if one of the qualifying
selections wins.
spend
Otherwise the maximum amount you are prepared to lose if
none of them wins.
Adjusting Bet full Choose whether you want to place bets as per the
amounts amounts calculation of "Amount to win/lose" or whether you want the
sizes of the bets adjusted to the current offer in the market.
Adjust amounts
If "Adjust amounts" is chosen, the bets will be resized so as
to be matched by the amounts offered at the corresponding
prices. Otherwise there is some risk that they will stay
unmatched.
Bet Lifetime Trigger This is the period of time in seconds during which the
Expression unmatched bet will stay in the market. After this time has
elapsed, the bet will be automatically cancelled by the
program. E.g. if the lifetime of a bet is 3 sec. and the bet is
unmatched after it has been placed in the market, then it will
be cancelled at 3 sec. after this.
Behaviour
Performs Dutching with the specified settings by placing lay bets on the qualifying selections
Read more about Dutching.
If a market supports bet persistence, unmatched bets will be flagged according to the Action at In-
Play parameter.
Name of trigger String Choose the name of the trigger block you want to close
block
Behaviour
Finds a trigger block with the name specified and resets the state of all triggers in that block so that
they can be executed again.
If the block's "Repeat" parameter is set to "no more often than" or "specific number of times" you must
add a trigger that closes the block which effectively gives the program a command to repeat the block.
In the conditions of the closing trigger put the criteria for repeating the block, and be as accurate as
possible. For example, if you repeatedly bet and green up, in the closing trigger put a condition that
checks that there aren't any unmatched bets and that every selection's back and lay payouts are
equal (or differ very slightly).
Behaviour
Safely deletes the market from the program. Use this action often to delete markets that you no
longer need to refresh.
Behaviour
Safely deletes every market that belongs to the same event as the market where the trigger has been
executed. Use this action to bulk delete all markets from an even you no longer need to refresh, e.g. a
football match.
Cancel Options
Behaviour
Finds unmatched back bets on each qualifying selection and matches those that satisfy the
conditions in Cancel Options at the best available prices.
Cancel Options
Behaviour
Finds unmatched lay bets on each qualifying selection and matches those that satisfy the conditions
in Cancel Options at the best available prices.
Text Trigger The text to write into the action log. You can include
Expression variables and other trigger expressions in square brackets,
to distinguish them from plain text. Example:
Behaviour
Adds a message to the action log. The text of the message is taken from the corresponding
parameter. All variables and trigger expressions (if any) are parsed before the message is added.
Text Trigger The text to write to the file. You can include variables and
Expression other trigger expressions in square brackets, to distinguish
them from plain text. Example:
To remove one line from the beginning of the file, use the
keyword [rmv_first]; to remove the last line from the file,
use [rmv_last]. A line is a string of characters ending with a
line break (the \n or \r character).
File path Path to the file The path to the file where to write the specified text. If a file
with the entered name does not exist, the trigger will try to
create it.
c:\data_[market_id]_[now_time_date_str].txt
Rewrite existing Checkbox Tick this box to rewrite the existing contents of the specified
contents file. If you leave it unticked, the text will be added at the end
of the file.
Behaviour
Writes the specified text into the file in the chosen path. All variables and trigger expressions (if any)
are parsed before the text is written.
26. remember
Name Trigger The name for the set of remembered selections. You may
Expression include variables in this name. They will be parsed and
converted into real values at the moment of the trigger's
execution.
How to update the Create a new If the trigger is to be repeated more than once in the same
list list every time market, this parameter defines what to do with the previous
list of remembered selections. If "Create a new list every
Add new to
time" is selected, the old list will be deleted and replaced
already
with the new remembered selections.
remembered
If "Add new to already remembered" is selected, the trigger
will add new qualifying selections to those already in the
list.
Behaviour
Makes a list of qualifying selections, names it according to the Name parameter and remembers it.
All properties of the remembered selections, such as their prices, volume %, offered amounts etc.
will be remembered as they were at the moment of the trigger's execution. If you also choose
"Remember selections' bets", all properties based on bets (Profit/Loss, back & lay matched amounts
etc.) will be remembered too.
You will then be able to access the remembered selections through Remembered Selections
Variables. This way you will be able to track changes that selections undergo with time. For instance,
you will be able to compare a selection's volume % now and 5 mins ago by comparing their volume
variable.
27. back at SP
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Places one "back at SP" bet on each qualifying selection. This is a special type of bet not to be
confused with placing a regular back bet at the actual starting price after the off. The price limit and
liability of each bet are evaluated from the expressions in those fields. If a market does not support
SP betting or if it is already In-Play, the action will do nothing.
28. lay at SP
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Places one "lay at SP" bet on each qualifying selection. This is a special type of bet not to be
confused with placing a regular back bet at the actual starting price after the off. The price limit and
liability of each bet are evaluated from the expressions in those fields. If a market does not support
SP betting or if it is already In-Play, the action will do nothing.
Cancel Options
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Finds unmatched back bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options. Then places one "back at SP" bet on each qualifying selection. This is
a special type of bet not to be confused with placing a regular back bet at the actual starting price after
the off. The price limit and liability of each bet are evaluated from the expressions in those fields. If a
market does not support SP betting or if it is already In-Play, the action will do nothing.
Cancel Options
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Finds unmatched lay bets on each qualifying selection and cancels those that satisfy the conditions
in Cancel Options. Then places one "lay at SP" bet on each qualifying selection. This is a special
type of bet not to be confused with placing a regular back bet at the actual starting price after the off.
The price limit and liability of each bet are evaluated from the expressions in those fields. If a market
does not support SP betting or if it is already In-Play, the action will do nothing.
Cancel Options
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Finds unmatched lay bets on each qualifying selection and cancels those that satisfy the conditions
in Cancel Options. Then places one "back at SP" bet on each qualifying selection. This is a special
type of bet not to be confused with placing a regular back bet at the actual starting price after the off.
The price limit and liability of each bet are evaluated from the expressions in those fields. If a market
does not support SP betting or if it is already In-Play, the action will do nothing.
Cancel Options
Price Limit Trigger Price limit of an SP bet. If left empty, no price limit is
Expression imposed.
Liability Trigger Liability of bet (for lay bets) or bet size (for back bets)
Expression
Behaviour
Finds unmatched back bets on each qualifying selection and cancels those that satisfy the
conditions in Cancel Options. Then places one "lay at SP" bet on each qualifying selection. This is a
special type of bet not to be confused with placing a regular back bet at the actual starting price after
the off. The price limit and liability of each bet are evaluated from the expressions in those fields. If a
market does not support SP betting or if it is already In-Play, the action will do nothing.
Behaviour
Behaviour
Text Trigger The text to send to your email address. You can include
Expression variables and other trigger expressions in square brackets,
to distinguish them from plain text. Example:
Behaviour
Sends an email message to the address and using the settings configured in Email & SMS Options.
The text of the message is taken from the corresponding parameter. All variables and trigger
expressions (if any) are parsed before the message is sent.
Text Trigger The text to send to your mobile number. You can include
Expression variables and other trigger expressions in square brackets,
to distinguish them from plain text. Example:
Behaviour
Sends a text message to the mobile number and using the settings configured in the SMS Service
window. The text of the message is taken from the corresponding parameter. All variables and trigger
expressions (if any) are parsed before the message is sent.
37. alert
Behaviour
Shows a message box with the names of the qualifying selection and the name of the trigger when
its conditions are satisfied.
File Path String The path to the sound file (WAV) to be played.
Behaviour
Plays a sound from the file specified once the trigger's conditions are met.
Scope Individually for Determines whether the win/lose history is wiped for all
each sport types of sports or for the current one only.
Globally
Behaviour
Clears all history of wins and losses (based on your account statement) and zeroes all Win/Lose
History Variables.
Value Trigger The value that you want to assign to the default back
Expression amount.
Scope This market Determines in what markets the default back amount will
be set to the specified value.
All markets
Refreshed
markets
Behaviour
Assigns the given value to the default back amount in the chosen market(s).
Value Trigger The value that you want to assign to the default lay amount.
Expression
Scope This market Determines in what markets the default back amount will
be set to the specified value.
All markets
Refreshed
markets
Behaviour
Assigns the given value to the default lay amount in the chosen market(s).
Value Trigger The value that you want to assign to the default SP back
Expression amount.
Scope This market Determines in what markets the default back amount will
be set to the specified value.
All markets
Refreshed
markets
Behaviour
Assigns the given value to the default SP back amount in the chosen market(s).
Value Trigger The value that you want to assign to the default SP lay
Expression amount.
Scope This market Determines in what markets the default back amount will
be set to the specified value.
All markets
Refreshed
markets
Behaviour
Assigns the given value to the default SP lay amount in the chosen market(s).
Behaviour
Changes the rate at which the market is refreshed before its start to the given value.
Behaviour
Changes the rate at which the market is refreshed after its start (after it turns In-Play) to the given
value.
Behaviour
Stops refreshing the market. Triggers will no longer be executed in this market.
Rule Random The rule by which the winners in the market are
determined.
By Last Price
Random By Rank
Winners determined
by trigger
Behaviour
Settles the market in Test Mode. Read about Bet Settlement Simulator. The winners are appointed
according to the specified rule. The first three rules are described in the Bet Settlement Simulator.
The rule "Winners determined by trigger" takes all selections that were affected by the specified
trigger and makes them the winners in the market. Of course that trigger must be executed in the
market before the settlement takes place.
Text Trigger The text to write into the Excel cell. You can include variables
Expression and other trigger expressions in square brackets, to
distinguish them from plain text. Example:
Cell Address Trigger The address of the Excel cell. Must be of the following
Expression format:
{sheet_name}!{cell_address}
Example:
Sheet1!A2
querymarket_id!Dsel_index
Behaviour
Writes something into an Excel cell with the specified address. The text is taken from the
corresponding parameter. All variables and trigger expressions (if any) are parsed before the text is
written.
Name of trigger or String Choose the name of the trigger or block you want to activate
block
Behaviour
Finds a trigger or a trigger block with the name specified and makes it "Enabled". If it was already
enabled or if no trigger or trigger block with such name are found, the trigger does nothing.
Name of trigger or String Choose the name of the trigger or block you want to
block deactivate
Behaviour
Finds a trigger or a trigger block with the name specified and makes it "Disabled". Triggers and
blocks that are not enabled will not be executed. If it was already disabled or if no trigger or trigger
block with such name are found, the trigger does nothing.
A special set of options can be configured for every trigger action that involves doing something with
unmatched bets (most often cancelling them).
These options define additional properties that an unmatched must possess in order to be cancelled
or matched. If a bet does not satisfy these conditions, it will be skipped by the trigger action.
Apply the action only to bets that have the specified bet persistence. If a market does not support
persistence, this option is ignored.
Specify the price range for the bets that must be affected by the action.
Specify the amount range for the bets that must be affected by the action.
In actions that do both cancelling and betting (such as cancel then back), this option defines
whether the action is permitted if there are no unmatched bets to cancel. I.e. if the action is "cancel
then back" and there aren't any back bets to cancel for that selection, setting this to "Do not bet if
no bets to cancel" will prevent the action from placing new back bets. Otherwise the action will go
ahead with betting even if it didn't cancel any unmatched bets.
9.4.2 Selections
This field determines what selections the trigger will be applied to.
Those selections will be chosen by the program before the trigger's conditions are checked, so the
Selections field has a higher priority.
Applies the trigger to all selections that satisfy its conditions. If there are no conditions in the
trigger, it will be applied to all selections in the market.
Applies the trigger to the first selection out of those that satisfy its conditions. Matching
selections are by default sorted by their back price, but you can change their sorting order
applying the condition Selection's Sorting Order is defined by.
Applies the trigger to last selection out of those that satisfy its conditions. Matching selections
are by default sorted by their back price, but you can change their sorting order applying the
condition Selection's Sorting Order is defined by.
Applies the trigger to all selections except those that satisfy its conditions.
Applies the trigger to the first selection out of those that do not satisfy its conditions. Matching
selections are by default sorted by their back price, but you can change their sorting order
applying the condition Selection's Sorting Order is defined by.
Applies the trigger to the last selection out of those that do not satisfy its conditions. Matching
selections are by default sorted by their back price, but you can change their sorting order
applying the condition Selection's Sorting Order is defined by.
7. Favourite
8. Second Favourite
Applies the trigger to the second lowest priced selection in the market.
9. Third Favourite
Applies the trigger to the third lowest priced selection in the market.
10.Fourth Favourite
Applies the trigger to the fourth lowest priced selection in the market.
11.Fifth Favourite
Applies the trigger to the fifth lowest priced selection in the market.
Applies the trigger to all selections in the market except the lowest priced selection.
13.Underdog
14.Second Underdog
15.Third Underdog
Applies the trigger to all selections in the market regardless of the conditions.
9.4.3 Markets
Fill in this trigger field to define the markets where the trigger will be executed.
1. All Markets
2. Horse Races
The trigger can be executed only in Horse Races (and Horse Racing - Todays Card).
3. Win Markets
4. Place Markets
5. Non-Races
The trigger can be executed only in markets not belonging to Horse Races or Greyhound Races.
6. Greyhound Races
The trigger can be executed only in Greyhound Races (and Greyhound Races - Todays Card)
7. Soccer Games
The trigger can be executed only in markets belonging to Soccer or Soccer Fixtures.
8. Tennis Matches
9. Financial Markets
The trigger can be executed only in markets from the Financial Markets category.
1. All Markets
Applies the trigger to all markets, i.e. the status does not matter.
2. In-Play
3. Idle
Applies the trigger to markets that are in an "idle" state, i.e. they are active but not In-Play,
waiting to start.
4. Suspended
5. In-Play or Suspended
7. Settled
Applies the trigger to markets that have been settled. A market is considered settled in these
cases:
or
It has finished and all real bets placed in this market have been settled and reflected in the
account statement. If there were no bets, then the market is settled if the program could download
the market's outcome and identify its winners. You ought to have this option turned on for this to
work correctly.
Use this status in triggers that modify a stake size in staking plans.
9.4.5 Execute
This field determines how many times and how often the trigger will be executed if all its conditions
are satisfied.
The trigger will be executed once in any market of the current racecourse or Greyhound racing
stadium (e.g. Wolverhampton for UK horse racing, Beaudesert for Australian horse racing or
Nottingham for UK Greyhound racing) where it will fire first. Once it has fired in the given
racecourse/stadium, it will never be executed in the same racecourse again (unless you reload
the triggers of course).
The trigger will be executed one time in any market of the current sports event (e.g. a race, a
football match, a tennis meeting) where it will fire first. E.g. if you monitor Match Odds and Correct
Score of two football matches, Barcelona v Real Madrid and Manchester United v Aston Villa, then
if the trigger has fired in Correct Score of Barcelona v Real Madrid, it will not then fire in the Match
Odds market of that same event. It may, however, fire in Match Odds or Correct Score of the other
game, Manchester United v Aston Villa, but again -- only once, no matter how many markets you
are monitoring from that game.
The trigger will be executed one time in each market where its conditions are satisfied. Then the
program will stop checking this trigger in that market.
The trigger can be executed one time per each qualifying selection. The program will keep
checking it until all selections in the market are affected by the trigger.
The trigger will be checked at certain time intervals and executed whenever its conditions are met.
The length of these time intervals cannot be shorter than the value specified. But it can be longer,
subject to the market refresh rate value. I.e. if you set it to "no more often than 1 sec" and
markets are refreshed every 3 sec, the trigger will be checked every 3 sec instead of 1.
The trigger will be checked and executed (if its conditions are met) every time a market is
refreshed. Once it has been executed the number of times specified, the program will stop
checking it.
The trigger will only be executed one time in the first market where its conditions are met.
9.4.6 Conditions
Conditions act in addition to the other trigger parameters to determine when it should or should not
be executed.
You may execute a trigger when its conditions are met or not met, depending on what's more
convenient in a particular situation.
Logical Operator
Body
Parameter
Additional Parameters
Comparison Operator
Value(s)
Additional parameters and comparison operators are specific to the Body and Parameter of the
condition and may vary.
Logical (or Boolean) operators compare expressions that return either TRUE or FALSE. Their result
also gives either TRUE or FALSE.
AND
OR
Returns TRUE if at least one of the expressions is TRUE. If none of them is TRUE, the result will
be FALSE.
If you connect two conditions with this operator, the resulting list of qualifying selections will
combine those that satisfied each condition.
AND NOT
Returns TRUE if the first expression is TRUE, and the expression standing next to AND NOT is
FALSE.
OR NOT
Returns TRUE is the first expression is TRUE, or the expression standing next to this operator is
FALSE.
and not Selection's Back Price is greater than and Selection's Back Price is equal or less than
3.0 3.0
and not Any Other Selection's Lay Matched is and All Other Selections' Lay Matched is not
equal to 0 equal to 0
or not Every Selection's Profit/Loss is greater or At Least One Selection's Profit/Loss is equal or
than 0 less than 0
and not All Other Selections' Rank is greater and Any Other Selection's Rank is equal or less
than sel_order than sel_order
and not At Least One Selection's Back and Every Selection's Back Unmatched is equal
Unmatched is greater than 2 or less than 2
9.4.6.2 Body
1. Selection's
Looks for one or more selections in the market in that satisfy a condition. If there are conditions
preceding this one, it will narrow down the list of selections to search in to those that satisfied all
previous conditions.
Examples:
This w ill look for all selections in the current m arket that have m atched back bets on them
The first condition w ill look for all selections w ith m atched back bets. The second condition w ill look
for all selections w hose price is less than 1.1 am ong those w ho have m atched back bets. Thus the
search scope of the first condition is the w hole m arket, w hile the search scope of the second
condition is the results of the previous condition.
If you change the logical operator to "OR", the search scope of both conditions w ill be the w hole
m arket. Thus the selections each of them finds are added up.
Checks if at least one selection that did not satisfy the previous conditions meets the current
condition.
Example:
Looks for selections w ith m atched back bets, then checks w hether any other selection in the m arket
has m atched lay bets. So if there is at least one w ith lay bets that does not have back bets, the
conditions are satisfied.
If there are no previous condition, the program will choose "other" selections against the Selection
field of the trigger.
Checks if all selections except the ones that satisfy the previous conditions meet the current
condition.
Conditions w ill be satisfied if there are selections w ith m atched back bets, and if all other selections
in the m arket have lay m atched bets.
If there are no previous condition, the program will choose "other" selections against the Selection
field of the trigger.
4. Every Selection's
Checks if there is at least one selection in the market that satisfies the current condition. It is
different from "Selection's" because it ignores all previous conditions, whereas "Selection's" acts
like a filter.
Compare the example with that in "Selection's":
Looks for all selections w ith m atch back bets. But also checks w hether there is at least one selection
priced below 1.1. It could be a selection that fits into the first condition, but not necessarily. If it doesn't
find such selection, the conditions are not satisfied.
6. Favourite's
Checks if the favourite, i.e. the selection with the lowest price, meets the condition.
7. Second Favourite's
Checks if the second favourite, i.e. the selection with the second lowest price, meets the
condition.
8. Third Favourite's
Checks if the third favourite, i.e. the selection with the third lowest price, meets the condition.
9. Probable Loser's
Checks if the selection with the highest price, meets the condition.
1. Trigger
Checks that a trigger satisfies the condition. You get to choose the trigger's name from the drop-
down list:
1. Market's
Checks whether some parameter of the current market satisfies the condition.
Checks the parameters of the horse race that immediately precedes the current market
(according to its start time).
Checks the parameters of the football market that immediately precedes the current market
(according to its start time).
4. Previous Event's
Checks the parameters of the market that immediately precedes the current market (according to
its start time). It can belong to any sport.
Checks the parameters of the market that immediately precedes the current market (according to
its start time), provided that the current trigger has been applied to that market. That is, the
program will look for markets where the trigger has been executed before. If it finds one or more
such markets, it will pick the one that starts just before the current market. If there aren't any that
fall in this category, the condition will not be satisfied.
Global
Checks conditions that concern the whole application or some parameters that don't apply to any
selection, market or trigger.
9.4.6.2.1 Difference betw een Selection’s, Any Other Selection’s, All Other Selections', Every Selection’s and At Least One
Selection’s
Selection’s
This one picks each selection in the list and then checks the conditions against it. What is in the list
it picks from, depends on what you’ve set for the Selections property:
If it’s “All Matching Selections”, then the trigger will check each selection in the market that meets
your previous conditions. If you put “Selection’s” in the first condition, then all selections in the
market will be checked, and those that match the criteria will be considered “Matching”. The next
condition will then look among those “matching” ones. Basically, Selection’s works as a filter:
The second one picks the first and seconds favourites out of the ones that matched the first
condition. If the first and second favs are prices less than 5.0, these conditions will produce zero
matching selections.
This one literally takes any other selections, apart from the one you have picked, and checks the
conditions against them. If they satisfy the condition, the selection to which they are “other” is
considered as “matching”.
It’s like when you go to a restaurant, and when the waiter asks you what you would like to eat, you
ask him back: is there any other pasta with meat, apart from spaghetti Bolognese? He says, “Yes,
we also have pasta with meatballs, but it’s twice as expensive”, and so your matching selection is
the spaghetti Bolognese, because you’ve only got a tenner to spend.
A typical example would be to check a settled market in order to establish if a particular horse has
NOT won in a race. You would check if the horse’s winning place is 0 and any other horse’s place is
1. Because if every horse’s place is zero, then it means the race has not finished yet.
Note how you add the prefix “other_” in front of any selection variable you want to use to define that
“other” selection. It will let the program know that you mean the other selection, not the matching
one.
This option is very similar to the previous one, except that it implies that absolutely all selections,
other than the matching one, meet the condition.
If we further examine the previous example with pasta, the waiter’s response could be “no, all other
pastas are either vegetarian or seafood”. In that case, his response could be formalised in the
following way:
In terms of betting, suppose you want to lay on a selection if it is the only selection with a matched
back bet. You could do this by adding these conditions:
Every Selection’s
Unlike simply Selection’s, this condition does not work as a filter, but rather as a switch: Yes/No. If
every selection in the market meets the condition, then the trigger will go on to checking the next
condition or to actually performing its action if it was the last condition in the list. If, however, there is
any selection that fails to meet the criteria, the resulting number of matching selections will be zero,
and the trigger will not perform.
Example: you want to restart your green-up cycle (where you lay then back to an equal profit) only
after there are no unmatched bets on any of the selections. You would then make sure that:
As the name suggests, this option looks for at least one (there could be more) selection that
satisfies the criteria. It is also a Yes/No switch, not a filter.
How is this option different from Any Other Selection’s? Here’s an example.
The above trigger will pick the favourite if it has a matched lay bet and if you have any matched back
bets in this whole market. You could have placed both back and lay bets on that favourite alone. Or
you could lay on the favourite and then back on the second favoruite. Either way, the trigger will
work.
This trigger will only work if there is a lay bet on the favourite and a back bet (or several of them) on
the rest of the selections. Unlike the previous trigger, it will not work if you only placed your bets on
the favourite.
9.4.6.3 Parameter
Selection Parameters
1. Back Price
2. Lay Price
4. Rank
The rank of the selection by its back price. The favourite, that is the selection with the lowest
price, gets a rank of 1. The selection with the highest price gets the highest rank value which is
equal to the number of selections in the market.
5. Trigger Expression
Any expression you want to evaluate against the selection. Can consist of arithmetic
expressions, trigger variables, user variables and functions. Although a trigger expression may
not be a direct property of a selection, the program will look for possible selection specific
variables in it. That is why this parameter is attributed to selection. But in fact it can contain any
kind of expression, such as:
6. Profit/Loss
7. Index
The index of the selection in the list from top to bottom. It is determined by the way BetFair
arranges selections in the market.
8. Back Matched
9. Lay Matched
Total amount of all your back bets that are unmatched on the selection.
Total amount of all your lay bets that are unmatched on the selection.
The sum of the amounts of all your matched back bets on the selection multiplied by their
prices.
The sum of the amounts of all your matched lay bets on the selection multiplied by their prices
The sum of money offered for this selection at the current best back price
The sum of money offered for this selection at the current best lay price
The actual starting price (becomes non-zero only at In-Play and only in markets that support
SP).
24. Volume %
The percentage of the money traded on the selection as compared to the total amount of money
traded in this market. Can be anything from 0 to 100.
The change of the back price over the last refresh, in price ticks.
The change of the lay price over the last refresh, in price ticks.
The change of the back price over the specified number of last minutes. For example, if the price
changed from 3.8 to 4.2, this will be equal to 0.4.
The change of the lay price over the specified number of last minutes.
The change of the back price over the specified number of last minutes, in price ticks. So, if the
price has dropped from 2.0 to 1.82, this will be equal to -18.
The change of the lay price over the specified number of last minutes.
This parameter is now outdated and remains in the list for compatibility with the older versions.
You should now use:
Trigger {name} number of runs per selection is greater than 0
The total amount of money offered for the selection on the back side. If you have the option
"Retrieve all price offers" on, this will include all prices ever offered for the selection. Otherwise
it'll be equal to the sum of the offers at the three current best back prices.
The total amount of money offered for the selection on the lay side.
Checks whether the selection falls into the list of selections that form the specified back book%.
The program adds up all chances of winning (100.0/back price), starting from the favourite. Once
it adds the chance of the current selection, it stops and checks whether the obtained figure
satisfies the selection.
Example.
Checks whether the selection falls into the list of selections that form the specified lay book%.
Is identical to the previous parameter, but works with lay prices.
Checks whether the selection falls into the list of selections that form the specified back book%
in reverse order. The program adds up chances of winning starting from the selection with the
highest price. Once it's added the chances of the current selection, it stops and checks whether
the obtained figure satisfies the condition.
Checks whether the selection falls into the list of selections that form the specified lay book% in
reverse order.
The best back price the selection was trading at before the market turned In-Play.
The best lay price the selection was trading at before the market turned In-Play.
41. Name
Selection's Name.
42. Handicap
Horse's Stall Number. Has a value only in markets where silks are available.
Horse's Cloth Number. Has a value only in markets where silks are available.
45. Age
Horse's age. Has a value only in markets where silks are available.
Horse's weight in pounds. Has a value only in markets where silks are available.
The number of days since the horse last participated in a race. Has a value only in markets
where silks are available.
Horse's official rating. Has a value only in markets where silks are available.
The Claim of the horse's jockey. Has a value only in markets where silks are available.
50. Form
The name of the horse's jockey. Has a value only in markets where silks are available.
This is a special condition that can be applied only to the Body "Selection's". It is not a
condition, but rather an action that you perform on all selections that matched the trigger's
conditions so far. It sorts all matching selections by the value that you specify in the text box.
The selection whose value is the minimum will come first, and the one with the maximum value
In this picture the trigger finds selections with matched lay bets, then sorts them by their volume
percentage.
So if the Selections parameter of this trigger is Last Matching Selection, the trigger's actions will
be applied to the selection with the highest volume.
You can sort matching selections several times within the same trigger conditions.
In this example the trigger finds selections with matched lay bets, sorts them by their volume,
checks that the lowest volume% is greater than 1%, then sorts all matching selections by their
last traded price.
Trigger Parameters
1. Number of runs
The number of times the trigger with the chosen name has been executed. If "overall" is
ticked, this number is cumulative for all markets that have been refreshed since the start of
the program. Otherwise this number is counted only for the current market.
When the block to which the trigger belongs is set to repeat more than once, the number of
runs will be reset each time the block is repeated.
Please note: a "run" is counted each time the trigger fires, regardless of the number of
selections it applies to. For example, if the trigger is set to be executed "once per
selections", and it first backs on 2 selections and then on 3 more (and the corresponding line
in the Active Triggers window flashes green twice), the number of runs will be equal to 2, not
5. If the trigger is set to "repeat no more often than 10 sec" and repeatedly backs four times
on the same horse, the number of runs will be equal to 4.
The number of times the trigger has fired across all markets of the current sports event. E.g.
if the trigger is set to back on the favourite, and you monitor Win, Place and Each Way
markets of each horse race, then the number of runs in the sports event will likely be equal to
3 (one favourite per each market). Likewise, if you monitor, say, Over/Under 0.5 Goals
through Over/Under 4.5 Goals and the trigger is set to lay on "Under", then the number of
runs in the sports event (after all the bets have been placed of course) will be equal to 5.
The number of times that trigger has fired in any of the markets that have taken place in the
given racecourse (for horse racing) or Greyhound stadium (for Greyhound racing). The
markets can belong to events that start at different times, the important thing is that they are
held at the same racecourse/stadium (for example, Ascot or Newbridge).
The number of times the trigger with the chosen name has been executed on the qualifying
selections.
Find selections w ith the last traded price less than 5 on w hich the trigger nam ed "laying" w as
executed at least once.
Market Parameters
1. Name
Market's full name. Example: Soccer / English Football / League Two / Fixtures 31 October /
Accrington S v Morecambe / Match Odds - Match Odds. The most common usage of this
parameter is for checking whether some pattern is present in the market's name, e.g.
Market's Name contains "Hcap"
2. Number of Selections
The number of selections in the market. This includes both selections active for auto-trading and
those that are not.
3. Matched Volume
The total amount of money (in your currency) matched in this market.
4. Back Book %
Back Book percentage made of all selections' back prices. Takes a value from 0 to 100.
5. Lay Book %
Lay Book percentage made of all selections' lay prices. Takes a value from 0 to 100.
6. Number of Places
7. Status
8. Race Status
The current status of the race, if the market belongs to a horse race or a Greyhound race. This
is not to be confused with just the Status. A race can have one of the following statuses:
This condition works only if you turn on the setting "Download race status".
9. SP
10.In-Play Mode
Checks whether the market will turn In-Play after the event starts.
The number of all your matched back bets placed in this market.
The number of all your matched lay bets placed in this market.
The number of all your unmatched back bets placed in this market.
The number of all your unmatched lay bets placed in this market.
The number of your bets that have been settled in this market. Settled bets are taken from your
account statement (in both Test Mode and real money mode), so you need to make sure it is
updated (configure "General Options" accordingly).
The total net profit/loss you made in the market, provided it is in Settled state. Read how to
determine whether a market is settled.
The P/L is made of all your settled bets and commission.
The number of minutes left till the market's start ("the off").
The number of minutes that have passed since the market's start.
The number of minutes that have passed since the market was last suspended.
The number of minutes that have passed since the market last started refreshing. If you stop
and restart refreshing, this value will be reset.
The number of minutes that have passed since the last goal (e.g. in Football) or point (e.g. in
tennis) was scored in the market. If no goals/points have been scored, this condition will check
the number of minutes since the start of market refresh.
Checks whether the Score in this market (if it is available) has changed or not changed. The
score may become available if you turn this option on. If the score in the market has changed,
this condition will "think" that the score has changed until the trigger is executed. After that if
you want to check the score again, you will need to repeat this trigger.
The number of withdrawn runners in the market. If none are withdrawn, this will be equal to 0.
The special code of the market that defines the types of its selections as well as bets that can
be placed in that market. This is currently available for markets in Horse Racing, Greyhound
Racing, Soccer and Tennis. A market can be assigned one of the following codes:
So, for example, suppose you have added the following condition:
If this condition is checked in a Correct Score market, it will be satisfied (i.e. return TRUE),
otherwise it will return FALSE.
So this is effectively a way to determine whether your market is of a specific type, e.g. if you are
coding a strategy involving different market types within the same football match. The market's
betting code can be obtained through a variable market_code.
Note that you will have to enter an additional parameter for Over/Under (Soccer) and First Half
Goals (Soccer). This should be the number of goals in the name of the market, i.e. 0.5, 1.5, 2.5
etc. The following condition will return TRUE in an Over/Under 2.5 Goals market and FALSE - in
an Over/Under 1.5 Goals or any other type of market.
Global Parameters
The amount of money you have won or lost in the last settled market where you were betting.
The profits and losses from all bets that you placed in that market as well as the exchange
commission (if any) are added up to make this figure. Make sure your account statement is set
to be updated.
The total amount you have won or lost based on your account statement records. The number of
settled bets that make up this figure depends on the size of the statement that you configure in
General Options.
3. Current Time
Checks the parameters of the current time. The examples of acceptable time notation are given
below:
14:00
05:00 PM
12:30
22:15:03
01:12:45 AM
06:00
If neither "AM" nor "PM" is given, the standard numeration from 00:00 to 23:59 is applied.
You may also add a date in the following format: dd/mm/yyyy. The date must stand in front of the
time value, for example:
01/05/2008 12:20
08/12/2009 05:12:02 PM
15/11/2017 17:14
Also, you may check the current day of week. The acceptable values of weekdays are listed
below:
Sunday is considered the first day of week. So if you use expressions such as "is less than", "is
greater than", take into account that "Sun" is less than "Mon", "Sat" is greater than "Fri" and so
on. To make it easier to understand, you can mentally assign each day of week a number from 1
to 7, "Sun" being "1" and "Sat" being "7".
Also, you may check the current month. The acceptable month names are listed below:
Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec.
Example:
This will return true if the current month is either Jan, Feb, Mar, Apr or May.
You can't combine weekdays and/or months and date/time values in one condition. For example,
the following notation is NOT allowed:
To check both day of week, month and date and/or time, you must create two or more
conditions. For instance:
Note: if you use comma as the decimal separator ("," instead of "."), you will need to separate
values in a list with semicolons. For example:
4. User Variables
Check whether one or more user variables are set. You can separate two or more variable
names with a comma.
You can also check remembered selections variables here.
Check whether there are new records in your Account Statement since the trigger was last
executed. You can choose to look up transactions belonging to a sport type, to the current
market or globally.
If you can't find a parameter you need, try checking whether it can be expressed through a
corresponding trigger variable.
Comparison operators, as their name implies, allow you to compare two values (operands). The
result of applying such an operator is either TRUE or FALSE. See the list of supported comparison
operators below.
For string operands (please note that string comparisons are case insensitive, i.e.
ABC is equal to abc):
is equal to
Returns TRUE if both operands are equal, or FALSE otherwise. You must enclose each operand
in double quotes when comparing operands that may contain spaces. E.g.:
Selection's Name is equal to "Marine Captain"
is not equal to
contains
Returns TRUE if some part of the left operand is equal to the right operand, or FALSE otherwise.
Market's Name contains "Hcap".
Returns TRUE if none part of the left operand is equal to the right operand, or FALSE otherwise.
is in list
Returns TRUE if the left operand is equal to one or more strings separated by commas and listed
in the right operand.
Selection's Name is in list "The Draw", "0 - 0", "1 - 1"
Please note that the right operand must not be a trigger expression, i.e. it shouldn't include
variables.
is not in list
Returns TRUE if the left operand is not equal to any of the strings listed in the right operand.
is in file
Returns TRUE if the left operand is equal to one or more strings listed in the text file whose path is
specified in the right operand, or FALSE otherwise. In the file, each string must be placed on a
separate line. Trigger expressions in the right operand will not be parsed. Use the "Browse" button
to choose the file on your disk.
You can also specify an URL instead of a path to the text file. The requirements for the page's
format are the same as above. The URL must start either with "http" or "https", e.g. "https://
dl.dropboxusercontent.com/u/12345678/testfile.txt"
is not in file
Returns TRUE if the left operand is not equal to any of the strings listed in the file with the path
specified in the right operand (or a page with the URL specified), or FALSE otherwise.
is equal to
is not equal to
is less than
Returns TRUE if the left operand is less than the right operand, or FALSE otherwise.
is greater than
Returns TRUE if the left operand is greater than the right operand, or FALSE otherwise.
Returns TRUE if the left operand is equal or less than the right operand, or FALSE otherwise.
Returns TRUE if the left operand is equal or greater than the right operand, or FALSE otherwise.
is between
Returns TRUE if the left operand is equal or greater than the first right operand, and is equal or
less than the second right operand, or FALSE otherwise. Examples of comparisons that return
TRUE:
5 is between 4 and 6
-8 is between -8 and 0
10 is between 1 and 10
is outside
Returns TRUE if the left operand is less than the first right operand, or is greater than the second
right operand; otherwise returns FALSE. Examples of comparisons that return TRUE:
7 is outside 8 and 20
0 is outside -5 and -2
14.5 is outside 13 and 14
is in list
Returns TRUE if the left operand is equal to one or more values separated by commas and listed
in the right operand, or FALSE otherwise. Trigger expressions in the right operand are not parsed.
Selection's Index is in list 3, 6, 8
is not in list
Returns TRUE if the left operand is not equal to any of the values listed in the right operand, or
FALSE otherwise.
is in file
Returns TRUE if the left operand is equal to one or more values listed in the text file whose path is
specified in the right operand, or FALSE otherwise. In the file, each value must be placed on a
separate line. Trigger expressions in the right operand will not be parsed. Use the "Browse" button
to choose the file on your disk.
is not in file
Returns TRUE if the left operand is not equal to any of the values listed in the file specified by the
right operand, or FALSE otherwise.
is the maximum
Returns TRUE if the expression in the left operand has the maximum value among all selections
that met previous trigger conditions, or FALSE otherwise. To do this comparison, the program
evaluates the same expression specified by the left operand for all qualifying selections. It then
determines the one with the maximum value and compares it with the value of left operand for the
current selection.
is the minimum
Returns TRUE if the expression in the left operand has the minimum value among all selections
that fit previous trigger conditions, or FALSE otherwise.
Returns TRUE if the expression in the left operand has the maximum value among all active
selections in the market, or FALSE otherwise. To do this comparison, the program evaluates the
same expression specified by the left operand for all active selections in the market, no matter
whether they qualify for this trigger or not. It then determines the one with the maximum value and
compares it with the value of the left operand for the current selection.
Returns TRUE if the expression in the left operand has the minimum value among all active
selections in the market, or FALSE otherwise.
You may be struggling with finding some conditions you are used to. Don't worry, the new version is
fully compatible with all older conditions, they are just called differently or situated in a different
category.
1. Any Selection's
We've dropped the word "Any" and combined this option with "Selection's". They act in the same
way, so we decided to avoid any confusion. Now if you want to apply a trigger to "All Matching
Selections", you just choose "Selection's", just as you do if you apply it to, say, "Favourite".
2. Trigger Expression
As all trigger expression are evaluated against the current selection, even if they don't contain
selection variables, this option has been made a parameter of a selection:
So if an expression does not contain selection specific variables, choose "Selection's" as the
default Body. This also applies to all trigger expressions containing market or global variables.
If you do want to evaluate the expression against some particular selection, choose the
appropriate Body for it.
Since these are market specific parameters, they've been made Parameters of a corresponding
Market's Body.
4. Affected by Trigger
This option has been rephrased to "Trigger number of runs per selection is greater than 0 / is
equal to 0"
So the condition on the picture would be equivalent to "Selection's Affected by Trigger laying".
Accordingly, to check that a selection was not affected by a trigger, change "is greater than 0" to
"is equal to 0".
6. Last Won/Lost Amount, Total Won/Lost Amount, Current Time, User Variables
9.4.7 Variables
Trigger variables are special keywords that the program replaces with certain values.
You can use trigger variables in trigger expressions and in any text field in the Triggers Editor. The
value of each variable will be calculated with regards to the moment in which the trigger is being
checked (simultaneously with refreshing a market).
You must make sure you use the correct spelling of all variables. To help you with this task, we've
designed the Formula Builder in which you just select the right variable and click on its name to add
it to your expression.
Some variables may contain prefixes and indexes. A word in curly brackets denominates an index,
so you need to replace it with a digit.
You can view the current values of variables in the User Variables window.
9.4.7.1 General
General variables return values common for the whole trading session.
Below is the full list of such variables with description.
test_funds floating point Total test funds available for test betting
my_funds floating point The total amount of current funds (either test
or real, depending on whether the Test
Mode is on) available for betting
base_price floating point This is the price of the base bet for any lay
bets below the minimum. The first bet is
always the minimum amount in your
currency at the lowest possible price (the
base price). Then the base bet is cancelled
and the price of the final bet adjusted. The
lower the base price, the more chances that
your bet will be rejected by BetFair if it is
too small in size. The higher the base price,
the more chances that your base bet will be
matched instead of your intended small bet.
MF Pro holds a history of your winnings and losses, as well as of the bets that were placed and
settled in your account. You can access this history through the trigger variables listed below.
Please keep in mind that this history's depth is defined by the Account Statement settings.
Therefore, if you always retrieve today's statement, and have not placed any bets yet today, these
variables will return zero.
hist_{number}_backa floating point The sum of the amounts of all back bets placed in
the settled market indexed by {number}.
Settled markets are sorted by the date of their
settlement and are assigned numbers. Number 1
refers to the latest settled event, number 2 - to the
event that was settled before the latest one and so
on.
So, if you want to get the amount of all the back
bets in the latest settled market, write
hist_1_backa. If you want to get it for the event that
was settled before the last one, write hist_2_backa
and so forth.
In order to refer to the earliest settled market write
hist_hist_count_backa.
Example:
There are 5 markets settled within the given period of
time (specified in the "Account Statement" settings).
Market 1, settled at 12:30, 3 back bets sized 5
EUR, 12 EUR and 3 EUR
Market 2, settled at 13:15, no back bets
Market 3, settled at 13:30, 1 back bet, 14 EUR
Market 4, settled at 13:45, no back bets
Market 5, settled at 15:05, 2 back bets, each 4
EUR.
As Market 5 is assigned index 1, and Market 1 -
index 5 (according to their settlement time), the
variable hist_1_backa would return 8, hist_5_backa
= 20, hist_2_backa = 0 and so on.
hist_{number}_backp floating point The weighted average price of all back bets made in
hist_{number}_laya floating point The total amount of all lay bets made in the settled
market indexed by {number}.
hist_{number}_layp floating point The weighted average price of all lay bets made in
the settled market indexed by {number}.
hist_{number}_pl floating point The amount that you won/lost in the settled market
indexed by {number}.
hist_{number}_time date/time The date and time when the market indexed by
{number} was settled.
last_lost floating point The total amount that you lost since the last win. If
you did not lose in any market this will be equal to
0. If you won the first event and then lost the next
three events, then this value will be the sum of three
losses.
last_won floating point The total amount that you won since the last loss. If
you did not win in any market this will be equal to 0.
last_pl floating point The amount that you won or lost in the last settled
market. This amount is a cumulative profit/loss of all
bets placed in that market.
losses integer The number of your losses since the last win. If you
won 2 events, then lost 4 events in a row, this
variable will return 4. If you lost 3 events then won,
this variable will return 0.
wins integer The number of your wins since the last loss. If you
lost the first event and then won 5 times in a row this
variable will return 5. If you lost 2 times, then won 3
times, then lost again this variable will return zero.
total_won floating point Total Profit/Loss that you earned since the first
account statement record within the timeframe
specified by the Account Statement settings. If you
lost money, this value will be negative.
last_deposited floating point The last amount deposited into your account.
last_withdrawn floating point The last amount withdrawn from your account.
You can customize the above variables by adding special prefixes in front of the variable. These
prefixes refer to specific types of markets:
nr_ Non-race markets (those that are neither horse nor Greyhound races)
If you trade on various types of markets during the day, you can use these prefixes to separate
settled bets from different markets. For example:
gh_hist_count - the number of settled greyhound races
hr_hist_1_backp - the average price of back bets placed in the last settled market of a horse race
fn_hist_1_pl - the profit/loss of the last settled market in a financial market
hr_hist_hr_hist_count_pl - the profit/loss of the first settled market of a horse race (the variable
hr_hist_count is parsed first, so it will replace it with the number of settled races and then parse
the rest of the variable)
hr_last_won - the total amount that you won in horse racing markets since the last loss in horse
racing
nr_losses - the number of losses (since the last win) in non-race markets.
You can access the information about the selections (horses, teams, players) that won in the last
market that was settled earlier than the market you're currently in.
Use prefix pw_[number of winner]_ for that purpose.
For example, to know the name of the horse that took first place in the previous settled horse race,
write pw_1_sel_name. If no markets have been settled yet, or these markets are not present in "My
Markets" list, this will return 0, otherwise it'll return the name of the winning selection.
If there was more than one winner in the event (such as in place markets), you case use a different
index to get the parameters of the second, third place etc.
pw_2_last_traded - this will get you the last traded price of the horse that took the second place.
Please note that this information can only be available in Settled markets.
Market variables return various market parameters. They are always bound to a market and don't
make sense otherwise.
Below is the full list of market variables with description.
b_book floating Book percentage formed by the back prices of all selections in the
point market, for example 89.5, 112.34.
l_book floating Book percentage formed by the lay prices of all selections in the
point market, for example 89.5, 112.34.
places integer The number of winning places in the market. Win markets will
always have 1 place, whereas place markets can have different
number of places.
event_finished date/ The date and time at which the market has finished. It is the point in
time time when BetFair declared it closed. However, it does not
event_finished_ string necessarily coincide with the time at which the market was settled
datestr (i.e. its bets settled and added to the account).
string
The event_finished_datestr and event_finished_timestr variables
event_finished_ return strings with the corresponding date formatted as dd/mm/yyyy
timestr and time formatted as hh:nn:ss respectively.
event_off date/ The date and time at which the market has actually started (turned
time in-play). If the market eventually was suspended and turned in-play
event_off_dates string several times, only the time of the first turning in-play is fixed. If you
tr added the market after it has already started the variable will return
string the date and time of your adding it to "My Markets". If you added the
market after it was suspended and never turned in-play this variable
event_off_times will return zero.
tr
The event_off_datestr and event_off_timestr variables return
strings with the corresponding date formatted as dd/mm/yyyy and
time formatted as hh:nn:ss respectively.
event_start date/ The scheduled date and time of the market's start. In most cases it
time does not coincide with the time of the actual start.
event_start_dat string The event_start_datestr and event_start_timestr variables return
estr strings with the corresponding date formatted as dd/mm/yyyy and
string
time formatted as hh:nn:ss respectively.
event_start_tim
estr
refresh_start date/ The date and time at which you last started monitoring (refreshing)
time the event. Each time you stop a market this time is reset to zero
refresh_start_d and is then updated when you start the market.
string
atestr The refresh_start_datestr and refresh_start_timestr variables
string
return strings with the corresponding date formatted as dd/mm/yyyy
refresh_start_ti and time formatted as hh:nn:ss respectively.
mestr
last_suspend date/ The date and time at which the market was suspended last time. If
time the market was never suspended this variable will return zero. If it
last_suspend_d was suspended and resumed several time, the variable will return
string
atestr the date and time of the latest suspension.
string
The last_suspend_datestr and last_suspend_timestr variables
last_suspend_ti return strings with the corresponding date formatted as dd/mm/yyyy
mestr and time formatted as hh:nn:ss respectively.
last_inplay date/ The date and time at which the market turned "in-play" last time.
time This variable differs from event_off, because event_off is only set
last_inplay_dat once: when the event starts. Whereas last_inplay is set each time
string
estr a market's status is switched to "in-play". For example, if a football
string match is turned in-play after a goal was scored (and the market was
suspended for several sec.).
last_inplay_tim
estr The last_inplay_datestr and last_inplay_timestr variables return
strings with the corresponding date formatted as dd/mm/yyyy and
time formatted as hh:nn:ss respectively.
last_goal_time date/ The date and time at which the latest goal (e.g. in Football) or point
time (e.g. in Tennis) were scored in the market. If no goals have been
last_goal_time_ string scored so far or if you turned off downloading scores, this variable
datestr will be equal to 0.
string
The last_goal_time_datestr and last_goal_time_timestr variables
last_goal_time_ return strings with the corresponding date formatted as dd/mm/yyyy
timestr and time formatted as hh:nn:ss respectively.
1/0 Returns 1 if the market will be turned In-Play as the event starts, or
market_turn_in 0 otherwise.
play
market_sp integer Returns 1 if the market supports SP bets and bet persistence, or 0
otherwise.
sport_id integer The unique identifier of the sport (e.g. Tennis, Horse Racing or
Greyhound Racing) in BetFair database.
event_id integer The unique identifier of the sports event, e.g. a football meeting, a
horse race, a tennis match, a basketball game etc. One event may
incorporate several markets. This identifier is generated by the
program and can be used for your convenience (e.g. when naming
variables).
market_parent string The name of the parent category to which the market belongs. For
example, for horse races which you added from today's card this
variable will always return "Horse Racing - Todays Card". Several
markets of the same football match (like "Match Odds" and "Total
Goals") will share the same market_parent, for instance
"Portsmouth v Sunderland".
You can tell what this variable will return from the full name of the
market in the header of the market screen:
It's the text that comes just before the actual name of the market,
between the forward slashes.
integer The unique identifier of the parent category to which the market
market_parent_ belongs. This is a number which corresponds with the name of the
id parent category on BetFair.
market_name string The full name of the market, including its category and additional
information, such as mileage in horse races.
market_venue string Only for races: the name of the venue (race course) where the race
takes place.
market_volume floating Total matched amount in the market given in your currency.
point
market_length floating The distance in meters of the race that the market belongs to.
point Applicable to horse racing and Greyhound markets only, and to
those of them that have an indicator of the distance in their name,
e.g. "5f Hcap".
floating The estimated average duration of the race that the market belongs
market_duratio point to, in seconds, from the moment the market turns In-Play to the
n moment it gets suspended at the end of the race. This figure is
based on the historical market data we possess under the BetFair
Historical Data Licence and is by no means precise. We will not
accept any claims as to this figure being inaccurate, so please use
it at your own risk.
mber
winner_name string The name of the selection that was chosen the winner of the race.
wp_id integer The unique identifier of the corresponding Win or Place market in
BetFair database. If the market for which this variable is checked is
a Win market, then the ID of the corresponding Place market will be
returned, and vice versa. If such market is not found in "My Markets"
the variable returns 0.
ew_id integer The unique identifier of the corresponding Win or Each Way market
in BetFair database. If the market for which this variable is checked
is a Win market, then the ID of the corresponding Each Way market
will be returned, and vice versa. If such market is not found in "My
Markets" the variable returns 0.
market_index integer Market's index in the list of markets sorted by their start date. See
the paragraph Accessing Markets By Index below.
reduction floating The overall reduction factor of all non-runners in the market. This is
point the sum of all withdrawn selections' reduction factors.
commission floating The commission that BetFair will charge for bets in this market.
point Returns the percentage divided by 100, for example "0.05" for 5%
commission, "0.1" for 10% commission and so on.
idle_rate floating The value of the frequency rate (in seconds) at which the market is
point refreshed before it turns In-Play.
inplay_rate floating The value of the frequency rate (in seconds) at which the market is
point refreshed after it turns In-Play.
market_mbnum integer The total number of all matched back bets placed on all selections
in the market
market_mlnum integer The total number of all matched lay bets placed on all selections in
the market
market_ubnum integer The total number of all unmatched back bets placed on all
selections in the market
market_ulnum integer The total number of all unmatched lay bets placed on all selections
in the market
market_min_pl floating Returns the minimum profit that any combination of winning
point selections can generate in the market. It can produce a negative
number if the minimum P/L is in fact a loss.
market_max_pl floating Returns the maximum profit that any combination of winning
point selections can generate in the market. It can produce a negative
number if all P/Ls are negative.
floating The amount of money you have won or lost in this market after it has
market_settled point been settled. It is always equal to 0 in non-settled markets.
_pl
floating The amount you will win or lose in this market if you close all open
market_tradeo point back and lay bets (do a trade-out) on all selections right now.
ut
floating The minimum amount you will win or lose in this market if you close
market_tradeo point all open back and lay bets (do a trade-out) with the specified P/L
ut_{ratio} Ratio % on all selections right now.
market_code integer A number that corresponds to the market's betting code. The
following values are assigned to market codes:
ew_divisor integer The number by which selections' odds are divided in an Each Way
hose racing market.
race_status integer The number that corresponds to the race status of this market if it
belongs to a horse race or a Greyhound race, and if "Download race
status" is turned on. This variable can return one of the following
values:
0 - Dormant;
1 - Delayed;
2 - Parading;
3 - Going Down;
4 - At The Post;
5 - Going Behind;
6 - Under Orders;
7 - Off;
8 - Finished;
9 - False Start;
10 - Photograph;
11 - Result;
12 - Weighed In;
13 - Race Void;
14 - Abandoned;
15 - Approaching;
16 - Going in Traps;
17 - Hare Running;
18 - Final Result;
19 - No Race;
20 - Meeting Abandoned;
21 - Rerun.
market_score1 integer The first value of the current score in a match (soccer, tennis,
basketball etc.), if the score is available for this market. That is, if
the score is 2:1, then market_score1 will return 2.
If this value is -1, it means that the score for this market is not
available at the moment. In order for this variable to be supported,
don't forget to turn on the download of match score.
market_score2 integer The second value of the current score in a match (soccer, tennis,
basketball etc.), if the score is available for this market. If this value
is -1, it means that the score for this market is not available at the
moment. In order for this variable to be supported, don't forget to turn
on the download of match score.
integer The first value of the previous score in a match, if it is available. This
market_pscore is the score that was immediately before the latest goal has been
1 scored. For example, after the first goal, market_pscore1 will return
0, because the previous score was 0:0. If the score was 1:2 and
then the second team scored to 2:2, then market_pscore1 will return
1, whereas market_score1 will return 2. If this value is -1, it means
that the score for this market is not available at the moment. In order
for this variable to be supported, don't forget to turn on the download
of match score.
integer The second value of the previous match score. If this value is -1, it
market_pscore means that the score for this market is not available at the moment.
2 In order for this variable to be supported, don't forget to turn on the
download of match score.
score_exists 0/1 Returns 1 if score is available for this market, and 0 otherwise. In
order for this variable to be supported, don't forget to turn on the
download of match score.
match_minute floating The number of minutes left till the end of the current quarter. This is
point a very approximate value, we cannot guarantee that it is either
precise or updated in time. In order for this variable to be supported,
don't forget to turn on the download of match score.
market_score1 integer The first value of the current score in a match (soccer, tennis,
basketball etc.), if the score is available for this market. That is, if
the score is 2:1, then market_score1 will return 2.
If this value is -1, it means that the score for this market is not
available at the moment. In order for this variable to be supported,
don't forget to turn on the download of match score.
market_score2 integer The second value of the current score in a match (soccer, tennis,
basketball etc.), if the score is available for this market. If this value
is -1, it means that the score for this market is not available at the
moment. In order for this variable to be supported, don't forget to turn
on the download of match score.
integer The first value of the previous score in a match, if it is available. This
market_pscore is the score that was immediately before the latest goal has been
1 scored. For example, after the first goal, market_pscore1 will return
0, because the previous score was 0:0. If the score was 1:2 and
then the second team scored to 2:2, then market_pscore1 will return
1, whereas market_score1 will return 2. If this value is -1, it means
that the score for this market is not available at the moment. In order
for this variable to be supported, don't forget to turn on the download
of match score.
integer The second value of the previous match score. If this value is -1, it
market_pscore means that the score for this market is not available at the moment.
2 In order for this variable to be supported, don't forget to turn on the
download of match score.
score_exists 0/1 Returns 1 if score is available for this market, and 0 otherwise. In
order for this variable to be supported, don't forget to turn on the
download of match score.
match_minute floating The value of the match minute in Football markets, if such
point information is available on BetFair. Before the start of the match this
variable is equal to zero. In Time Machine mode it is calculated
approximately, based on the scheduled start of the match. In order
for this variable to be supported, don't forget to turn on the download
of match score.
integer Returns the number of extra minutes at the end of the half.
match_extra_ti
me
integer Returns the number of goals the home team scored in the first half,
match_ht_score if now is already the second half.
1
integer Returns the number of goals the away team scored in the first half, if
match_ht_score now is already the second half.
2
match_ycards1 integer Returns the number of yellow cards received by the home team.
match_ycards2 integer Returns the number of yellow cards received by the away team.
match_rcards1 integer Returns the number of red cards received by the home team.
match_rcards2 integer Returns the number of red cards received by the away team.
tennis_player integer Returns the number of points that the player with the given {number}
{number} has won in the current game of the current set. The {number} can be
_points_won either 1 (for the top selection in the list of players) or 2 (for the
bottom selection). If a match is a doubles, then the "player" refers to
a couple of players competing against the other couple.
If one of the players is having an Advantage, this variable will return
50 as the number of points.
tennis_player integer Returns the number of games that the player with the given {number}
{number} has won in the current set.
_games_won
tennis_player integer Returns the number of sets that the player with the given {number}
{number} has won in the current match.
_sets_won
tennis_player -1/0/1 Returns 1 if the player with the given {number} has won the game
{number}_set with the specified {game_number} in the specified {set_number}, or 0
{set_number} otherwise. If there is no data or the game has not finished yet,
_game returns -1.
{game_number
}
tennis_player integer Returns the score of the {set_number}'s set for the player with the
{number}_setsc given {number}. Example: if the scores are 6-5-1 for the first player
{set_number} and 2-2-0 for the second player, then tennis_player1_setsc2 will be
equal to 5, and tennis_player2_setsc3 will be equal to 0.
If a set with {set_number} has not started yet, this variable will return
0.
integer Returns the previous number of points that the player with the given
tennis_p_playe {number} had won just before the points score has changed. For
r{number} example, if at first the score is 0-15, and then the first player scores
_points_won 15 points, the score becomes 15-15. In this case
tennis_p_player1_points_won = 0, tennis_p_player2_points_won =
15, tennis_player1_points_won = 15, tennis_player2_points_won =
15. This variable can help find out who actually scored last.
integer Returns the previous number of games that the player with the given
tennis_p_playe {number} had won just before the games score has changed.
r{number}
_games_won
integer Returns the previous number of sets that the player with the given
tennis_p_playe {number} had won just before the set score has changed.
r{number}
_sets_won
integer Returns the index of the player (1 or 2) who gets to serve first.
tennis_first_to_
serve
integer Returns the index of the player (1 or 2) who won the coin toss.
tennis_toss_win
ner
integer Returns the index of the player (1 or 2) who currently serves (at the
tennis_current_ start of the point).
server
integer Returns the index corresponding to the type of the latest stroke.
tennis_stroke_t Can take one of the following values:
ype
-1 - not available;
0 - point start;
1 - point;
2 - fault.
tennis_player integer Returns the number of service breaks that the player with the given
{number} {number} has had since the start of the match.
_service_break
s
Each trigger expression containing a market variable is calculated separately for each market. For
example, if your trigger is set up to work in "Win Markets", then each variable will be calculated
individually for each market in "My Markets" list.
You can access the variables of a particular market through addressing this market by its index.
This index indicates the place of the market in the list of markets sorted by their start time. For
example, if you have three markets in your list, a race starting at 14:05, a tennis match starting at
20:00 and a football match starting at 18:30, then the race will be number 1, football match number 2
and tennis match - number 3.
To access a market by its index add the prefix mr_{number}_ in front of any of the variables listed
above. For example, to get the name of the first market in the list query mr_1_market_name. To
get the number of selections in the second market try mr_2_runner_number and so on.
Match Score
MF Pro allows you to see and operate the scores of certain matches, such as soccer, tennis,
basketball, baseball, ice hockey etc. The score is refreshed every 15 seconds. You can see it in the
top of the market's window, in all the markets that belong to a particular match. You can access the
values of the current and previous score through market variables market_score1, market_score2,
market_pscore1 and market_pscore2. Therefore, you can also use these values in your triggers.
Please be aware: in no way we guarantee the correctness and reliability of the score data.
We do not accept responsibility in case the score is not available or not updated in time.
You should use it "as is", always keeping in mind that we can stop providing this service.
To turn the score on, activate the option Download match score in the Monitoring Options.
There is a simple and efficient way to connect different markets of the same event in a trigger
condition. This is mostly needed in strategies where you make a decision whether to bet in one
market based on some data of the other market belonging to the same event. Among typical
examples are:
Betting in Win market of a horse race or Greyhound event based on the circumstances of the
Place market
Betting in an Over/Under market in Football based on the team's or the draw's price in the Match
Odds market
Sometimes you may be looking to implement an arbitrage, whereby you bet in multiple markets
expecting a total P/L to be positive no matter of the outcome of a particular market.
Normally you can check any market's property or piece of data with a market variable. If you need to
check the parameters of a different market within the same event, you can use the corresponding
prefix.
winplace_
This prefix refers to the Win market if you are using it in the context of a Place market, and vice
versa.
Let's look at an example. I'm refreshing a Win a Place market of 17:05 Fakenham.
It literally means: the back price of the favourite in the opposite market is less than 3.0.
If I check this selection in the Win market, the condition will be true, because in the Place market
the price (in red square) is indeed less than 3.0. But if I check the same condition in the Place
market, it will return false, as the price in the opposite, Win market, is higher than 3.0.
Please note: if you use the winplace_ prefix from inside an Each Way market, it will point to the
Place market.
eachway_
It works exactly in the same way as winplace_. E.g. to get the back price of the favourite in the Each
Way market, call eachway_r_1_back_price. If you are comparing a selection’s price to the price of
that same selection in the Each Way market, use:
If you are using it inside an Each Way market, then it will point to the Win market of the same race.
E.g. if you call eachway_b_book from inside the Each Way market, it will return the back book% of
the Win market that corresponds to this Each Way market.
Note: if you call a variable with this prefix from inside a Place market, it will point to the Each Way
market that belongs to the same horse race.
rcwin_
This is a prefix for Win markets in horse racing and Greyhound racing markets. By using this prefix
from any market of a particular racing event, you can access the parameters of the Win market and
its selections, provided that you have loaded it into the program. Unlike winplace_, this prefix
always points to the same market, regardless of where it is being called from.
rcplc_
This is a prefix for Place (To be Placed) markets in horse racing and Greyhound racing markets. By
using this prefix from any market of a particular racing event, you can access the parameters of the
Place market and its selections, provided that you have loaded it into the program. Unlike
winplace_, this prefix always points to the same market, regardless of where it is being called from.
hr2b_
This is a prefix for 2 TBP markets in horse racing. By using this prefix from any market of a particular
racing event, you can access the parameters of the 2 TBP market and its selections, provided that
you have loaded it into the program. If there is no 2 TBP market in the event due to the fact that the
Place market has exactly 2 winning places, then this prefix will address the Place market instead.
hr3b_
This is a prefix for 3 TBP markets in horse racing. By using this prefix from any market of a particular
racing event, you can access the parameters of the 3 TBP market and its selections, provided that
you have loaded it into the program. If there is no 3 TBP market in the event due to the fact that the
Place market has exactly 3 winning places, then this prefix will address the Place market instead.
hr4b_
This is a prefix for 4 TBP markets in horse racing. By using this prefix from any market of a particular
racing event, you can access the parameters of the 4 TBP market and its selections, provided that
you have loaded it into the program. If there is no 4 TBP market in the event due to the fact that the
Place market has exactly 4 winning places, then this prefix will address the Place market instead.
football1_
This prefix refers to a Match Odds market in a Football match, if checked within the other markets
of the same match. You can use it to get all the usual market data from the Match Odds, e.g. the
price of The Draw: football1_s_3_back_price.
football2_
This prefix refers to a Correct Score market in a Football match, if checked within the other markets
of the same match. Example: the profit/loss of the 0-0 selection: football2_s_1_profit_loss.
football3_
This prefix refers to a Total Goals market in a Football match, if checked within the other markets of
the same match.
football4_
This prefix refers to a Asian Handicap market in a Football match, if checked within the other
markets of the same match.
football5_
This prefix refers to a Half Time market in a Football match, if checked within the other markets of
the same match.
football6_
This prefix refers to an Over/Under 0.5 Goals market in a Football match, if checked within the
other markets of the same match.
football7_
This prefix refers to a Over/Under 1.5 Goals market in a Football match, if checked within the other
markets of the same match.
football8_
This prefix refers to a Over/Under 2.5 Goals market in a Football match, if checked within the other
markets of the same match.
football9_
This prefix refers to a Over/Under 3.5 Goals market in a Football match, if checked within the other
markets of the same match.
football10_
This prefix refers to a Over/Under 4.5 Goals market in a Football match, if checked within the other
markets of the same match.
football11_
This prefix refers to a Over/Under 5.5 Goals market in a Football match, if checked within the other
markets of the same match.
football12_
This prefix refers to a Over/Under 6.5 Goals market in a Football match, if checked within the other
markets of the same match.
football13_
This prefix refers to a Over/Under 7.5 Goals market in a Football match, if checked within the other
markets of the same match.
football14_
This prefix refers to a Over/Under 8.5 Goals market in a Football match, if checked within the other
markets of the same match.
football15_
This prefix refers to a First Half Goals 0.5 market in a Football match, if checked within the other
markets of the same match.
football16_
This prefix refers to a First Half Goals 1.5 market in a Football match, if checked within the other
markets of the same match.
football17_
This prefix refers to a First Half Goals 2.5 market in a Football match, if checked within the other
markets of the same match.
football18_
This prefix refers to a Half Time Score market in a Football match, if checked within the other
markets of the same match.
football19_
This prefix refers to a Half Time / Full Time market in a Football match, if checked within the other
markets of the same match.
football20_
This prefix refers to a Both Teams To Score market in a Football match, if checked within the other
markets of the same match.
football21_
This prefix refers to a Next Goal market in a Football match, if checked within the other markets of
the same match.
football22_
This prefix refers to a DRAW NO BET market in a Football match, if checked within the other
markets of the same match.
football23_
This prefix refers to a First Goal Odds market in a Football match, if checked within the other
markets of the same match.
football24_
This prefix refers to a Odd or Even market in a Football match, if checked within the other markets
of the same match.
football25_
This prefix refers to a Double Chance market in a Football match, if checked within the other
markets of the same match.
football26_
This prefix refers to a Goal Lines market in a Football match, if checked within the other markets of
the same match.
Here is an example of the implementation of the Football Cash Generator strategy - a popular
variation of football arbitrage.
You can google it and get a full description, but in a few words it has the following steps.
Thus if the match ends in 0-0, you will either end up with a zero P/L or make small profit if the green-
up trigger kicks in. If a goal is scored, the greening up will most probably fire and secure you profit in
spite of the losing back bet on 0-0. The worst case scenario is the equal score with no green-up - in
this case you will lose it all, but this should only happen if the chances for winning are very high for
the favourite, so the first underdog's goal does not improve The Draw's prices.
Conditions expanded:
The way to make sure the bet is placed on "0 - 0" in the Correct Score market is to find a selection
with index 1 (the first in list) in the market with Betting Code "Correct Score" (see Betting Code in
market-related parameters).
There is an additional condition to check the volume in the Match Odds market (using the constant
min_vlm and the prefix football1_ that relates to Match Odds markets).
Conditions expanded:
(football2_s_1_profit_loss)/(lay_price-1)
What does it mean? The prefix football2_ is, as we already know, for Correct Score markets. So the
expression football2_s_1_profit_loss reads "The profit/loss of the first selection in the Correct Score
market of this match". We expect it to be positive following a back bet. We then divide it by
(lay_price-1) to get the amount we need to lay on The Draw, so that the liability of this bet is fully
covered by the back bet's expected profit.
To make sure that the lay bet comes only after the back bet is matched, we add this condition to the
trigger:
which in effect means "The sum of your matched back bets on the first selection of the Correct
Score market must be greater than 0".
It must kick in the Match Odds market - for that reason I added the first condition, that the laying
trigger must have been applied to the qualifying selection in this market (remember that it will have
laid on The Draw, and not anywhere else). Also, it must not bet until the price is right - otherwise the
P/L from the green-up will not cover our liabilities. For this purpose I added the second condition:
Here football2_s_1_bm_backa is the amount of the back bet on the 0 - 0 selection in the Correct
Score market, lay_payout is equal to the price of the lay bet (on The Draw) multiplied by its size,
and bm_laya is the size of that lay bet. The formula is working on the premise that the difference
between the lay bet and back bet after the green up must be at least the size of the back bet placed
on 0 - 0. This way they will cancel each other out, leaving us with zero profit or liability. Ideally, we're
looking for a higher price. We then divide the bet's amount by (1-commission) to account for the
market commission that will be deducted from the profit.
You can try these triggers yourself by downloading the trigger file from this link.
tennis1_
This prefix refers to a Match Odds market in a Tennis match, if checked within the other markets of
the same match.
tennis21_
This prefix refers to a Set 1 Winner market in a Tennis match, if checked within the other markets
of the same match.
tennis22_
This prefix refers to a Set 2 Winner market in a Tennis match, if checked within the other markets
of the same match.
tennis3_
This prefix refers to a Set Correct Score market in a Tennis match, if checked within the other
markets of the same match.
tennis4_
This prefix refers to a Set Betting market in a Tennis match, if checked within the other markets of
the same match.
Selection variables return various selection parameters. They are always bound to a selection and
don't make sense otherwise.
Below is the full list of selection variables with description.
Note: you must enclose string variables in double quotes if they contain spaces inside them, and
you don't want these spaces to be wiped out. For example:
Trigger Expression FIND("The Draw", "sel_name") is greater than 0
sel_index integer The index under which the selection is displayed on BetFair. For
example, if there are 5 selections in the market:
1. Fitzroy Crossing
2. Monsieur Reynard
3. Reel Man
4. Cracking Nick
5. Title Role
"Fitzroy Crossing"'s index will be 1, "Monsieur Reynard"'s index will be 2
and so on.
Please note! Index is not the same as the selection's place in the list of
selections sorted by their price. Therefore, the favourite's index will not
necessarily be 1.
sel_trap integer The selection's Trap number (for Greyhound races only). The number is
displayed in front of the dog's name. You can use trap numbers instead
of names for importing selections for auto-trading from a text file.
sel_order integer The place of the selection in the list of selections sorted by their price.
The favourite will have sel_order = 1, second favourite - sel_order = 2
and finally the probable loser will have the highest sel_order which will
be equal to runner_number.
sel_place integer The place a selection took after the event was settled. Can return a
number from 0 to the number of places assigned to that event.
If a selection is a winner, it'll be assigned sel_place = 1, the second
winner - sel_place = 2 and so on. Selections with undefined places will
have sel_place = 0
traded_minp floating The minimum price at which at least one bet has been matched on this
point selection.
traded_mina floating The amount matched on this selection at the minimum traded price.
point
traded_maxp floating The maximum price at which at least one bet has been matched on this
point selection.
traded_maxa floating The amount matched on this selection at the maximum traded price.
point
traded_minp_ floating The minimum price at which at least {minvlm} has been matched on this
{minvlm} point selection.
traded_mina_ floating The amount matched on this selection at the minimum traded price with
{minvlm} point at least {minvlm} matched.
traded_maxp_ floating The maximum price at which at least {minvlm} has been matched on this
{minvlm} point selection.
traded_maxa_ floating The amount matched on this selection at the maximum traded price with
{minvlm} point the matched amount of {minvlm} or higher.
traded_{price} floating The amount of money matched in the market on this selection at the
point price specified by {price}. For example, traded_4.5 will return the amount
of money traded at the price of 4.5. This variable will only work if you
activated "Load traded volume for all prices" in General Options.
tradedh_{price} floating The amount of money matched in the market on this selection at the
point price specified by {price} or higher. For example, tradedh_4.5 will return
the cumulative amount of money traded at the prices of 4.5, 4.6, 4.7 and
so on up to 1000. This variable will only work if you activated "Load
traded volume for all prices" in General Options.
tradedl_{price} floating The amount of money matched in the market on this selection at the
point price specified by {price} or lower. For example, tradedl_4.5 will return
the cumulative amount of money traded at the prices of 4.5, 4.4, 4.3 and
so on down to 1.01. This variable will only work if you activated "Load
traded volume for all prices" in General Options.
traded_last floating The amount of money matched in the market on this selection at the last
point traded price. This variable will only work if you activated "Load traded
volume for all prices" in General Options.
b_offered_{price} floating The amount of unmatched money offered for this selection on the back
point side (i.e. under back prices) at a particular {price}. This variable will only
work if you activated "Retrieve all price offers" in General Options.
l_offered_{price} floating The amount of unmatched money offered for this selection on the lay
point side (i.e. under lay prices) at a particular {price}. This variable will only
work if you activated "Retrieve all price offers" in General Options.
most_traded_price floating The price at which the maximum volume has been matched. This
point variable will only work if you activated "Load traded volume for all prices"
in General Options.
floating The maximum volume that has been matched at one price. This variable
most_traded_volum point will only work if you activated "Load traded volume for all prices" in
e General Options.
traded_avg_price floating The average weighted price at which the selection has been traded up to
point the moment. This is an indicator of the selection's value in the eyes of
bettors who placed matched bets on it. It is calculated as:
Where P1, P2, ..., Pn are the prices at which at least 0.1p has been
traded, and A1, A2, ..., An are their respective traded amounts.
lt_ma floating The moving average of the last traded price: the average of all non-zero
point values of the last traded price recorded over the period defined by the
market's history depth.
near_sp floating What the starting price would be if the market was reconciled now taking
point into account the SP bets as well as unmatched exchange bets on the
same selection in the exchange.
far_sp floating What the starting price would be if the market was reconciled now taking
point into account only the currently place SP bets. The Far Price is not as
complicated but not as accurate and only accounts for money on the
exchange at SP.
actual_sp floating The actual starting price of the selection (is zero, until the market turns
point in-play)
back_sptotal floating The total amount of SP back bets placed on the selection. This is the
point sum of all bets' liabilities.
lay_sptotal floating The total amount of SP lay bets placed on the selection. This is the sum
point of all bets' liabilities.
back_payout floating The sum of all your matched back bets' amounts multiplied by their
point prices.
lay_payout floating The sum of all your matched lay bets' amounts multiplied by their prices.
point
back_volume floating The sum of the three amounts offered at the best back prices. If you turn
point the option Retrieve all price offers on, then this variable will return the
sum of all the amounts that are offered for the selection on the back
side.
lay_volume floating The sum of the three amounts offered at the best lay prices. If you turn
point the option Retrieve all price offers on, then this variable will return the
sum of all the amounts that are offered for the selection on the lay side.
volume floating Selection's volume percentage as compared to the total matched amount
point in the market. For instance, if 100 EUR out of 1000 EUR in the market
were matched on this selection, its volume percentage will be 10%.
profit_loss floating Selection's P/L. In place markets you can also use profit_loss2.
point
profit_loss2 floating The second P/L figure in place markets. For example, if P/L is displayed
point as 25.2 -14, then profit_loss will be 25.2 and profit_loss2 will be -14.
profit_loss3 floating The middle P/L for Asian Handicap and Each Way markets.
point
tradeout_pl floating The P/L this selection will have if you trade it out right now (apply either
point green-up or loss distribution). Note that a selection's P/L in a win market
will be affected by bets placed on other selections.
tradeout_pl_{ratio} floating The P/L this selection will have if you trade it out right now (apply either
point green-up or loss distribution) with the specified P/L ratio %. For
example, tradeout_pl_80 will show the selection's P/L in case you close
its bets with 80% of profit or loss on that selection and 20% -- on the
rest of selections in the market. Note that a selection's P/L in a win
market will be affected by bets placed on other selections.
tradeout_net floating The net amount you will win or lose on this selection if you trade it out
point right now (apply either green-up or loss distribution). This variable is
different from the previous one: its value is not affected by the bets
placed on all other selections.
tradeout_net_{ratio} floating The net amount you will win or lose on this selection if you trade it out
point right now (apply either green-up or loss distribution) with the specified P/
L ratio %. This variable is different from the previous one: its value is not
affected by the bets placed on all other selections. For example,
tradeout_net_80 will show the selection's net P/L in case you close its
bets with 80% of profit or loss on that selection and 20% -- on the rest of
selections in the market.
b_leap floating Back price leap (the number of ticks the back price grew by over the last
point refresh).
l_leap floating Lay price leap (the number of ticks the lay price grew by over the last
point refresh).
b_growth floating The change of the back price of the selection within one refresh. This
point variable has the same meaning as b_leap, except that b_leap returns it
in ticks, and b_growth returns a value. For example, b_growth for the
price change from 4.0 to 4.2 is 0.2. If the price changed from 4.2 to 4.0,
then it's -0.2.
l_growth floating The change of the lay price of the selection within one refresh.
point
b_tick floating Price tick (increment) calculated for the current price range of the
point selection's back price. For example, if the price is 2.0 then b_tick will be
0.02, if 10.5, then it'll be 0.5 etc. You can know more about available
price ticks from BetFair online help. Tip: if you need to calculate a price
that is several ticks higher or lower than the specified value, use function
r_ticks instead.
l_tick floating Price tick calculated for the current price range of the selection's lay
point price. Tip: if you need to calculate a price that is several ticks higher or
lower than the specified value, use function r_ticks instead.
bsp_backp floating The price limit (if exists) of the last SP back bet that you placed on the
point selection.
bsp_backl floating The amount / liability of the last SP back bet that you placed on the
point selection.
bsp_layp floating The price limit (if exists) of the last SP lay bet that you placed on the
point selection.
bsp_layl floating The maximum liability of the last SP lay bet that you placed on the
point selection.
bsp_backid floating The ID of the last SP back bet that you placed on the selection.
point
bsp_layid floating The ID of the last SP lay bet that you placed on the selection.
point
bsp_type floating The type of the last SP that you bet placed on the selection. The variable
point will return the index that corresponds with the type of the bet. Thus, 1
stands for a lay bet, and 2 stands for a back bet. If no SP bets found,
this will return 0.
bsp_number floating The number of all SP bets that you placed on the selection
point
bsp_backnum floating The number of all SP back bets that you placed on the selection
point
bsp_laynum floating The number of all SP lay bets placed on the selection
point
bu_backp floating The price of the last non-SP unmatched back bet placed on the
point selection.
bu_backa floating The amount of the last non-SP unmatched back bet that you placed on
point the selection.
bu_layp floating The price of the last non-SP unmatched lay bet that you placed on the
point selection.
bu_laya floating The amount of the last non-SP unmatched lay bet that you placed on the
point selection.
bu_bpricedat_ floating The total amount of all your back unmatched bets (non-SP) placed at the
{price} point specified price.
bu_lpricedat_{price} floating The total amount of all your lay unmatched bets (non-SP) placed at the
point specified price. The {price} can be either a number or a user variable.
bu_backprs floating The persistence code of the last non-SP unmatched back bet that you
point placed on the selection. Returns 0, if the bet will be cancelled, 1 - if it will
be kept, and 2 - if it'll be matched at SP, when the market turns In-Play
bu_layprs floating The persistence code of the last non-SP unmatched lay bet that you
point placed on the selection. Returns 0, if the bet will be cancelled, 1 - if it will
be kept, and 2 - if it'll be matched at SP, when the market turns In-Play
bm_backp floating The price of the last non-SP matched back bet that you placed on the
point selection.
bm_backa floating The amount of the last non-SP matched back bet that you placed on the
point selection.
bm_layp floating The price of the last non-SP matched lay bet that you placed on the
point selection.
bm_laya floating The amount of the last non-SP matched lay bet that you placed on the
point selection.
bm_bpricedat_ floating The total amount of all your back matched bets placed at the specified
{price} point price. The {price} can be either a number or a user variable.
bm_lpricedat_ floating The total amount of all your lay matched bets placed at the specified
{price} point price. The {price} can be either a number or a user variable.
bm_backid long The ID of the last non-SP matched back bet that you placed on the
integer selection
bm_layid long The ID of the last non-SP matched lay bet that you placed on the
integer selection
bm_type integer The type of the last non-SP matched bet placed on the selection. The
variable will return the index that corresponds with the type of the bet.
Thus, 1 stands for a lay bet, and 2 stands for a back bet. If no matched
bets found, this will return 0.
bm_number integer The number of all non-SP matched bets that you placed on the selection
bm_backnum integer The number of all non-SP back matched bets that you placed on the
selection
bm_backtime date/ The date and time when the last non-SP back matched bet was placed.
time
bm_backmtime date/ The date and time when the last back matched bet was actually
time matched.
bm_laynum integer The number of all non-SP lay matched bets that you placed on the
selection
bm_laytime date/ The date and time when the last non-SP lay matched bet was placed.
time
bm_laymtime date/ The date and time when the last lay matched bet was actually matched.
time
bm_backavp floating The average price of all non-SP back matched bets that you placed on
point the selection.
bm_layavp floating The average price of all non-SP lay matched bets that you placed on the
point selection.
bu_backid long The ID of the last non-SP unmatched back bet that you placed on the
integer selection
bu_layid long The ID of the last non-SP unmatched lay bet that you placed on the
integer selection
bu_type integer The type of the last non-SP unmatched bet placed on the selection. The
variable will return the index that corresponds with the type of the bet.
Thus, 1 stands for a lay bet, and 2 stands for a back bet. If no
unmatched bets found, this will return 0.
bu_number integer The number of all non-SP unmatched bets placed on the selection
bu_backnum integer The number of all non-SP back unmatched bets placed on the selection
bu_backtime date/ The date and time when the last non-SP back unmatched bet was
time placed.
bu_laynum integer The number of all non-SP lay unmatched bets placed on the selection
bu_laytime date/ The date and time when the last non-SP lay unmatched bet was placed.
time
bu_backavp floating The average price of all non-SP back unmatched bets placed on the
point selection.
bu_layavp floating The average price of all non-SP lay unmatched bets placed on the
point selection.
voldif_{minutes} floating The amount by which the traded volume (in currency units) of this
point selection has grown over the time specified by {minutes}. For example,
if the starting traded volume is £1,000 and in 3 minutes it has become
£1,500, then voldif_3 will return 500. Obviously, this variable will always
have a positive value or zero, unless BetFair voids some of the matched
bets placed on the selection.
pdif_{minutes} floating The absolute back price difference over the time specified by {minutes}.
point For example, pdif_5 will return the value that back price changed by
within the last 5 minutes. This number can be negative or positive,
depending on the direction the price changed in. For example, if the price
changed from 4.0 to 3.8, the difference will be -0.2.
lpdif_{minutes} floating The absolute lay price difference over the time specified by {minutes}.
point For example, lpdif_2.5 will return the value that lay price changed by
within the last 2.5 minutes. This number can be negative or positive,
depending on the direction the price changed in.
tdif_{minutes} integer The change of the back price over the time specified, in price ticks. For
example, if the price has changed from 3.0 to 3.65 within 4 minutes,
then tdif_4 will return 13.
ltdif_{minutes} integer The change of the lay price over the time specified, in price ticks. For
example, if the price has changed from 6.0 to 5.1 within 11.5 minutes,
then tdif_11.5 will return -9.
minbp_{minutes}, floating The minimum value of the back or lay price within the latest time
point specified by {minutes}. The variable minbp_{minutes} returns back
minlp_{minutes}
price and minlp_{minutes} - lay price. If it's been less than {minutes}
since you started refreshing the market, these figures will show the
maximum or minimum value since the beginning of the refresh. The time
should not exceed the market's history depth.
maxbp_{minutes}, floating The maximum value of the back or lay price within the latest time
point specified by {minutes}. The variable maxbp_{minutes} returns back
maxlp_{minutes}
price and maxlp_{minutes} - lay price. For more details see the
previous option.
minlt_{minutes} floating The minimum value of the last traded price the selection has had over the
point last {minutes}.
maxlt_{minutes} floating The maximum value of the last traded price the selection has had over
point the last {minutes}.
last_backp floating The last back price that was recorded for the selection before the event
point has started.
last_layp floating The last lay price that was recorded for the selection before the event
point has started.
last_order integer The order of the selection before the off. 1 stands for the favourite, 2 - for
the second favourite and so on.
last_last_traded floating The last traded price that was recorded for the selection right before the
point off.
handicap floating The digital value of the selection's handicap in "Asian Handicap" and
point "Total Goals" markets.
Silks Variables. Only valid in horse races where Silks are available.
silk_form_[index] string A particular character from the form identifier, counting from right to left.
I.e., if the form is 28322P, then silk_form_1 is "P", silk_form_2 is "2",
silk_form_3 is "2" and so on. If the index is greater than the length of
the form, the variable will return empty string.
silk_numeric_form string A string containing the horse's form identifier excluding any non-numeric
characters, such as P, F, R, B, U, -, / or x. E.g. if the form is 283-22P,
then silk_numeric_form will return 28322.
silk_numeric_form_ string A particular character from the form identifier, counting from right to left,
[index] excluding any non-numeric characters. E.g. if the form is 283-22P, then
silk_numeric_form_1 will return 2 and not P as in the case with
silk_form_1.
integer The number of characters in the horse's form excluding any non-numeric
silk_numeric_form_l characters.
ength
silk_sex string The sex of the horse ("f" for filly, "g" for gelding and "c" for colt).
silk_damsire_year integer The year the horse's grandfather on the mother's side was born.
integer Returns the number of points that the player that corresponds to the
tennis_player_points current selection has won in the current game of the current set. Make
_won sure you only address this variable in the context of a selection that
represents a player. I.e. it's OK to check this variable for selections in
"Match Odds" or "Set Winner", but not OK for "Set Betting", as none of
the four selections in that market represent a player.
integer Returns the number of games that the player represented by the current
tennis_player_game selection has won in the current set.
s_won
tennis_player integer Returns the number of sets that the player represented by the current
{number}_sets_won selection has won in the current match.
tennis_player_set -1/0/1 Returns 1 if the player represented by the current selection has won the
{set_number}_game game with the specified {game_number} in the specified {set_number}, or
{game_number} 0 otherwise. If there is no data or the game has not finished yet, returns -
1.
tennis_player_setsc integer Returns the score of the {set_number}'s set for the player represented by
{set_number} the current selection. Example: if the scores are 6-5-1 for the player,
then tennis_player_setsc2 will be equal to 5.
If a set with {set_number} has not started yet, this variable will return 0.
integer Returns the previous number of points that the current player had won
tennis_p_player_poi just before the points score has changed. For example, if at first the
nts_won score is 0-15, and then the first player scores 15 points, the score
becomes 15-15. In this case tennis_p_player_points_won = 0,
tennis_player_points_won = 15. This variable can help find out who
actually scored last.
integer Returns the previous number of games that the current player had won
tennis_p_player_ga just before the games score has changed.
mes_won
integer Returns the previous number of sets that the current player had won just
tennis_p_player_sets before the set score has changed.
_won
integer Returns the player’s number of service breaks since the start of the
tennis_player_servic match (for the player that corresponds with the selection)
e_breaks
If you have more than one matched or unmatched bet of any type, you can address these bets by
index. By inserting this index inside the variable you can access the list of all bets that you placed
on a selection.
The syntax is the following:
For matched bets:
bm_{number}_backa, bm_{number}_backp, bm_{number}_backid, bm_{number}_backtime
For SP bets:
bsp_{number}_backl, bsp_{number}_backp, bsp_{number}_backid, bsp_{number}_backtime
Instead of the {number} you should insert the index of the bet. Index 1 corresponds with the last bet
that was placed on the selection. Index 2 - with the bet that was placed before the last one and so
on. For example, you have six unmatched bets which are listed in the following way:
Variable Value
bu_1_backp 11.5
bu_1_backa 8
bu_2_backp 10.5
bu_2_backa 5
bu_3_backp 11.0
bu_3_backa 4.5
bu_1_layp 7.0
bu_1_laya 7.7
bu_2_layp 7.5
bu_2_laya 4.2
bu_3_layp 8.5
bu_3_laya 6.5
You can refer to a selection by its index assigned to it by BetFair. Add a prefix s_{number}_ to any
selection variable. For example, s_1_back_price will return the price of the first selection (which is
not necessarily the favourite!).
You can use the same selection variables for getting the parameters of selections sorted by their
price, such as favourite, second favourite etc. This can be done by adding a prefix r_{number}_ in
front of the variable. The {number} stands for the place of the selection in the list of selections
sorted by price, starting from the lowest price.
Thus, r_1_ is a prefix for the favourite, r_2_ - for the second favourite and so on.
To address the probable loser (the selection with the highest price) write either r_0_ or
r_runner_number_. In the latter case the market variable runner_number will be parsed first and
will return the number of selections in the market.
Examples:
r_1_back_price - the favourite's back price
r_2_bm_laya - the amount of the last matched lay bet placed on the second favourite
r_0_profit_loss - probable loser's P/L
r_3_back_unmatched - the total back unmatched amount of the third favourite.
You can combine selections and sorted selections in trigger expressions. While selection variables
always concern the selection they are checked for, sorted selection variables are calculated
independently.
Examples:
b_leap > r_1_b_leap - checks if the back price leap of the selection is greater than that of the
favourite
100/back_price + 100/r_1_back_price + 100/r_2_back_price
Whenever using the Any Other Selection's or All Other Selections' as the Body of a condition, don't
forget to insert other_ in front of any selection variables you will use in this condition.
Read more on the specifics of All Other Selections' and Any Other Selection's here.
To know how to create the same variables, but for place markets please read this topic.
A trigger with the action "remember" creates a list of selections which you can access by adding a
special prefix.
Then to get the value of a variable belonging to one of the selections in the remembered list, you use
the following syntax:
{name}_{index}_{variable}
Where {name} is the name under which the selections were remembered by the trigger, {index} is
the index of the remembered selection and {variable} is the selection variable you want to evaluate.
Example:
Let's say there were four qualifying selections whose last traded price was in the range 1.01 to 10.0.
The trigger remembered them under the name of "top". To get the last traded price of the second
selection you would write:
top_2_last_traded
To get the third selection's back price at that moment, you would write:
top_3_back_price
And so forth.
{name}_number
In a trigger condition you can address the variables of the remembered selection that the condition
relates to. To get the variables of the same selection remembered by a trigger, you would use this
syntax:
{name}_{variable}
You don't specify the index, instead the program tries to find the remembered selection that is the
same as the one that you are checking in the condition.
Example. Suppose you remembered selections a minute ago and now want to compare how their
volume percentages have changed with time.
Tip! If you want the remembered selections to be unique for each market where you remember
them, add market_id to the end of the Name:
These variables apply and can be evaluated for selections meeting the conditions of the trigger. That
is they make sense only in the context of a trigger for which they qualify.
match_b_book floating The book percentage formed of the matching selections' chances of
point winning based on back prices. For example, if there are three
matching selections with back prices 2.0, 6.4 and 10, the variable
will return 75.63 (100/2.0 + 100/6.4 + 100/10).
match_l_book floating The book percentage formed of the matching selections' chances of
point winning based on lay prices.
integer The number of selections that have matched all conditions at to the
matching_num moment of checking the variable.
ber
match_index integer The index of the selection in the list of matching selections. If more
than one selection met the conditions, this variable returns the
position of the selection in the list of qualifying selections.
match_{index} prefix You can use this prefix to address all matching selections by their
_ index. Example:
In horse racing, the form of a horse is a record of significant events including its performance in
previous races. The form may identify the horse's sire, dam and wider pedigree. It is used by tipsters
and punters as an aid in the prediction of its performance in future races.
When you add a condition that has "Form" as its parameter, you can analyse its contents and find
specific sequences (patterns) using the following syntaxes.
Each syntax corresponds with one character in a sequence.
[XYZ] - any character from the group inside the brackets. In this example it is X, Y or Z.
[?XYZ] - any character from the group inside the brackets, but it can be missing in the form. This is
needed when you are not sure whether a particular character is in the sequence, and want to just
ignore it in case it's there. For instance, if you want to search for [12][12][12] (when a horse takes
either the first or second place three times in a row), but don't care about possible breaks in its
career, you can check for this sequence:
[12][?/-][12][?/-][12]
The expression [?/-] stands for a possible "/" or "-", but it does not necessarily have to be there. So,
this sequence will be found in the following forms:
1-2-1
2/12
1/1/1
2-22
and so on.
[^XYZ] - any character except the ones listed in the brackets, after the ^ character. In this example
it can be anything except X, Y and Z.
The last two symbols do not stand for any actual character in the form, but they denominate a
special circumstance for other character(s) in the sequence.
For example, you might want to search for the sequence 123, but with a condition that this pattern is
at the start of the form's string. I.e. 123P801, 123-246U etc., but NOT 451230 or 72B9123. In that
case you would need to look for this sequence:
@123
Alternatively, to look for a specific pattern in the end of the string, you will need to write:
123$
Apart from these syntaxes you can also put the actual character you are looking for.
Examples.
[123]%[1234] Finds a form that contains three characters: the first one should be 1 to 3, the
second one can be anything at all, and the third one must be a number from 1 to 4. For example, 2-
3, 1/4, 3P3, 201.
[^FU][1234567]%[^P] Finds a pattern of four characters: one should be anything but "F" or "U",
the second - a number from 1 to 7, the third one can be any character, and the fourth one should be
any character except "P". For instance, R4U0, 11-B, 06/R.
[^/-]1%[^0F] Finds a pattern of four characters: the first one can be anything except "/" or "-",
the second one must be 1, the third one can be any character, and the last one should not be "0" or
"F". For example, 21F8, U1-P, 0114.
If you want to find a specific sequence of characters, you can just put it in the value field. For
example:
Will find any horse that at any time in its life won in two races and then came second.
Will find any horse that has ever fell, then had years off track, then took a place outside the top 9.
If you have imported selections from a text file, along with some numeric or text values, you can
access those values with this variable:
imported_{index}
Where index is the index of the value (starting from 1) in the list separated by "Tab" characters (as in
the original file). So if you have a line in that text file:
Then here is how the values will be assigned to the corresponding variables:
You can then easily use these variables in your triggers. Example:
If you specify an index that is greater than the number of values you imported for the given selection,
the variable will return empty string. You therefore can check if it is not empty using this condition:
integ The number of markets where selections or their values were imported.
imported_m er
kt_num
integ The number of selections affected by the import file, i.e. the ones that were
imported_se er activated or for which at least one value was imported.
ls_num
Syntax
cell_[sheet_name]_[cell_address]
The [sheet_name] and [cell_address] are the address of the cell a value is stored in. The sheet must
exist in the Excel file MF Pro is connected to, and the cell's address must comply with Excel
notation. For example:
cell_sheet1_B3
cell_mysheet_A4
But that's not all the things you can do. Suppose you want to connect to a market sheet, but don't
want to type in the name of the sheet each time you add a new market. Since MF Pro always
names market sheets as "query" plus the ID of the market, you can compose the address of trigger
variables:
cell_querymarket_id_K4
Let's go further and find out how you can for example address a cell where the current back price of
a selection is stored. You already know how to address a market sheet. Having read section "Excel
Interface / Overview" you will also learn that back prices are displayed in cells D4, D7, D10 etc. Now,
the index of each selection can be obtained from the sel_index variable. The array 4, 7, 10 etc. can
be represented as sel_index*3+1. Therefore the final address can be formulated as:
cell_querymarket_id_D(sel_index*3+1)
If you have a custom cell that you want to use in the trigger expression here are some tips.
If your custom cell is meant to be inserted in any market sheet, then use the same formula as
above:
cell_querymarket_id_[cell_address]
If your custom cell's address is parsed for each selection, for example S14:3, then you need to
convert the number of the column into its name. Column 14 is N. Then, convert the row number
according to this scheme:
Row Notation
1 sel_index*3+1
2 sel_index*3+2
3 sel_index*3+3
cell_querymarket_id_N(sel_index*3+1)
There is a predefined order in which user and trigger variables are parsed inside a trigger expression.
The order determines which variable is replaced with an actual value before the other. This gives you
an opportunity to include variables in the names of certain other variables.
1. User variables and Constants. For this reason you cannot include any other variable in the name
of a user defined variable when executing a trigger with the "set user variable" action.
4. General Variables.
Operators
Here is the full list of signs you can use inside your trigger expressions:
+ addition
- subtraction
* multiplication
^ raising to power
/ division
% modulus or remainder. For example, 5 % 4 = 1, 36 % 6=0, 23 % 7 = 2
= equal to
<> not equal to
> greater than
>= equal or greater than
< less than
<= equal or less than
( ) brackets
You can combine these operators with numbers and trigger variables. For example:
Functions
1. r_ticks(original_price, ticks)
Returns a price that is ticks higher or lower than original_price. If ticks is positive the returned
price will be higher, and if it is negative the price will be lower.
For example: r_ticks(6, 4) will return 6.8, and r_ticks(4.1, -5) will return 3.8.
Note that for Asian Handicap markets a tick is equal to 0.01 regardless of the price range.
The expression r_ticks(original_price, 0) will return original_price adjusted for the correct value
based on its price range. E.g. if you write r_ticks(10.17, 0), it will return 10.0, if you write r_ticks
(2.57, 0), it will return 2.58 and so on.
2. g_ticks(price1, price2)
Returns the difference between price1 and price2 in ticks. If price1 is less than price2, the result
will be positive, otherwise - negative. Examples:
g_ticks(2, 3) = 50
g_ticks(4, 3.5) = -10
g_ticks(6, 6) = 0
Another examples:
fibonacci(2, 5, 0) = 10
fibonacci(4, -2, 20) = 8
6. INTEGER(expression)
Returns the integer number made of expression by discarding its fractional part. I.e. INTEGER
(2.7) or INTEGER(2.123) would return 2. The expression can be a negative number, thus
INTEGER(-23.454) will return -23.
7. RANDOM(expression)
Returns a random number between 0 and (expression-1). The expression must evaluate to an
integer number. If the expression is negative, the returned number will be in the range between -
(expression-1) and 0.
Examples: RANDOM(-10) returns anything between -9 and 0. RANDOM(15) returns anything
between 0 and 14.
RANDOM(runner_number) + 1 returns a random runner index from 1 to the number of selections in
the market.
MF Pro utilizes several simple Excel functions. They are listed below:
4. FIND(pattern, string)
Returns the position of the first occurrence of pattern in string. If pattern is not found it returns 0. If
string starts with pattern, then the function will return 1 and so on. Example: FIND("Horse", "Horse
Racing - Todays Card") will return 1, because the pattern "Horse" stands in the beginning of the
string. The pattern "orse" will be found on the second place and so on.
5. ABS(expression)
Returns the absolute value of a number, a number without its sign.
ABS(-9) = 9
These functions have the same syntax as in Excel. However there are several restrictions that you
must know about:
all function names must be written in English. No other languages are supported
all numbers must have dot as a decimal separator. For example, numbers like 5,2 must be
entered as 5.2. If the expression that contains these numbers will be later output to an Excel
spreadsheet, it will be automatically formatted according to your system's decimal separator.
You can combine different functions in one expression. Here are a couple examples:
PLEASE NOTE
If you are working with an Excel spreadsheet you are not limited with functions that you can use in
your spreadsheet calculations. All aforesaid refers to expressions that you may enter into the
application's fields.
The integral part of this value is the number of days that have passed since 12/30/1899. The
fractional part of this value is the time of day.
Following are some examples of TDateTime values and their corresponding dates and times:
0 12/30/1899 12:00 am
This format is also supported and used by Excel and VBA (and by many programming languages).
To find the fractional number of days between two dates, subtract the two values. To increment a
date and time value by a certain fractional number of days, add the fractional number to the date and
time value.
Below is a list of the most frequent date and time patterns converted into the date/time format
supported by MF Pro:
1 second 0.00001157
1 minute 0.000694
10 minutes 0.00694
1 hour 0.04164
12 hours 0.49968
1 day 1.0
So, in order to convert the time given in this format into - say - minutes, divide this number by
0.000694. For example:
(now_time - event_off)/0.000694
This will give you the time in minutes that has passed since the actual start of an event.
For easier access to the current date and time use the "Current Time" trigger condition.
They are conveniently organised as web pages which you can view with your browser software.
Program Logs
Trigger Logs
Statement
To view the program logs, simply click on this link in the Main Menu:
The information on the bets you placed either manually or through various auto-trading functions of
the program
The score and list of winners in a settled market
Deposits and withdrawals of funds in Test Mode
Error messages, such as "Insufficient funds" or "Can't place bets below the minimum"
It is very important to keep track of all these messages as they will help you control the actions of
the program and give confidence to your trading.
Each log is named after the name of the trigger it follows, and that in its turn can be broken up in
markets if there is more than one market a trigger can operate in.
The text of the log is made up of clusters recorded each time a market is refreshed. A cluster starts
with a line "Checking market "[market name]". Then it lists all trigger's conditions indicating whether
they are satisfied or not, sometimes backing it up with additional information. This way you can
easily see what condition it was that the trigger "stumbled upon".
Once all conditions of a trigger have been satisfied (if there were any), a log record will appear saying
"Going to ..." and the action that the trigger is supposed to perform along with all the details related
to this type of action.
Then most likely the log will keep saying that the trigger has already been executed in this market (if
it must be executed "once per market") or it will start a new cluster with the report on the trigger's
conditions if the trigger can be repeated.
Develop a habit of constantly checking trigger logs. This will save you efforts and time as developing
and testing triggers is often a matter of trial and error, and you want to be fully aware of how a trigger
is performing before you switch to the real money mode.
10.3 Statement
Your statement, like the one at BetFair's web site, lists all your transactions sorted by date and
time.
MarketFeeder Pro generates both a real money statement and a test mode statement. These
statements are not correlated, and so there is a chance you might have only a test statement if you
were betting in test mode only. You can switch between them using the menu on the statement
page.
11 Getting Started
Before you start working with MarketFeeder Pro, you need to register an account with BetFair and
deposit funds at least once. You will need your username to enter the program.
Then it is highly recommended to make yourself acquainted with the basics of trading at an online
exchange.
When making your first steps in mastering MarketFeeder Pro, do have the Test Mode turned on at
all times.
It is strongly recommended that you read the other chapters of the manual before changing the
settings, so that you are fully aware of the consequences.
Settings Profile
When you first log in to MF Pro, it offers you a default settings profile - some predefined configuration
that we carefully chose for a new user. We believe it perfectly serves the needs of someone who
hasn't explored the full potential of the program yet. If you need to experiment with the program's
settings, click on this link in the Main Menu:
Test Mode
It is recommended that you start your experience with MarketFeeder Pro in Test Mode. It is safe yet
allows you to try all trading functions. Upon installation of the program you are given 100 test
currency units (e.g. £100) for your first bets. Should you need more test funds, click on the "Transfer
Test Funds" link. When you are absolutely (I stress the word "absolutely") confident that you are
ready to start betting with real money, you can press the link "Test Mode is ON" to switch it off.
Confirmation Messages
By default the program will ask your permission for every operation that is considered critical, such
as deleting something or, above all, placing a bet. This, of course, is a measure of precaution and
should be used until you get acquainted with the way various buttons and functions work in
MarketFeeder Pro. But if you get annoyed by these message boxes, you can turn them off via
Settings -> General Options.
One-Click Betting
By default all square areas in market views with prices on them are betting buttons. This means that
once you press that button, a bet is immediately placed. If you are not comfortable with this, for
example, if you don't want to make an unwanted bet accidentally, you can turn this option off in
Settings -> Betting Options.
Adding markets you want to trade in is quite simple and can be done in three ways:
1. Manually, through the Event Tree. You simply navigate to the market you want to add and click on
its name, one at a time.
2. Manually, through the Market Locator. You search for markets that satisfy your criteria and add
as many as the program will find in one go.
3. Automatically, through the Scheduled Market Search. Markets will be search and added by the
program, according to the search template that you'll specify in the settings.
If you are not happy with the default colour scheme for betting buttons (back and lay), you can
change them in Settings -> Look & Feel.
2. Click on the race's name and wait till the market loads into the program.
3. Switch to the "My Markets" tab and check that the market's name is there.
4. Check your Test Funds. The first you will place will be a test bet to avoid any risks. You are given
100 test currency units at the beginning. You can deposit or withdraw test funds if needed.
5. Start refreshing the market. As prices keep changing on the screen, choose the selection you
want to bet on. Note its current back and lay prices. Check the Default Back and Default Lay
amounts in this market.
6. Click directly on the blue betting button. The program will try to place a back bet with a size equal
to the Default Back amount and the price displayed on the betting button.
7. To safeguard you from possible errors while you are doing your first steps, it will ask for your
permission:
You will be able to turn these confirmation windows off when you feel confident. For now just press
"Yes".
8. You can see your first bet to the right of the market window. Congratulations! You are now ready
to go to One-Click Betting.
All triggers must exist inside a block, even if there is only one trigger in the block. So press Add
Block. Click on the block's name and type in something more meaningful there.
In majority of cases the block must be set to be repeated "just once". This option will be offered by
default.
Now press Add Trigger and rename the trigger that will appear on the screen to "laying on the
second favourite".
As you can see, the program adds the first action to the trigger automatically. Its default action is
lay, just what we need!
But we will work with the other fields of the trigger. We will set the Price to lay_price - this variable
holds the value of the current lay price of a selection. The Amount is already filled with default_laya -
that's a variable holding the default lay amount in a market. We'll leave it like that.
Fill all other fields as shown in the picture using drop-down lists.
Lay the default lay amount at the current lay price on the second favourite, in all types of
markets, in Idle state (before In-Play), one time in each market.
Now don't forget to save the trigger file. Press Save As and type the name for the file, for example
"my_triggers.mft".
Let's check our trigger now. Load it into the program by pressing Open Triggers and choosing
"my_triggers.mft" from the list.
Add some market and turn the triggers ON. It is also HIGHLY RECOMMENDED to always test new
triggers, in Test Mode. So make sure it is turned ON.
Watch the trigger place a lay bet in the market. It will go flashing green once it is executed.
So we'll lay on the favourite in every race and double our bet size after each loss. Once a bet has
won, we will return to the initial stake size.
If you haven't tried creating triggers before, read this manual first.
To start with, create a new triggers file and save it under the name of "martingale_lay.mft".
Then add two constants by pressing Add Constant and name them in the following way.
Then add a trigger block to put triggers in. Name it "Martingale Lay".
Our first trigger will place a lay bet on the favourite. We'll call it simply "laying".
Pay attention to the value we placed in the Amount field. It should be current_bet, as this variable
holds the value of the current bet size.
The second trigger will double the size of the bet after a loss. As the value of the bet size is stored in
the variable current_bet, we need to set this variable to a new value.
Note that the trigger should be set to act in Settled markets. Also its condition stipulates that the
market's Settled P/L is less than 0. Together with the Market Status parameter it means that the
trigger will be executed in markets that have been settled with loss.
The third trigger will reset the size of the bet to the initial value after profit.
It also should be applied only to settled markets, and only when their Settled P/L is greater than 0,
that is if they were settled with profit.
In effect our staking plan is ready to go. However, there is an important nuance to it. Usually you
would want to bet in a sequence, that is betting in the next market only if the bets in the previous
market have been settled. We will need to make the program wait till the previous market where a
bet was triggered is settled. To do that, we'll add these conditions to the laying trigger.
They mean:
Either this trigger has never been executed yet
or
The market where it was executed before is now settled.
Without these conditions the trigger will lay in any market that is being refreshed. So if two or more
markets are refreshed simultaneously, nothing would prevent it from laying in all of them.
Let's save the triggers we've made and load them into MarketFeeder Pro. It is HIGHLY
RECOMMENDED to always test new triggers, especially staking plans, in Test Mode. So we make
sure it is turned ON. We will also turn off deleting settled markets as the conditions of one of our
triggers queries the state of the previous markets, so we need them to stay in the program's
memory.
You can add several markets now and set them to start being monitored at around 1 min before the
off.
[HORSE RACING] UK and Irish win not in-play yet for all today's UK & Irish win markets
[HORSE RACING] UK and Irish win and place for all today's UK & Irish win & place markets
[HORSE RACING] UK and Irish win Handicap for all today's UK & Irish handicap win markets
[HORSE RACING] UK and Irish win non-handicap for all today's UK & Irish non-handicap win
markets
[HORSE RACING] UK and Irish win where Favourite less than 2 for all today's UK & Irish win
markets where the favourite's price is less than 2.0
[HORSE RACING] Australian and New Zealand win for all today's (coming in the next 24
hours) Australian and New Zealand win markets
Recommended Settings
Although technically you will be able to monitor all those markets at once, we don't recommend
refreshing more than 10 of them at the same time. Firstly, you will be limited by the BetFair's
request limit. Read more in Connection Monitor. Secondly, it may eat up too much of your
computer's memory and slow down the performance of the program.
Thus we recommend setting your Monitoring Options to "Start monitoring events at 10 mins before
the beginning".
To arrange the silks data on the screen in the order most suitable for you, play with the "Horse
Racing Silks" table using drag-n-drop.
We have developed a special market mode for races, Race Mode. So it is a good idea to configure
your Settings to "Show markets in Race Mode" by default. You will have all essential information on
screen, including the silks, plus the multi-coloured bars will let you know instantly which runner is
ahead of the others and which one is limping behind.
The optimal refresh rate for races is 2 to 4 sec before the off and 0.3 to 1 sec at In-Play.
To get the list of withdrawn runners, press the Market Info button.
11.5.2 Football
We have prepared several Market Locator templates for you to search for today's Football matches.
They are:
[SOCCER] Correct score Match Odds Total goals Going in-play Volume 1000 Starting in 24
hours
[SOCCER] Current in-play match odds
[SOCCER] Italian in-play match odds and correct score
[SOCCER] Match odds and Correct score starting in 10 minutes
[SOCCER] Over-Under will turn in-play Favourite less 1.3 Volume greater 2000
[SOCCER] UK match odds going in-play and high volume
If you will be trading in Asian Handicap markets, you may want to turn the Full Mode on, to see all
three P/Ls for each selection.
Monitoring Options
The recommendations for Greyhound Racing are pretty much the same as for Horse Racing, except
that BetFair currently does not provide silks for this sport. Therefore, as an alternative for Race
Mode, you could also use Brief Mode or Engineer Mode, depending on your needs.
Just open any market and press one of the betting buttons next to a preferred selection. When you
click on it with a left button of your mouse, a bet is placed immediately, with the price displayed on
that button and the default back or lay amount appointed for this market.
You can back at the current lay price and lay at the current back price by pressing Shift + left
button of your mouse.
To place a bet at the best available price (at 1.01 for back bets and at the maximum possible price
for lay bets, according to the maximum best lay price setting), press Ctrl + left button of your
mouse on the corresponding back or lay bet button.
If you are in the Engineer Mode, you can also place a back bet with a predefined payout or a lay bet
with a predefined liability by pressing Alt + left mouse button.
If you want to turn one-click betting off for safety reasons, do it in the "Betting Options" tab of the
Settings.
Auto-Greenup
1. Add a market where you want to trade, preferrably one with high volume of matched bets. Switch
it to Brief Mode.
6. Notice the green price label telling you the minimum back price for a greenup.
7. Watch MarketFeeder Pro complete the trade when the price is right.
8. Open Auto-Greenup settings and play with them to achieve different results. Try Stop-Loss as well
as the "Always attempt to green up" option.
Manual Greenup
4. Look at the trade-out button. The upper figure shows you what P/L the selection will have if you
trade out now. The lower P/L shows you how much money you will win or lose on that selection.
5. When the lower value becomes positive, press the trade-out button to green up.
6. Alternatively you can right-click on any betting button of this selection and press "Green Up".
3. Click on the last traded price to scroll down to the currently traded prices.
Using One-Click Betting or the Betting Interface, place a bet at the current best back price.
Wait till the red line drops below the pink rectangle. When the right moment comes, press the Green
Up button to complete the trade. The bet will be calculated and placed automatically.
Click on another selection's name to open a new tab in the Ladder. Place a lay bet by clicking inside
the cell right above the red line.
Wait till the blue line gets above the light-blue rectangle. Guided by the "What if" P/L, press Green
Up again to complete another trade.
You can repeat these steps as many times as you want, enjoying regular profits.
3. Turn Auto-Dutching on. Watch MarketFeeder Pro place bets to complete the Dutching.
4. Experiment with Auto-Dutching settings yourself (don't forget to have Test Mode on!) till you get
best results.
The main part of any staking plan is correcting the size of a bet according to the previous bet's
results. This should normally be done as soon as that bet (or several bets in one market) is settled.
Virtually all known staking plans can be realised in MarketFeeder Pro through triggers.
The simplest plan that recoups previous losses by increasing the size of the next bet by the amount
of the loss can be found in your library of triggers, under the names of simple_staking_plan_back.mft
and simple_staking_plan_lay.mft. Just open one of those files and give it a try (in Test Mode
preferrably).
If you want anything more elaborate than those, experiment with other staking plan triggers in your
library. You are encouraged to edit the values of the constants in the header of each trigger file. This
way you can change the length of a staking plan cycle, the initial bet size, the extent to which bets
are modified etc.
Eventually you will be able to design and implement your own staking plan. The main steps you
would need to follow are:
1. Determine what type of bet you will be placing (back or lay) and on what conditions. Make a
trigger that places this bet and put it in the very bottom of your trigger block.
2. Formulate on which conditions the size of the stake is modified, e.g. if the previous result is a
loss, if there have been three losses in a row, if the size of the loss is greater than a certain value
etc. Make a trigger with those conditions and set its "Market Status" property to "Settled". It will
then be executed each time a market is settled (with or without bets).
3. Define when the size of the bet should get back to its normal (usually when all the losses are
recouped or when a bet has reached a certain maximum value). Put this trigger before number 2 and
1.
4. Add all other triggers that you may need for the staking plan to work properly. It could be triggers
modifying some variables, or those acting as a stop-loss.
Our support team is always ready to give you a hand in making your triggers.
12 Excel Interface
12.1 Overview
MF Pro allows you to interact with Excel spreadsheets in both directions. MF Pro passes market
and account data to Excel documents and can accept some commands back from Excel. It also
can process values taken from specific Excel cells and react to them through triggers.
If any of "My Markets" is being monitored, the list of selections and their data will be displayed and
updated in the market sheet. Below is the example of a selection row in a sheet, with an explanation
of each cell:
Address Description
in the
exampl
e sheet
A4 Selection's name
I4 Back price leap (the number of ticks back price has changed by)
A5 Volume percentage of the selection as compared to the total amount matched in the
market
B5:D5 Three amounts offered for the three best back prices
E5 Profit/Loss figure
F5:H5 Three amounts offered for the three best lay prices
I5 Lay price leap (the number of ticks lay price has changed by)
D6 Back volume of the selection. If you don't enable the option "Retrieve all price offers",
back volume will be the sum of the three amounts offered for the three best back prices.
Otherwise it'll be the sum of all the amounts offered for this selection at different back
prices.
E6 Pressure of Money which in this context is back volume divided by lay volume of the
selection (D6/F6).
L6 The actual SP price of the selection. It is calculated by BetFair, only after the market
turns In-Play.
MF Pro will work with any instance of Excel that is opened at the moment. If no spreadsheets are
opened it will create a new workbook automatically and will use it for exchanging data with the
application during the whole session. This means you can connect to MF Pro from your own
spreadsheets without the need to utilize a special Excel file.
Once a connection between MF Pro and Excel is established the "Launch Excel" button becomes
disabled. If there are any markets in "My Markets" list MF Pro will add a separate sheet for each of
them. It will load the essential market data into each sheet: name, number of places, scheduled time
of start etc. Please remember than market sheets are not deleted together with markets.
Each market sheet will have a special name. It has the following format: "query[market ID]", for
example "query124524". Read how to refer to such sheets from inside the triggers in section "Excel-
Bound Variables".
This is possible through a table of custom cells and formulae available in "Excel Options".
Each row in the table represents a cell or a group of cells of the same kind.
The left column defines the address of the cell and the right column defines its formula.
Cell Address
[sheet_name]![cell_address]
This is a generic representation of a cells address in Excel. Use it if you want your formula to be
inserted in a specific cell in your spreadsheet. In the picture above you can see an example of such
address: sheet!A1. With each refresh of each market MF Pro will output the total won amount into
the cell addressed sheet1!A1.
Certainly, you need to have a sheet named sheet1 in your spreadsheet in order to create a custom
Excel functions and arithmetic calculations are allowed though. If a formula contains an Excel
function you must put an equation sign in front of the expression. So, you might have written "=MAX
(total_won, last_won)" or "=SUM(A1:A10)" or whatever you like.
Please keep in mind that non-Roman characters (for example Cyrillic) are not allowed for cell
addresses.
However you can feel free to use them in the cell formula, especially if you have a non-English Excel.
Also please use the punctuation and syntax that is required by your local Excel copy.
[cell_address]
If you provide only a cell address, this will let MF Pro know that you want to calculate and display the same
formula in this cell, for each market that you are monitoring. In the picture above there are two such examples:
N3 and N4. This means these formulas will be displayed in every market sheet, in cells N3 and N4
respectively. Therefore you can use market variables here, as well as variables starting with r_[number]_ and
s_[number]_.
All Excel functions and arithmetic operations are acceptable as well.
S[column]:[row]
Such syntax commands MF Pro to display the same formula in a specific place for each selection in
each market monitored. The [column] is an integer number identifying the number of the column
where a formula will be displayed. Columns are numerated from 1 to 256 and correspond with the
Excel column names from "A" to "IV".
The [row] is the number of the row where the formula must be put. It can be an integer number from 1
to 3, since each selection occupies three rows in a market sheet.
Cell Value/Formula
Insert an expression or an Excel formula into this field. As you can see from the examples,
expressions can contain arithmetic operations, functions and trigger variables. If you have one or
more Excel functions inside the expression add an equation sign in front of it.
Excel functions must be entered in the language of your MS Office installation. For example, if you
have an Italian copy of Excel enter commands in Italian language.
If you need to import custom cells that you can express through the existing market data, please
read section "Importing Selection Data From a Sheet"
Please note: custom cells are updated in a spreadsheet only if one or more markets are being
monitored.
With the "Import Selection Cells" function you can match specific selections against the numbers or
strings that you prepared by yourself. For example, you are subscribed to a tipster service and
receive lists of expected prices every night. You want to compare tomorrow's races data to the
tipster's lists and lay if any selection's price is equal or greater than the expected odds.
With MF Pro it is easy to do this: you just need to insert all tipster's records in a separate
spreadsheet, with the names of selections being stored in the first column and their prices in the
next column. See below:
The picture shows a sheet named "my_sheet" with an example list of selections. You see the
names of the selections in column A and their respective numbers in column B. If you wish you may
shift these columns to the right, for example, place names in column C and the numbers - in column
D. The most important thing is that the selections' names must be stored in the leftmost column of
the cell range. Let's shift the cells down and right to demonstrate that it does not matter for MF Pro:
You can insert the selections from several markets, one under another, with no particular order. MF
Pro will match the names against the real selections that it will find among "My Markets".
Now let's import these values into MF Pro. I click "Import Selection Cells" and a new window opens:
It gives a short description of what this function does. You need to enter the name of the sheet where
your data are stored, the range address in Excel notation and the column in the market sheet that
you want to start outputting the data from.
The sheet name and range must be taken from the sheet where you have the list of selections with
your custom data. In our example it is "my_sheet" and "D5:E15". If you don't specify the range
correctly or don't include all the cells into it, MF Pro won't be able to recognize all the cells you are
trying to import.
The "Output starting column" can be anything you choose. We should give only one advice: start
from any column outside the table that MF Pro uses for displaying the default market data.
Otherwise your custom cells will be overwritten with those data. So choosing anything starting from
column L will be fine.
The box "Clear previously imported cells" will delete all cells that were previously imported into
MarketFeeder Pro (in all markets). If you untick this box all the cells that you are importing will be
added to already existing cells.
Now, let's press "Create Custom Cells". MF Pro will process the Excel sheet we've supplied and - if
everything is fine - will report how many selections it has processed:
Now if we refresh the market that we imported selection data for, we will see that MF Pro shows the
custom cells in the market sheet, in column L:
You now can create triggers comparing these numbers to the market data.
Let's finish out example and create a trigger that will compare these figures with the actual
selection's prices and lay if they are equal or greater than the custom odds we've imported.
After executing the trigger we've got 7 lay bets (if you want to avoid laying at the odds of 1000, add
another condition to the trigger that prevents doing so):
You can directly specify the markets that the selections will be searched in. If a selection has a
unique name which appears only in one market, then that's not necessary. However, if the same
selection's name can be found in more than one market (for example, "The Draw" or a horse's name
in win and place markets), you can make the program know which one you mean.
Enclose the name of the market in square brackets and put the selection's name next to it.
Examples:
You can input only a part of the market's name, it is not necessary to type in the whole name. Only
make sure that the pattern identifies the market completely.
There is a big difference between importing selection cells and creating one formula for each
selection. You should only import cells if you can't express the values of these cells through the
existing market data that MF Pro displays in the market sheet. For example, if you want to display
the average of the current back price and last traded price of a selection, you don't need to import
the cells, each showing this figure for a particular selection. Instead, you need to create a custom
cell with a formula (back_price + last_traded)/2. MF Pro will then automatically propagate this
formula among all selections existing in "My Markets". You will thus save your time and computer
resources, as maintaining imported cells is more resource-consuming than maintaining a custom
cell formula.
Use cells import if you have some unique information about selections, something that can't be
expressed through any market figures - predicted odds are an ideal example.
Always remember that you can import only the actual values of the cells, not their formulas. If you
are trying to import formulas, then this is an obvious evidence that you can create a custom cell
instead.
Examples of the information that can be imported and can't be expressed through custom cells:
predicted odds
predicted order of selections
staking plan according to a tipster's advice
predicted volume of selections
It is also possible (and in most cases easier) to import selection data from a text file.
At the end of this page you will see the examples of both betting and cancelling procedures. You
can apply these examples right away without knowing much about DDE technology. If you are
interested in details please read the following paragraph.
Here are some ready VBA procedures that you can insert in an Excel sheet's code before
connecting MF Pro to it. By calling these procedures you can manipulate bets directly from Excel.
Backing
Laying
Please pay attention that since version 6.0 handicap markets are supported, so you must specify
the handicap ID of the selection you want to bet on. This ID is zero in all markets except Asian
Handicap markets.
Note: if you wish to leave either price or amount the same, you can input zero (0) instead of any of
these parameters (but not both at the same time). For example:
Update 4038075284#, 0, 4
When you connect MF Pro to Excel a separate sheet for your current bets is created. It's called
"bets".
For the convenience of referring to each bet the list is organised in several columns. Each column
lists bets in the same order and with the same set of parameters.
Cell Title
B5 ID The unique ID (number) of the bet. If a bet is a real one (made with real
money), this ID will be assigned to it by BetFair. Otherwise the ID will be
generated by MF Pro.
You might need this ID for cancelling or updating the bet.
C5 Market ID The unique ID of the market where the bet was placed. This ID is
generated by BetFair.
D5 Selection ID The unique ID of the selection that the bet was placed on. This ID is
generated by BetFair.
E5 Handicap ID The Asian Handicap ID of the result you are betting on. This ID refers to
Asian Handicap markets only, and is needed together with the selection
ID in order to place, cancel or update a bet.
For all other markets this field will show zero.
F5 Price The price that the bet was offered or matched at. If it is a "limit on close"
SP bet, then this field will show the limit price.
G5 Amount The amount of the bet. If it is an SP bet, the field will show the liability.
H5 Test/Real If the bet is placed in test mode, this field will show 1, otherwise - 0.
Example:
You might need to scroll the page to the right to see all three columns (all bets, matched bets and
unmatched bets).
The purpose of this sheet is to give you direct access to the parameters of your current bets. If you
intend to bet manually or using triggers and other automated trading functions, you may ignore this
tool and turn it off in the settings. It is only needed if you want to place or cancel bets directly from
Excel, for example, if you work with MF Pro from a special pre-saved Excel spreadsheet.
13 Time Machine
Time Machine is a tool for MarketFeeder Pro that allows you to back test your betting strategies in
markets whose data are stored on your disk rather than downloaded from BetFair.
The full Time Machine manual can be opened with a link that is present in the installation folder of
MarketFeeder Pro. The file's name is manual_tm.chm.
Alternatively, you can call the help file from inside Time Machine, press the blue question button in
the bottom-left corner of the program's window.
back_amount2, Amount of the second best back bm_layavp, The average price of all non-SP lay
price offer. 204 matched bets 211
back_amount3, Amount of the third best back price bm_layid, The ID of the last non-SP matched lay bet
offer. 205 210
back_matched, Total back matched amount. 207 bm_laymtime, The date and time when the last
back_payout, Total back payout (bets' amounts non-SP lay matched bet was actually matched
multiplied by their prices). 207 211
back_price2, Second best back price offered. 205 bm_laynum, The number of all non-SP lay matched
back_price3, Third best back price offered. 205 bets 211
back_sptotal, The total amount of SP back bets bm_layp, The price of the last non-SP matched lay
placed on the selection. 207 bet 210
back_unmatched, Total back unmatched amount. bm_laytime, The date and time when the last
207 non-SP lay matched bet was placed 211
back_volume, The sum of the three amounts offered bm_lpricedat_{price}, Sum of all your lay matched
at the best back prices. 207 bets at {price} 210
balance, The amount of real funds in your account bm_number, The number of all non-SP matched bets
177 210
base_price, Base price for lay bets below the bm_type, The type of the last non-SP matched bet
minimum 178 210
basketball variables 189 bsp_backid, The ID of the last SP back bet that you
BetFair placed on the selection. 209
commission 79 bsp_backl, The amount / liability of the last SP back
bet that you placed on the selection. 209
connection timeout 87
bsp_backnum, The number of all SP back bets that
market_outcome 93
you placed on the selection 209
synchronize date and time 87
bsp_backp, The price limit (if exists) of the last SP
bets back bet that you placed on the selection. 209
betting interface 36
bsp_layid, The ID of the last SP lay bet that you
current bets 46 placed on the selection. 209
list of 43 bsp_layl, The maximum liability of the last SP lay
one-click betting 253 bet that you placed on the selection. 209
placing with a trigger 120 bsp_laynum, The number of all SP lay bets placed
settings 81 on the selection 209
settling 93 bsp_layp, The price limit (if exists) of the last SP lay
small bets 83 bet that you placed on the selection. 209
betting code 169 bsp_number, The number of all SP bets that you
bm_backa, The amount of the last non-SP matched placed on the selection 209
back bet 210 bsp_type, The type of the last SP that you bet
bm_backavp, The weighted average price of all placed on the selection. 209
non-SP back matched bets 211 bu_backa, The amount of the last non-SP
bm_backid, The ID of the last non-SP matched back unmatched back bet that you placed on the
bet 210 selection. 210
bm_backmtime, The date and time when the last bu_backavp, The average price of all non-SP back
non-SP back matched bet was actually matched unmatched bets 211
211 bu_backid, The ID of the last non-SP unmatched
bm_backnum, The number of all non-SP back back bet 211
matched bets 211 bu_backnum, The number of all non-SP back
bm_backp, The price of the last non-SP matched unmatched bets 211
back bet 210 bu_backp, The price of the last non-SP unmatched
bm_backtime, The date and time when the last back bet placed on the selection. 209
non-SP back matched bet was placed 211 bu_backprs, The persistence code of the last
bm_bpriceat_{price}, Sum of all your back matched non-SP unmatched back bet 210
bets at {price} 210 bu_backtime, The date and time when the last
bm_laya, The amount of the last non-SP matched non-SP back unmatched bet was placed 211
lay bet 210
-D- overview
variables
263
223
default_backa, Default (one-click) back amount
186
default_backsp, Default (one-click) back SP amount
-F-
/ liability 186 far_sp, What the starting price would be if the
default_laya, Default (one-click) lay amount 186 market was reconciled now 207
default_laysp, Default (one-click) lay SP amount / football variables 189
liability 186 formulae
discount_rate, Discount rate for your account 178 date and time 228
download race status 91 engineer mode 32
Dutching formula builder 47
automated 62 operators and functions 225
example 261 variables 176
with a trigger 131
-G-
green up
lay_payout, Total lay payout (bets' amounts market_min_pl, The minimum potential profit in the
multiplied by their prices). 207 market 187
lay_price, Best lay price offered. 205 market_mlnum, The number of all matched lay bets
lay_price2, Best lay price offered. 205 in the market. 186
lay_price3, Third best lay price offered. 205 market_name, The full name of the market, including
lay_sptotal, The total amount of SP lay bets placed its category and additional information 185
on the selection. 207 market_num, The number of markets in "My
lay_unmatched, Total lay unmatched amount. 207 Markets" list 177
lay_volume, The sum of the three amounts offered at market_parent, The name of the parent category to
the best lay prices. 207 which the market belongs 184
log files 229 market_parent_id, The unique identifier of the parent
log of a particular trigger 120 category to which the market belongs 185
program log (bets etc.) 230 market_pscore1, The first value of the previous
score. 189, 190
settings 106
market_pscore2, The second value of the previous
trigger logs 230
score. 189, 190
write to log file with a trigger 135
market_score1, The first value of the current score.
logging in 10 189
losses, The number of your losses since the last market_score2, The second value of the current
win. 181 score. 189, 190
lpdif_{minutes}, The absolute lay price difference over market_settled_pl, The amount you won/lost in this
the time specified by {minutes} 212 settled market 187
lt_ma, The moving average of the last traded price market_sp, Returns 1 if the market supports SP
206 bets and bet persistence, or 0 otherwise. 184
ltdif_{minutes}, The change of the lay price over the market_tradeout, Sum of net P/Ls of all market
time specified, in price ticks 212 selections after a trade-out. 187
market_tradeout_{ratio}, Min. net P/Ls of all market
-M- selections after a trade-out with P/L ratio%. 187
market_turn_inplay, 1 if market turns In-Play as the
market modes event starts, 0 otherwise. 184
brief 29 market_ubnum, The number of all unmatched back
engineer 32 bets in the market. 186
full 30 market_ulnum, The number of all unmatched lay
bets in the market. 187
race 31
market_venue, The venue (race course) where the
settings 74
race takes place. 185
market search
market_volume, Total matched amount in the market
fast search 14 given in your currency. 185
Market Locator 20 markets
scheduled search 90 football 249
market_code, Market's betting code 187 greyhound racing 251
market_duration, The estimated duration in secs of horse racing 246
the race that the market belongs to. 185 in triggers 148
market_id, The unique identifier of the market in limit refresh 20, 24, 88, 93, 148, 149, 183,
BetFair database. 184 246, 249, 251
market_index, Market's index in the list of markets market status 149
sorted by their start date. 186
monitoring options 87
market_inplay, An index of the market's status. 0 -
outcome 93
Idle, 1 - In-running, -1 - Suspended. 185
overview 24
market_length, The distance in meters of the race
that the market belongs to. 185 search 20
market_max_pl, The maximum potential profit in the variables 183
market 187 match_{index}_, Referring to matching selections by
market_mbnum, The number of all matched back their index 220
bets in the market. 186
match_b_book, Back book% calculated for the my_balance, The total amount of current (test or
matching selections 219 real) funds in your account 177
match_corners1, Number of corners for the home my_funds, Total current funds (test or real) available
team 191 for betting 177
match_corners2, Number of corners for the away
team 191
match_extra_time, The number of extra minutes at -N-
the end of the half 190
near_sp, What the starting price would be if the
match_ht_score1, How many goals the home team
market was reconciled now 207
scored in First Half 190
new_statement, Returns 1 if there is a new record in
match_ht_score2, How many goals the away team
your account statement or 0 otherwise. 181
scored in First Half 190
now_time, Returns current date and time 178
match_index, The index of the selection in the list of
matching selections 220 now_time_datestr, Returns current date in a string
formatted dd/mm/yyyy 178
match_l_book, Lay book% calculated for the
matching selections 219 now_time_timestr, Returns current time in a string
formatted hh:nn:ss 178
match_minute, The match minute in Football.
189, 190
match_penalties1, Number of penalties scored by
home team 191
-P-
match_penalties2, Number of penalties scored by pdif_{minutes}, The absolute back price difference
away team 191 over the time specified by {minutes} 212
match_period, Number of current match period or 0 if places, The number of winning places in the market
unknown 189, 190 183
match_rcards1, Number of red cards received by prices
home team 190 all selection's prices 75
match_rcards2, Number of red cards received by chances for winning 79
away team 190
Ladder 44, 75
match_ycards1, Number of yellow cards received by
SP, starting prices 74
home team 190
variables 205
match_ycards2, Number of yellow cards received by
away team 190 profit_loss, Selection's P/L. 207
matching_number, The number of selections that profit_loss2, The second P/L figure in place markets.
meet all previous conditions 220 207
maxlp_{minutes}, The maximum value of the lay profit_loss3, The middle P/L figure in Asian Handicap
price within thetime specified by {minutes} 212 and Each Way markets. 208
maxlt_{minutes}, The maximum last traded price
within the specified {minutes} 212
mf_hour, Returns 1 hour in the program's format
-R-
178 race status 167
mf_minute, Returns 1 minute in the program's format race_status, Race status of a horse race market
178 188
mf_second, Returns 1 second in the program's reduction, The overall reduction factor of all
format 178 non-runners in the market. 186
min_stake, Minimum bet amount for your currency refr_market_num, The number of markets that are
178 currently being monitored 177
minlp_{minutes}, The minimum value of the lay price refresh_start, The time in minutes that's passed
within thetime specified by {minutes} 212 since you started monitoring the event. 183
minlt_{minutes}, The minimum last traded price refresh_start_datestr, The formatted date of the start
within the specified {minutes} 212 of the market refreshing 183
most_traded_price, The price at which the maximum refresh_start_timestr, The formatted time of the start
volume has been matched. 206 of the market refreshing 183
most_traded_volume, The maximum volume that has runner_number, The number of selections in the
been matched at one price. 206 market, excluding withdrawn selections. 185
tennis_current_game, The current game number in tennis_stroke_type, The latest stroke type in the
the current set of a Tennis match 192 current game 192
tennis_current_server, The index of the player that tennis_toss_winner, The index of the player that won
serves in this point 192 the toss 192
tennis_current_set, The current set number in a Test Mode 47
Tennis match 192 managing with triggers 140
tennis_first_to_serve, The index of the player that settings 92
gets to serve first 192 turning on/off 48
tennis_p_player_games_won, The previous number test_balance, The amount of test funds in your
of games won by the current player 215 account 177
tennis_p_player_points_won, The previous number of test_funds, Total test funds available for test betting
points won by the current player 215 177
tennis_p_player_sets_won, The previous number of test_mode, Returns 1 if Test Mode is on, or 0 if it is
sets won by the current player 215 off. 178
tennis_p_player{number}_games_won, The previous total_funds, Total real funds available for betting. This
number of games won by player with given {number} is the sum of UK and AUS wallets. 177
192 total_won, Total Profit/Loss that you earned since
tennis_p_player{number}_points_won, The previous the first account statement record 181
number of points won by player with given {number} trade out
191
with a trigger 124
tennis_p_player{number}_sets_won, The previous
traded_{price}, Returns the amount of money traded
number of sets won by player with given {number}
at {price} 206
192
traded_avg_price, The average weighted price at
tennis_player_games_won, The number of games
which the selection is traded. 206
won by the current player in the current set 214
traded_last, Returns the amount of money matched
tennis_player_points_won, The number of points won
at the last traded price 206
by the current player in the current game of the
current set 214 traded_maxa, The amount matched at the max.
traded price. 205
tennis_player_service_breaks, The total number of
player's service breaks 215 traded_maxa_{minvlm}, The amount matched at the
max. price with at least {minvlm}. 206
tennis_player_set{set_number}_game{game_number
}, Whether the player has won in the given game of traded_maxp, The max. price at which at least one
the given set 215 bet is matched. 205
tennis_player_sets_won, The number of sets won by traded_maxp_{minvlm}, The max. price at which at
the current player in the current match 214 least {minvlm} is matched. 205
tennis_player_setsc{set_number}, The score of the traded_mina, The amount matched at the min.
{set_number}'s set for the current player 215 traded price. 205
tennis_player{number}_games_won, The number of traded_mina_{minvlm}, The amount matched at the
games won by player with given {number} in the min. price with at least {minvlm}. 205
current set 191 traded_minp, The min. price at which at least one
tennis_player{number}_points_won, The number of bet is matched. 205
points won by player with given {number} in the traded_minp_{minvlm}, The min. price at which at
current game of the current set 191 least {minvlm} is matched. 205
tennis_player{number}_service_breaks, The number tradedh_{price}, Returns the amount of money traded
of service breaks for player with {number} 192 at {price} or higher 206
tennis_player{number}_set{set_number}_game{game tradedl_{price}, Returns the amount of money traded
_number}, Whether the player won or lost the given at {price} or lower 206
game in the given set. 191 tradeout_net, Selection's net winnings/losses in
tennis_player{number}_sets_won, The number of case of an immediate trade-out. 208
sets won by player with given {number} in the current tradeout_net_{ratio}, Selection's net winnings/losses
match 191 in case of an immediate trade-out. 208
tennis_player{number}_setsc{set_number}, The tradeout_pl, Selection's P/L in case of an immediate
score of the {set_number}'s set for the player with trade-out. 208
given {number} 191 tradeout_pl_{ratio}, Selection's P/L in case of an
immediate trade-out. 208
-V-
variables 176
constants 115
Excel-Bound variables 223
full catalog 47
horse form 220
market variables 183
matching selections 219
parsing order 225
remembered selections 217
selection variables 204
user variables 115
view variables 117
win/lose history 180
voldif_{minutes}, How much the volume of the
selection has changed over {minutes} 212
volume, Selection's percentage of traded volume.
207
-W-
waiting_market_num, The number of markets that
are waiting to be refreshed 177
winner_name, The name of the selection that took
the 1st place in the event. 186
wins, The number of your wins since the last loss.
181