MT4MT5之家-MT4MT5指标脚本EA,这里只有干货!
 
昨日:篇  今日:篇   总帖:篇   会员:
今日:0    总帖:92
admin
5128
我问了Chatgpt如何判断股价涨跌最前沿最先进的方式有哪些?下面是他的回答,仅供参考。预测股价涨跌是股市分析的核心任务之一。以下是判断股价涨跌最前沿最先进的方式: 人工智能和机器学习算法:人工智能和机器学习算法在股市分析中越来越受欢迎,因为它们能够处理大量数据并发现模式。这些算法可以帮助识别技术指标、财务指标和市场情绪等数据的趋势和模式,以预测股价涨跌。 自然语言处理技术:自然语言处理技术可以帮助分析公告、新闻和社交媒体等来源的文本数据,从而了解公司、市场和经济的趋势。这些趋势可以帮助分析股价的涨跌。 数据挖掘技术:数据挖掘技术可以发现数据中隐藏的模式和趋势,从而提供有关股价涨跌的预测。这些技术可以帮助分析历史数据,并使用这些数据中发现的规律来预测未来的趋势。 大数据分析:大数据分析可以帮助股市分析师分析大量数据,从而了解市场趋势和公司绩效。这些趋势可以帮助分析股价的涨跌。 模拟和预测建模:模拟和预测建模技术可以帮助股市分析师创建模型,以预测股价的涨跌。这些模型可以基于历史数据和其他变量来预测未来的趋势。
1 0 979天前
admin
5924
以前写过一个MT4的神龙通道指标,最近迷上了大A,想做大A的韭菜,鉴于昨天大A第49次下破3000点了,本人决定全仓梭哈,为国护盘,所谓重仓出奇迹,本次梭哈已获得蚂蚁金服(花呗,借呗,网商银行),百度金融(有钱花,度小满),腾讯股份(微粒贷),美团股份(美团零用钱),京东资本(白条、金条),小米集团(小米金融),360集团(360借条)、建设银行 、平安银行 、招商银行 (信用卡部)等机构战略投资!房子已挂搜房网,车子已挂瓜子网,媳妇正接洽百合网。不要怂,满仓就是干!,所以写了个通达信和同花顺的神龙通道指标,由于没有建立同花顺和通达信指标公式的栏目,所以发到吹牛下面。VIP会员免费下载:通达信同花顺神龙通道指标
2 0 1109天前
admin
5762
很多老板或许遇到这样的问题,比如正在会所和小MM深入浅出的探讨人生呢,这个时候想改下电脑上ea的参数,怎么办?总不能出门就背着电脑或者笔记本吧,这个时候就会想到,如何用手机就可以手机远程控制操作家里的电脑呢?其实非常简单,最简单的方法就是手机上装一个microsoft远程桌面,这个的缺点就是你家里的电脑得是固定外网IP才可以。所以我教大家一个更有效没有限制的简单的方法。那就是家里的电脑装一个向日葵远程控制软件,手机上再装一个向日葵远程控制APP,这样就可以完美实现用手机操作电脑了。视频教程如下:手机远程控制电脑电脑端设置https://www.bilibili.com/video/bv1be411T7u4手机远程控制电脑手机端设置https://www.bilibili.com/video/bv1iW4y1Y7eF视频教程备用:https://pan.baidu.com/s/1dCNcGARo8XW3l0T2FTqaCw?pwd=mp9u 提取码: mp9u 复制这段内容后打开百度网盘手机App,操作更方便哦
2 0 1122天前
admin
5524
外汇指标中的“重绘”是什么意思?外汇指标中的重绘是一种常见的表达方式,指的是技术指标的重绘也就是国内股票软件里的常说的未来函数(但是严格意义上讲MT4MT5里是没有未来函数这个概念,所以这里用重绘来表达)。重绘指标是一种指标,当新的价格数据(蜡烛/柱)进入时,它会改变它的数据显示。ZigZag指标就是一个例子,它会随着新的价格数据的进入而改变过去的位置。为什么有未来函数重绘的指标不好?这很糟糕,因为信息不可靠。重新绘制指示器给人的印象是指示器显示的信息非常准确,而实际上并非如此。也就是说,知道如何使用某些重绘指标(例如 Zig Zag)的经验丰富的交易者明白,此工具会重绘,对他们来说不是问题,因为他们将使用 ZigZag 作为确认(汇合)与其他技术分析工具、基本面、价格行为或非重绘指标。为什么指标要重绘?由于各种原因,指标将重新绘制。通常是由于:不称职的编码,被故意设计为重绘(骗子),希望谦逊的交易者会因回测或“示例”而堕落,然后购买此指标。您如何知道指标是否重绘?找出指标是否重绘的最简单方法是:将指标放在 1 分钟图表上观察它是否会随着新的价格数据的出现而改变它的读数随着新价格数据的出现,图表上的箭头会消失吗?震荡指标在几支蜡烛之后会改变它的交叉点或斜率吗?这些是重新绘制指标的常见迹象。在代码方面,您可以发现重绘者:当以错误的顺序访问条形图时例如:for (int j = 0; j < limit; j++)当有负指数时例如indicator0 = iCustom(NULL,0,"indi", 0, i-1)表示将来的读数如果您有任何疑问,可以联系阿右来确认您的指标是否重绘。
1 0 1138天前
admin
5548
接下来的话可能会很扎心,我无意去改变人性,也无意去迎合人性。一个成熟的投资者与新手之间的区别不在于手法、技术,而更多的在于心性和思维方式。一、龙头思维,要做就做第一,喝最烈的酒、干最妖的票、挨最毒的打。韭菜思维是贪便宜的思维方式,很多人喜欢去买超跌或低价股,并不是逻辑上认为他们具备上涨的潜力,仅仅是出于本能,他们本能的认为低位的涨起来更就有空间,很多人都在问哪一个是即将的龙头,很多人认为追涨杀跌是人的天性,猜顶摸底次啊是人的天性。二、龙头思维,抓大放小,专注简单,弱水三千只取一瓢饮,只做属于自己的那部分行情,龙头三分之一的时间都是空仓的,三分之一的时间是试错,赚钱的也就只有三分之一的时间。韭菜思维是什么都想搞,无时无刻都想做,而且定位非常不清晰,一会首板,一会追龙头,空仓这辈子是不可能,怀揣着暴富的梦想但是只有三分钟的的耐心,之所以有这样的表现,是很大程度没有清晰的交易体系,缺乏执行力,任何一个方法如果没有自己深度的思考,没有一番纠结的权衡利弊,没有一番笃定,也咩有一段亲身实践的情感体验,你都不可能持续的做下去,这也就是为什么很多人的方法只属于他自己的原因,因为他已经跟他融为一体了。短线龙头说起来就一个字 ,就是等,说起来简单,做起来很难。等意味着你要洗尽铅华,以为这你要各种权衡利弊,意味着你的定位清晰明确,要做到这些不容易,这是一个需要刻意练习的技能而不是学科,要把这些提升到技能的层次,你才会和你的交易系统融为一体。三、龙头思维要具备强者心态自我突破,百分百自我承担,一个强者要充分认识自己,要知道自己的局限性,不断的突破自我,而盈利不过是你不断突破自我的奖励。而韭菜思维是什么呢,骨子里刻满了输家的基因却不自知,与其说别人误导你,还不如说你渴望被误导,他们渴望别人给他们心理按摩,当他们跟你说,20%的收益你要不要,而你的心里想的是,20%怎么能够,至少得50%。你明明知道一个3000的手机,你要在内存,摄像头。等方面做取舍,可你就是希望售货员跟你说这个手机如何的牛逼,就是你内心深处渴望听到这样的话。四、龙头思维是博弈视角,龙头是走出来的,竞争出来的。也是你试错出来的。韭菜思维是一根筋思维,太多人都在问下一个龙头是谁? 你如果想知道明天的行情如何,你就确问明天有多少人想买,有多少人想卖,想要进入到这种博弈思维层次,你就假设你自己是一个拥有几亿资金的大佬,哪怕你手里只有几千几万,如果把几亿的资金交给你,你不想控盘也不想成为庄家,但是你又能足够影响价格的走势,你会怎么办?你会考虑到你和其他投资者的利益关系,你会考虑到他们的投资风格,你会去想有赚钱效应的地方,如果没有,我愿意又应该如何去制造这个风口,我又应该如何去制造逻辑利用逻辑,进去之后,我又能保证自己能够全身而退,一旦你把握住这些核心的问题,那么什么明修栈道暗度陈仓围魏救赵这些主力思维不过是非常简单的事情。
3 0 1306天前
admin
5278
号外,韭菜又长起来了,为各位老板承接MT4,MT5,同花顺,通达信,文华财经,Python指标公式脚本EA专家量化交易人工智能交易系统开发,我们不割韭菜,我们只是镰刀的锻造者。
2 0 1373天前
admin
6166
在写ea的过程中很多老板让我推荐MT4MT5的外汇交易平台来开户,术业有专攻,阿右是专业编程的,一般不搞这些,无奈问的多了就推荐一个阿右用了十几年的老平台吧,支持MT4MT5,支持多种出入金方式,另外还有有美分账号,让你瞬间有富豪的感觉,鉴别黑平台其实很简单就看看他存在的时间是否足够长,时间,可以验证世间的一切真伪!点此链接外汇平台开户
7 0 1452天前
admin
5780
什么是降维打击?“降维打击”这个词,应该来自于刘新慈的小说《三体》。里面有个“二向箔”,这个玩意儿可以把所有接触者从三维降维到二维,是高等文明的清理员用来打击太阳系文明的武器,当人类无法适应二维的时候,地球文明的被毁灭也就是必然的了。以最直白的话来形容,降维攻击就是一方利用多维度的新型优势去攻击在这个维度上处于劣势的另一方.。通俗地讲,“降维打击”,就是“高纬度生物”对“低纬度生物”的一种毁灭式打击。三维的人,碾死一只二维世界的蚂蚁是何其容易,因为其水平不在一个层次,思维不在一个层次的战斗。我们生活在三维空间,除了平面以外,还有深度,但是对于蚂蚁来说,蚂蚁只知道前后左右,没有上下,那么它的世界近似是二维的。怎样实现“降维打击”要想实现“降维打击”,主要有两种方法:(1)把对方去掉一个维度,给于对手致命一击黑洞听说过吗,黑洞是将所有的维度塌缩到0维度(一个点)。而二向箔则是将三维塌缩成2维,其实质是破坏了三维空间内所有的物质的分子结构。《三体》中整个太阳系就是毁于一片小小的“二向箔”。(2)占居高维度三维生物就是二维生物的神!升维打击理论是指在同一个领域里面,利用不在同一竞争层面、高于同行业竞争者的技术或模式创新对其进行不对称打击,从而更快地占领市场。实现“升维”打击战略的关键是将高级别的技术和行业标准应用到低级别的行业,例如将军用技术应用到工业领域,将工业技术应用到民用领域等。交易里的升维进化与降维打击在金融交易里,也是可以通过“升维进化”来实现降维打击的。同样也是把高级别的技术或工具应用到低级别的交易市场里。高级别技术的一个现实例子是“人工智能技术在金融交易”的使用,当我们还在通过阅读著名分析师的评论而做交易参考的时候,“高维度”的交易者,已经通过人工智能瞬间掌握了“全数据”,对整个交易市场的心态了如指掌。当我们还在纠结于用一个通过看不懂豆粕的涨跌时,“高纬度”的交易者却已经再通过期权赚钱。
5 0 1461天前
admin
5975
在本文中,我想推荐我的从 MQL4 迁移到 MQL5 的指南版本。1. 图表周期在 MQL5 图表中,周期常数发生了变化,并添加了一些新的时间周期(M2、M3、M4、M6、M10、M12、H2、H3、H6、H8、H12)。要转换 MQL4 时间段,您可以使用以下函数:ENUM_TIMEFRAMES TFMigrate(int tf) { switch(tf) { case 0: return(PERIOD_CURRENT); case 1: return(PERIOD_M1); case 5: return(PERIOD_M5); case 15: return(PERIOD_M15); case 30: return(PERIOD_M30); case 60: return(PERIOD_H1); case 240: return(PERIOD_H4); case 1440: return(PERIOD_D1); case 10080: return(PERIOD_W1); case 43200: return(PERIOD_MN1); case 2: return(PERIOD_M2); case 3: return(PERIOD_M3); case 4: return(PERIOD_M4); case 6: return(PERIOD_M6); case 10: return(PERIOD_M10); case 12: return(PERIOD_M12); case 16385: return(PERIOD_H1); case 16386: return(PERIOD_H2); case 16387: return(PERIOD_H3); case 16388: return(PERIOD_H4); case 16390: return(PERIOD_H6); case 16392: return(PERIOD_H8); case 16396: return(PERIOD_H12); case 16408: return(PERIOD_D1); case 32769: return(PERIOD_W1); case 49153: return(PERIOD_MN1); default: return(PERIOD_CURRENT); } }应该注意的是,在 MQL5 中,图表时间框架常数的数值(从 H1 开始)不等于柱的分钟数(例如,在 MQL5 中,常数 PERIOD_H1 的数值=16385,但在 MQL4 PERIOD_H1 中=60)。如果在 MQL4 程序中使用 MQL4 常量的数值,则在转换为 MQL5 时您应该考虑到这一点。要确定图表指定时间段的分钟数,请将函数PeriodSeconds返回的值除以60。2. 声明内容MQL5 中不存在一些标准 MQL4 常量,因此应声明它们:#define OP_BUY 0 //Buy #define OP_SELL 1 //Sell #define OP_BUYLIMIT 2 //Pending order of BUY LIMIT type #define OP_SELLLIMIT 3 //Pending order of SELL LIMIT type #define OP_BUYSTOP 4 //Pending order of BUY STOP type #define OP_SELLSTOP 5 //Pending order of SELL STOP type //--- #define MODE_OPEN 0 #define MODE_CLOSE 3 #define MODE_VOLUME 4 #define MODE_REAL_VOLUME 5 #define MODE_TRADES 0 #define MODE_HISTORY 1 #define SELECT_BY_POS 0 #define SELECT_BY_TICKET 1 //--- #define DOUBLE_VALUE 0 #define FLOAT_VALUE 1 #define LONG_VALUE INT_VALUE //--- #define CHART_BAR 0 #define CHART_CANDLE 1 //--- #define MODE_ASCEND 0 #define MODE_DESCEND 1 //--- #define MODE_LOW 1 #define MODE_HIGH 2 #define MODE_TIME 5 #define MODE_BID 9 #define MODE_ASK 10 #define MODE_POINT 11 #define MODE_DIGITS 12 #define MODE_SPREAD 13 #define MODE_STOPLEVEL 14 #define MODE_LOTSIZE 15 #define MODE_TICKVALUE 16 #define MODE_TICKSIZE 17 #define MODE_SWAPLONG 18 #define MODE_SWAPSHORT 19 #define MODE_STARTING 20 #define MODE_EXPIRATION 21 #define MODE_TRADEALLOWED 22 #define MODE_MINLOT 23 #define MODE_LOTSTEP 24 #define MODE_MAXLOT 25 #define MODE_SWAPTYPE 26 #define MODE_PROFITCALCMODE 27 #define MODE_MARGINCALCMODE 28 #define MODE_MARGININIT 29 #define MODE_MARGINMAINTENANCE 30 #define MODE_MARGINHEDGED 31 #define MODE_MARGINREQUIRED 32 #define MODE_FREEZELEVEL 33 //--- #define EMPTY -13. 预定义变量MQL4 MQL5Descriptiondouble AskMqlTick last_tick; SymbolInfoTick(_Symbol,last_tick); double Ask=last_tick.ask; AskThe latest known ask price for the current symbol.SymbolInfoTickint Barsint Bars=Bars(_Symbol,_Period);BarsNumber of bars in the current chart.Barsdouble BidMqlTick last_tick; SymbolInfoTick(_Symbol,last_tick); double Bid=last_tick.bid;BidThe latest known bid price of the current symbol.SymbolInfoTickdouble Close[]double Close[]; int count;   // number of elements to copy ArraySetAsSeries(Close,true); CopyClose(_Symbol,_Period,0,count,Close);CloseSeries array that contains close prices for each bar of the current chart.CopyClose, ArraySetAsSeriesint Digitsint Digits=_Digits;DigitsNumber of digits after the decimal point for the current symbol prices._Digitsdouble High[]double High[]; int count;   // number of elements to copy ArraySetAsSeries(High,true); CopyHigh(_Symbol,_Period,0,count,High);HighSeries array that contains the highest prices of each bar of the current chart.CopyHigh, ArraySetAsSeriesdouble Low[]double Low[]; int count;   // number of elements to copy ArraySetAsSeries(Low,true); CopyLow(_Symbol,_Period,0,count,Low);LowSeries array that contains the lowest prices of each bar of the current chart.CopyLow, ArraySetAsSeriesdouble Open[]double Open[]; int count;   // number of elements to copy ArraySetAsSeries(Open,true); CopyOpen(_Symbol,_Period,0,count,Open);OpenSeries array that contains open prices of each bar of the current chart.CopyOpen, ArraySetAsSeriesdouble Pointdouble Point=_Point;PointThe current symbol point value in the quote currency._Pointdatetime Time[]datetime Time[]; int count;   // number of elements to copy ArraySetAsSeries(Time,true); CopyTime(_Symbol,_Period,0,count,Time);TimeSeries array that contains open time of each bar of the current chart. Data like datetime represent time, in seconds, that has passed since 00:00 a.m. of 1 January, 1970.CopyTime, ArraySetAsSeriesdouble Volume[]long Volume[]; int count;   // number of elements to copy ArraySetAsSeries(Volume,true); CopyTickVolume(_Symbol,_Period,0,count,Volume);VolumeSeries array that contains tick volumes of each bar of the current chart.CopyTickVolume, ArraySetAsSeries4. Account InformationMQL4MQL5Descriptiondouble AccountBalance()double AccountInfoDouble(ACCOUNT_BALANCE)AccountBalanceReturns balance value of the current account (the amount of money on the account).AccountInfoDoubledouble AccountCredit()double AccountInfoDouble(ACCOUNT_CREDIT)AccountCreditReturns credit value of the current account.AccountInfoDoublestring AccountCompany()string AccountInfoString(ACCOUNT_COMPANY)AccountCompanyReturns the brokerage company name where the current account was registered.AccountInfoStringstring AccountCurrency()string AccountInfoString(ACCOUNT_CURRENCY)AccountCurrencyReturns currency name of the current account.AccountInfoStringdouble AccountEquity()double AccountInfoDouble(ACCOUNT_EQUITY)AccountEquityReturns equity value of the current account. Equity calculation depends on trading server settings.AccountInfoDoubledouble AccountFreeMargin()double AccountInfoDouble(ACCOUNT_FREEMARGIN)AccountFreeMarginReturns free margin value of the current account.AccountInfoDoubledouble AccountFreeMarginCheck(string symbol,                               int cmd,                               double volume)-AccountFreeMarginCheckReturns free margin that remains after the specified position has been opened at the current price on the current account.double AccountFreeMarginMode()-AccountFreeMarginModeCalculation mode of free margin allowed to open positions on the current account.int AccountLeverage()int AccountInfoInteger(ACCOUNT_LEVERAGE)AccountLeverageReturns leverage of the current account.AccountInfoIntegerdouble AccountMargin()double AccountInfoDouble(ACCOUNT_MARGIN)AccountMarginReturns margin value of the current account.AccountInfoDoublestring AccountName()string AccountInfoString(ACCOUNT_NAME)AccountNameReturns the current account name.AccountInfoStringint AccountNumber()int AccountInfoInteger(ACCOUNT_LOGIN)AccountNumberReturns the number of the current account.AccountInfoIntegerdouble AccountProfit()double AccountInfoDouble(ACCOUNT_PROFIT)AccountProfitReturns profit value of the current account.AccountInfoDoublestring AccountServer()string AccountInfoString(ACCOUNT_SERVER)AccountServerReturns the connected server name.AccountInfoStringint AccountStopoutLevel()double AccountInfoDouble(ACCOUNT_MARGIN_SO_SO)AccountStopoutLevelReturns the value of the Stop Out level.AccountInfoDoubleint AccountStopoutMode()int AccountInfoInteger(ACCOUNT_MARGIN_SO_MODE)AccountStopoutModeReturns the calculation mode for the Stop Out level.AccountInfoInteger5. Array FunctionsMQL4MQL5 Descriptionint ArrayBsearch(double array[],                  double value,                  int count=WHOLE_ARRAY,                  int start=0,                  int direction=MODE_ASCEND)int ArrayBsearch(double    array[],                  double    searched_value                  )ArrayBsearchThe function searches for a specified value in a one-dimension numeric array.ArrayBsearchint ArrayCopy(object&dest[],               object source[],               int start_dest=0,               int start_source=0,               int count=WHOLE_ARRAY)int ArrayCopy(void  dst_array[],               void  src_array[],               int   dst_start=0,               int   src_start=0,               int   cnt=WHOLE_ARRAY               )ArrayCopyCopies an array to another one. Arrays must be of the same type, but arrays with type double[], int[], datetime[], color[], and bool[] can be copied as arrays of the same type. Returns the amount of copied elements.ArrayCopyint ArrayCopyRates(double&dest_array[],                    string symbol=NULL,                    int timeframe=0)-ArrayCopyRatesCopies data of the current chart bars to the two-dimensional array of RateInfo[][6] type and returns copied bars amount, or -1 if failed.int ArrayCopySeries(double&array[],                     int series_index,                     string symbol=NULL,                     int timeframe=0)int ArrayCopySeriesMQL4(double &array[],                         int series_index,                         string symbol=NULL,                         int tf=0)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int count=Bars(symbol,timeframe);    switch(series_index)      {       case MODE_OPEN:          return(CopyOpen(symbol,timeframe,0,count,array));       case MODE_LOW:          return(CopyLow(symbol,timeframe,0,count,array));       case MODE_HIGH:          return(CopyHigh(symbol,timeframe,0,count,array));       case MODE_CLOSE:          return(CopyClose(symbol,timeframe,0,count,array));       default: return(0);      }    return(0);   }ArrayCopySeriesCopies a timeseries array to a custom array and returns the count of the copied elements.CopyOpen, CopyLow, CopyHigh, CopyClose, Barsint ArrayDimension( object array[])-ArrayDimensionReturns the multidimensional array rank.bool ArrayGetAsSeries( object array[])bool ArrayGetAsSeries(void  array)ArrayGetAsSeriesReturns TRUE if an array is organized as a timeseries array (array elements are indexed from the last to the first one), otherwise returns FALSE.ArrayGetAsSeriesint ArrayInitialize(double &array[],                     double value)int ArrayInitializeMQL4(double &array[],                         double value)   {    ArrayInitialize(array,value);    return(ArraySize(array));   }ArrayInitializeSets all elements of a numeric array to the same value. Returns the count of initialized elements.ArrayInitialize, ArraySizebool ArrayIsSeries( object array[])bool ArrayIsSeries(void  array[])ArrayIsSeriesReturns TRUE if the array under check is a timeseries array (Time[],Open[],Close[],High[],Low[], or Volume[]), otherwise returns FALSE.ArrayIsSeriesint ArrayMaximum(double array[],                  int count=WHOLE_ARRAY,                  int start=0)int ArrayMaximumMQL4(double &array[],                      int count=WHOLE_ARRAY,                      int start=0)   {    return(ArrayMaximum(array,start,count));   }ArrayMaximumSearches for the element with the maximal value. The function returns position of this maximal element in the array.ArrayMaximumint ArrayMinimum(double array[],                  int count=WHOLE_ARRAY,                  int start=0)int ArrayMinimumMQL4(double &array[],                      int count=WHOLE_ARRAY,                      int start=0)   {    return(ArrayMinimum(array,start,count));   }ArrayMinimumSearches for the element with the minimal value. The function returns position of this minimal element in the array.ArrayMinimumint ArrayRange(object array[],                int range_index)int ArrayRange(void  array[],                int   rank_index                )ArrayRangeReturns the count of elements in the given dimension of the array.ArrayRangeint ArrayResize(object &array[],                 int new_size)int ArrayResize(void  array[],                 int   new_size,                 int   allocated_size=0                 )ArrayResizeSets a new size for the first dimension.ArrayResizebool ArraySetAsSeries(double &array[],                       bool set)bool ArraySetAsSeries(void  array[],                       bool  set                       )ArraySetAsSeriesReturns the count of elements in the given dimension of the array. Since indexes are zero-based, the size of dimension is 1 greater than the largest index.ArraySetAsSeriesint ArraySize( object array[])int ArraySize(void  array[])ArraySizeReturns the count of elements contained in the array.ArraySizeint ArraySort(double &array[],               int count=WHOLE_ARRAY,               int start=0,               int sort_dir=MODE_ASCEND)int ArraySortMQL4(double &array[],                   int count=WHOLE_ARRAY,                   int start=0,                   int sort_dir=MODE_ASCEND)   {    switch(sort_dir)      {       case MODE_ASCEND:          ArraySetAsSeries(array,true);       case MODE_DESCEND:          ArraySetAsSeries(array,false);       default: ArraySetAsSeries(array,true);      }    ArraySort(array);    return(0);   }ArraySortSorts numeric arrays by first dimension. Series arrays cannot be sorted by ArraySort().ArraySort, ArraySetAsSeries6. CheckupMQL4MQL5Descriptionint GetLastError()int GetLastError()GetLastErrorThe function returns the last occurred error, then the value of special last_error variable where the last error code is stored will be zeroized.GetLastErrorbool IsConnected()bool TerminalInfoInteger(TERMINAL_CONNECTED)IsConnectedThe function returns the status of the main connection between the client terminal and the server that performs data pumping. It returns TRUE if connection to the server was successfully established, otherwise, it returns FALSE.TerminalInfoIntegerbool IsDemo()bool IsDemoMQL4()   {    if(AccountInfoInteger(ACCOUNT_TRADE_MODE)==ACCOUNT_TRADE_MODE_DEMO)       return(true);    else       return(false);   }IsDemoReturns TRUE if the expert runs on a demo account, otherwise returns FALSE.AccountInfoIntegerbool IsDllsAllowed()bool TerminalInfoInteger(TERMINAL_DLLS_ALLOWED)IsDllsAllowedReturns TRUE if the function DLL call is allowed for the Expert Advisor, otherwise returns FALSE.TerminalInfoIntegerbool IsExpertEnabled()bool AccountInfoInteger(ACCOUNT_TRADE_EXPERT)IsExpertEnabledReturns TRUE if use of Expert Advisors is enabled in the client terminal, otherwise returns FALSE.AccountInfoIntegerbool IsLibrariesAllowed()bool MQLInfoInteger(MQL5_DLLS_ALLOWED)IsLibrariesAllowedReturns TRUE if an Expert Advisor can call library function, otherwise returns FALSE.MQLInfoIntegerbool IsOptimization()bool MQLInfoInteger(MQL5_OPTIMIZATION)IsOptimizationReturns TRUE if an Expert Advisor is running in the strategy tester optimization mode, otherwise returns FALSE.MQLInfoIntegerbool IsStopped()bool IsStopped()IsStoppedReturns TRUE if the program (an Expert Advisor or a script) has been commanded to stop its operation, otherwise returns FALSE.IsStoppedbool IsTesting()bool MQLInfoInteger(MQL5_TESTING)IsTestingReturns TRUE if an Expert Advisor is running in the testing mode, otherwise returns FALSE.MQLInfoIntegerbool IsTradeAllowed()bool MQLInfoInteger(MQL5_TRADE_ALLOWED)IsTradeAllowedReturns TRUE if trading by Expert Advisors is allowed and a thread for trading is not occupied, otherwise returns FALSE.MQLInfoIntegerbool IsTradeContextBusy()-IsTradeContextBusyReturns TRUE if a thread for trading is occupied by another Expert Advisor, otherwise returns FALSE.bool IsVisualMode()bool MQLInfoInteger(MQL5_VISUAL_MODE)IsVisualModeReturns TRUE if the Expert Advisor is tested with checked "Visual Mode" button, otherwise returns FALSE.MQLInfoIntegerint UninitializeReason()int UninitializeReason()UninitializeReasonReturns the code of the uninitialization reason for Expert Advisors, custom indicators, and scripts.UninitializeReason7. Client TerminalMQL4 MQL5 Descriptionstring TerminalCompany()string TerminalInfoString(TERMINAL_COMPANY)TerminalCompanyReturns the name of company owning the client terminal.TerminalInfoStringstring TerminalName()string TerminalInfoString(TERMINAL_NAME)TerminalNameReturns client terminal name.TerminalInfoStringstring TerminalPath()string TerminalInfoString(TERMINAL_PATH)TerminalPathReturns the directory, from which the client terminal was launched.TerminalInfoString8. Common FunctionsMQL4MQL5Descriptionvoid Alert(...)void Alert(argument,...)AlertDisplays a dialog box containing the user-defined data. Parameters can be of any type.Alertvoid Comment(...)void Comment(argument,...)CommentThe function outputs the comment defined by the user in the left top corner of the chart.Commentint GetTickCount()uint GetTickCount()GetTickCountThe GetTickCount() function retrieves the number of milliseconds that have elapsed since the system was started.GetTickCountdouble MarketInfo(string symbol,                   int type)double MarketInfoMQL4(string symbol,                       int type)   {    switch(type)      {       case MODE_LOW:          return(SymbolInfoDouble(symbol,SYMBOL_LASTLOW));       case MODE_HIGH:          return(SymbolInfoDouble(symbol,SYMBOL_LASTHIGH));       case MODE_TIME:          return(SymbolInfoInteger(symbol,SYMBOL_TIME));       case MODE_BID:          return(Bid);       case MODE_ASK:          return(Ask);       case MODE_POINT:          return(SymbolInfoDouble(symbol,SYMBOL_POINT));       case MODE_DIGITS:          return(SymbolInfoInteger(symbol,SYMBOL_DIGITS));       case MODE_SPREAD:          return(SymbolInfoInteger(symbol,SYMBOL_SPREAD));       case MODE_STOPLEVEL:          return(SymbolInfoInteger(symbol,SYMBOL_TRADE_STOPS_LEVEL));       case MODE_LOTSIZE:          return(SymbolInfoDouble(symbol,SYMBOL_TRADE_CONTRACT_SIZE));       case MODE_TICKVALUE:          return(SymbolInfoDouble(symbol,SYMBOL_TRADE_TICK_VALUE));       case MODE_TICKSIZE:          return(SymbolInfoDouble(symbol,SYMBOL_TRADE_TICK_SIZE));       case MODE_SWAPLONG:          return(SymbolInfoDouble(symbol,SYMBOL_SWAP_LONG));       case MODE_SWAPSHORT:          return(SymbolInfoDouble(symbol,SYMBOL_SWAP_SHORT));       case MODE_STARTING:          return(0);       case MODE_EXPIRATION:          return(0);       case MODE_TRADEALLOWED:          return(0);       case MODE_MINLOT:          return(SymbolInfoDouble(symbol,SYMBOL_VOLUME_MIN));       case MODE_LOTSTEP:          return(SymbolInfoDouble(symbol,SYMBOL_VOLUME_STEP));       case MODE_MAXLOT:          return(SymbolInfoDouble(symbol,SYMBOL_VOLUME_MAX));       case MODE_SWAPTYPE:          return(SymbolInfoInteger(symbol,SYMBOL_SWAP_MODE));       case MODE_PROFITCALCMODE:          return(SymbolInfoInteger(symbol,SYMBOL_TRADE_CALC_MODE));       case MODE_MARGINCALCMODE:          return(0);       case MODE_MARGININIT:          return(0);       case MODE_MARGINMAINTENANCE:          return(0);       case MODE_MARGINHEDGED:          return(0);       case MODE_MARGINREQUIRED:          return(0);       case MODE_FREEZELEVEL:          return(SymbolInfoInteger(symbol,SYMBOL_TRADE_FREEZE_LEVEL));       default: return(0);      }    return(0);   }MarketInfoReturns various data about securities listed in the Market Watch window.SymbolInfoInteger, SymbolInfoDouble, Bid, Askint MessageBox(string text=NULL,                string caption=NULL,                int flags=EMPTY)int MessageBox(string  text,                string  caption=NULL,                int     flags=0)MessageBoxThe MessageBox function creates, displays, and operates message box.MessageBoxvoid PlaySound(string filename)bool PlaySound(string filename)PlaySoundFunction plays a sound file.PlaySoundvoid Print(...)void Print(argument,...)PrintPrints a message to the experts log.Printbool SendFTP(string filename,              string ftp_path=NULL)bool SendFTP(string filename,              string ftp_path=NULL)SendFTPSends the file to the FTP server set in the Tools->Options->Publisher tab. If the attempt fails, it retuns FALSE.SendFTPvoid SendMail(string subject,               string some_text)bool SendMail(string  subject,               string  some_text)SendMailSends a message to the e-mail set in the Tools->Options->EMail tab.SendMailvoid Sleep(int milliseconds)void Sleep(int milliseconds)SleepThe Sleep() function suspends execution of the current expert within the specified interval.Sleep9. Conversion FunctionsMQL4MQL5Descriptionstring CharToStr(int char_code)string CharToString(int char_code)CharToStrConversion of the symbol code into a one-character string.CharToStringstring DoubleToStr(double value,                    int digits)string DoubleToString(double value,                       int digits=8)DoubleToStrReturns text string with the specified numerical value converted into a specified precision format.DoubleToStringdouble NormalizeDouble(double value,                        int digits)double NormalizeDouble(double value,                        int digits)NormalizeDoubleRounds the floating point value to the given precision. Returns normalized value of the double type.NormalizeDoubledouble StrToDouble(string value)double StringToDouble(string value)StrToDoubleConverts string representation of number to double type (double-precision format with floating point).StringToDoubleint StrToInteger(string value)long StringToInteger(string value)StrToIntegerConverts string containing the value character representation into a value of the int (integer) type.StringToIntegerdatetime StrToTime(string value)datetime StringToTime(string value)StrToTimeConverts string in the format "yyyy.mm.dd hh:mi" to datetime type (the amount of seconds that have passed since 1 Jan., 1970).StringToTimestring TimeToStr(datetime value,                  int mode=TIME_DATE|TIME_MINUTES)string TimeToString(datetime value,                     int mode=TIME_DATE|TIME_MINUTES)TimeToStrConverts value containing time in seconds that has passed since January 1, 1970, into a string of "yyyy.mm.dd hh:mi" format.TimeToString10. Custom IndicatorsMQL4MQL5 Descriptionvoid IndicatorBuffers(int count)-IndicatorBuffersAllocates memory for buffers used for custom indicator calculations.int IndicatorCounted()int IndicatorCountedMQL4()   {    if(prev_calculated>0) return(prev_calculated-1);    if(prev_calculated==0) return(0);    return(0);   }IndicatorCountedThe function returns the amount of bars not changed after the indicator had been launched last.OnCalculatevoid IndicatorDigits(int digits)bool IndicatorSetInteger(INDICATOR_DIGITS,digits)IndicatorDigitsSets precision format (the count of digits after decimal point) to visualize indicator values.IndicatorSetIntegervoid IndicatorShortName(string name)bool IndicatorSetString(INDICATOR_SHORTNAME,name)IndicatorShortNameSets the "short" name of a custom indicator to be shown in the DataWindow and in the chart subwindow.IndicatorSetStringvoid SetIndexArrow(int index,                    int code)bool PlotIndexSetInteger(index,PLOT_ARROW,code)SetIndexArrowSets an arrow symbol for indicators line of the DRAW_ARROW type.PlotIndexSetIntegerbool SetIndexBuffer(int index,                     double array[])bool SetIndexBuffer(index,array,INDICATOR_DATA)SetIndexBufferBinds the array variable declared at a global level to the custom indicator pre-defined buffer.SetIndexBuffervoid SetIndexDrawBegin(int index,                        int begin)bool PlotIndexSetInteger(index,PLOT_DRAW_BEGIN,begin)SetIndexDrawBeginSets the bar number (from the data beginning) from which the drawing of the given indicator line must start.PlotIndexSetIntegervoid SetIndexEmptyValue(int index,                         double value)bool PlotIndexSetDouble(index,PLOT_EMPTY_VALUE,value)SetIndexEmptyValueSets drawing line empty value.PlotIndexSetDoublevoid SetIndexLabel(int index,                    string text)bool PlotIndexSetString(index,PLOT_LABEL,text)SetIndexLabelSets drawing line description for showing in the DataWindow and in the tooltip.PlotIndexSetStringvoid SetIndexShift(int index,                    int shift)bool PlotIndexSetInteger(index,PLOT_SHIFT,shift)SetIndexShiftSets offset for the drawing line.PlotIndexSetIntegervoid SetIndexStyle(int index,                    int type,                    int style=EMPTY,                    int width=EMPTY,                    color clr=CLR_NONE)void SetIndexStyleMQL4(int index,                        int type,                        int style=EMPTY,                        int width=EMPTY,                        color clr=CLR_NONE)   {    if(width>-1)       PlotIndexSetInteger(index,PLOT_LINE_WIDTH,width);    if(clr!=CLR_NONE)       PlotIndexSetInteger(index,PLOT_LINE_COLOR,clr);    switch(type)      {       case 0:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_LINE);       case 1:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_SECTION);       case 2:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_HISTOGRAM);       case 3:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_ARROW);       case 4:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_ZIGZAG);       case 12:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_NONE);       default:          PlotIndexSetInteger(index,PLOT_DRAW_TYPE,DRAW_LINE);      }    switch(style)      {       case 0:          PlotIndexSetInteger(index,PLOT_LINE_STYLE,STYLE_SOLID);       case 1:          PlotIndexSetInteger(index,PLOT_LINE_STYLE,STYLE_DASH);       case 2:          PlotIndexSetInteger(index,PLOT_LINE_STYLE,STYLE_DOT);       case 3:          PlotIndexSetInteger(index,PLOT_LINE_STYLE,STYLE_DASHDOT);       case 4:          PlotIndexSetInteger(index,PLOT_LINE_STYLE,STYLE_DASHDOTDOT);       default: return;      }SetIndexStyleSets the new type, style, width and color for a given indicator line.PlotIndexSetIntegervoid SetLevelStyle(int draw_style,                    int line_width,                    color clr=CLR_NONE)void SetLevelStyleMQL4(int draw_style,                        int line_width,                        color clr=CLR_NONE)   {    IndicatorSetInteger(INDICATOR_LEVELWIDTH,line_width);    if(clr!=CLR_NONE)       IndicatorSetInteger(INDICATOR_LEVELCOLOR,clr);    switch(draw_style)      {       case 0:          IndicatorSetInteger(INDICATOR_LEVELSTYLE,STYLE_SOLID);       case 1:          IndicatorSetInteger(INDICATOR_LEVELSTYLE,STYLE_DASH);       case 2:          IndicatorSetInteger(INDICATOR_LEVELSTYLE,STYLE_DOT);       case 3:          IndicatorSetInteger(INDICATOR_LEVELSTYLE,STYLE_DASHDOT);       case 4:          IndicatorSetInteger(INDICATOR_LEVELSTYLE,STYLE_DASHDOTDOT);       default: return;      }   }SetLevelStyleThe function sets a new style, width and color of horizontal levels of indicator to be output in a separate window.IndicatorSetIntegervoid SetLevelValue(int level,                    double value)bool IndicatorSetDouble(INDICATOR_LEVELVALUE,level,value)SetLevelValueThe function sets a value for a given horizontal level of the indicator to be output in a separate window.IndicatorSetDouble11. Date and Time FunctionsMQL4 MQL5Descriptionint Day()int DayMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.day);   }DayReturns the current day of the month, i.e., the day of month of the last known server time.TimeCurrent, MqlDateTimeint DayOfWeek()int DayOfWeekMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.day_of_week);   }DayOfWeekReturns the current zero-based day of the week (0-Sunday,1,2,3,4,5,6) of the last known server time.TimeCurrent, MqlDateTimeint DayOfYear()int DayOfYearMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.day_of_year);   }DayOfYearReturns the current day of the year (1 means 1 January,..,365(6) does 31 December), i.e., the day of year of the last known server time.TimeCurrent, MqlDateTimeint Hour()int HourMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.hour);   }HourReturns the hour (0,1,2,..23) of the last known server time by the moment of the program start (this value will not change within the time of the program execution).TimeCurrent, MqlDateTimeint Minute()int MinuteMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.min);   }MinuteReturns the current minute (0,1,2,..59) of the last known server time by the moment of the program start (this value will not change within the time of the program execution).TimeCurrent, MqlDateTimeint Month()int MonthMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.mon);   }MonthReturns the current month as number (1-January,2,3,4,5,6,7,8,9,10,11,12), i.e., the number of month of the last known server time.TimeCurrent, MqlDateTimeint Seconds()int SecondsMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.sec);   }SecondsReturns the amount of seconds elapsed from the beginning of the current minute of the last known server time by the moment of the program start (this value will not change within the time of the program execution).TimeCurrent, MqlDateTimedatetime TimeCurrent()datetime TimeCurrent()TimeCurrentReturns the last known server time (time of incoming of the latest quote) as number of seconds elapsed from 00:00 January 1, 1970.TimeCurrentint TimeDay(datetime date)int TimeDayMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.day);   }TimeDayReturns day of month (1 - 31) for the specified date.TimeToStruct, MqlDateTimeint TimeDayOfWeek(datetime date)int TimeDayOfWeekMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.day_of_week);   }TimeDayOfWeekReturns the zero-based day of week (0 means Sunday,1,2,3,4,5,6) for the specified date.TimeToStruct, MqlDateTimeint TimeDayOfYear(datetime date)int TimeDayOfYearMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.day_of_year);   }TimeDayOfYearReturns day (1 means 1 January,..,365(6) does 31 December) of year for the specified date.TimeToStruct, MqlDateTimeint TimeHour(datetime time)int TimeHourMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.hour);   }TimeHourReturns the hour for the specified time.TimeToStruct, MqlDateTimedatetime TimeLocal()datetime TimeLocal()TimeLocalReturns local computer time as number of seconds elapsed from 00:00 January 1, 1970.TimeLocalint TimeMinute(datetime time)int TimeMinuteMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.min);   }TimeMinuteReturns the minute for the specified time.TimeToStruct, MqlDateTimeint TimeMonth(datetime time)int TimeMonthMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.mon);   }TimeMonthReturns the month number for the specified time.TimeToStruct, MqlDateTimeint TimeSeconds(datetime time)int TimeSecondsMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.sec);   }TimeSecondsReturns the amount of seconds elapsed from the beginning of the minute for the specified time.TimeToStruct, MqlDateTimeint TimeYear(datetime time)int TimeYearMQL4(datetime date)   {    MqlDateTime tm;    TimeToStruct(date,tm);    return(tm.year);   }TimeYearReturns year for the specified date. The returned value can be within the range of 1970 to 2037.TimeToStruct, MqlDateTimeint Year()int YearMQL4()   {    MqlDateTime tm;    TimeCurrent(tm);    return(tm.year);   }YearReturns the current year, i.e., the year of the last known server time.TimeCurrent, MqlDateTime12. File FunctionsMQL4 MQL5 Descriptionvoid FileClose(int handle)void FileClose(int file_handle)FileCloseCloses file previously opened by the FileOpen() function.FileClosevoid FileDelete(string filename)bool FileDelete(string file_name                 int common_flag=0)FileDeleteRemoves specified file name.FileDeletevoid FileFlush(int handle)void FileFlush(int file_handle)FileFlushFlushes all data stored in the file buffer to the disk.FileFlushbool FileIsEnding(int handle)bool FileIsEnding(int file_handle)FileIsEndingReturns logical true if file pointer is at the end of the file, otherwise returns false.FileIsEndingbool FileIsLineEnding(int handle)bool FileIsLineEnding(int file_handle)FileIsLineEndingFor CSV file returns logical true if file pointer is at the end of the line, otherwise returns false.FileIsLineEndingint FileOpen(string filename,              int mode,              int delimiter=';')int FileOpen(string ile_name,              int pen_flags,              short delimiter='\t'              uint codepage=CP_ACP)FileOpenOpens file for input and/or output. Returns a file handle for the opened file or -1 (if the function fails).FileOpenint FileOpenHistory(string filename,                     int mode,                     int delimiter=';')-FileOpenHistoryOpens file in the current history directory (terminal_directory\history\server_name) or in its subfolders. Returns the file handle for the opened file. If the function fails, the returned value is -1.int FileReadArray(int handle,                   object &array[],                   int start,                   int count)uint FileReadArray(int file_handle,                    void array[],                    int start_item=0,                    int items_count=WHOLE_ARRAY)FileReadArrayReads the specified amount of elements from the binary file into array.FileReadArraydouble FileReadDouble(int handle,                       int size=DOUBLE_VALUE)double FileReadDoubleMQL4(int handle,                           int size=DOUBLE_VALUE)   {    return(FileReadDouble(handle));   }FileReadDoubleReads the double-precision number with floating point from the current binary file position.FileReadDoubleint FileReadInteger(int handle,                     int size=LONG_VALUE)int FileReadInteger(int file_handle,                     int size=INT_VALUE)FileReadIntegerThe function reads the integer from the current binary file position.FileReadIntegerdouble FileReadNumber(int handle)double FileReadNumber(int file_handle)FileReadNumberRead the number from the current file position before the delimiter. Only for CSV files.FileReadNumberstring FileReadString(int handle,                       int length=0)string FileReadString(int file_handle,                       int size=-1)FileReadStringФункция читает строку с текущей позиции файла.FileReadStringbool FileSeek(int handle,               int offset,               int origin)bool FileSeekMQL4(long handle,                   int offset,                   ENUM_FILE_POSITION origin)   {    FileSeek(handle,offset,origin);    return(true);   }FileSeekThe function moves the file pointer to a new position that is an offset, in bytes, from the beginning, the end or the current file position.FileSeekint FileSize(int handle)ulong FileSize(int file_handle)FileSizeThe function returns file size in bytes.FileSizeint FileTell(int handle)ulong FileTell(int file_handle)FileTellReturns the current position of the file pointer.FileTellint FileWrite(int handle,...)uint FileWrite(int file_handle,...)FileWriteThe function is intended for writing of data into a CSV file, delimiter being inserted automatically.FileWriteint FileWriteArray(int handle,                    object array[],                    int start,                    int count)int FileWriteArray(int file_handle,                    void array[],                    int start_item=0,                    int items_count=WHOLE_ARRAY)FileWriteArrayThe function writes the array to a binary file.FileWriteArrayint FileWriteDouble(int handle,                     double value,                     int size=DOUBLE_VALUE)uint FileWriteDouble(int file_handle,                      double dvalue)FileWriteDoubleThe function writes a double value with floating point to a binary file.FileWriteDoubleint FileWriteInteger(int handle,                      int value,                      int size=LONG_VALUE)uint FileWriteInteger(int file_handle,                       int ivalue,                       int size=INT_VALUE)FileWriteIntegerThe function writes the integer value to a binary file.FileWriteIntegerint FileWriteString(int handle,                     string value,                     int size)uint FileWriteString(int file_handle,                      string svalue,                      int size=-1)FileWriteStringThe function writes the string to a binary file from the current file position.FileWriteString13. Global VariablesMQL4MQL5 Descriptionbool GlobalVariableCheck(string name)bool GlobalVariableCheck(string name)GlobalVariableCheckReturns TRUE if the global variable exists, otherwise, returns FALSE.GlobalVariableCheckbool GlobalVariableDel(string name)bool GlobalVariableDel(string name)GlobalVariableDelDeletes the global variable.GlobalVariableDeldouble GlobalVariableGet(string name)double GlobalVariableGet(string name)GlobalVariableGetReturns the value of an existing global variable or 0 if an error occurs.GlobalVariableGetstring GlobalVariableName(int index)string GlobalVariableName(int index)GlobalVariableNameThe function returns the name of a global variable by its index in the list of global variables.GlobalVariableNamedatetime GlobalVariableSet(string name,                            double value)datetime GlobalVariableSet(string name,                            double value)GlobalVariableSetSets a new value of the global variable. If it does not exist, the system creates a new global variable.GlobalVariableSetbool GlobalVariableSetOnCondition(string name,                                   double value,                                   double check_value)bool GlobalVariableSetOnCondition(string name,                                   double value,                                   double check_value)GlobalVariableSetOnConditionSets the new value of the existing global variable if the current value equals to the third parameter check_value.GlobalVariableSetOnConditionint GlobalVariablesDeleteAll(string prefix_name=NULL)int GlobalVariablesDeleteAll(string prefix_name=NULL                              datetime limit_data=0)GlobalVariablesDeleteAllDeletes global variables.GlobalVariablesDeleteAllint GlobalVariablesTotal()int GlobalVariablesTotal()GlobalVariablesTotalThe function returns the total count of global variables.GlobalVariablesTotal14. Mathematical Functions MQL4MQL5 Descriptiondouble MathAbs(double value)double MathAbs(double value)MathAbsReturns the absolute value (modulus) of the specified numeric value.MathAbsdouble MathArccos(double x)double MathArccos(double val)MathArccosThe MathArccos function returns the arccosine of x within the range 0 to Pi (in radians).MathArccosdouble MathArcsin(double x)double MathArcsin(double val)MathArcsinThe MathArcsin function returns the arcsine of x in the range -Pi/2 to Pi/2 radians.MathArcsindouble MathArctan(double x)double MathArctan(double value)MathArctanThe MathArctan returns the arctangent of x.MathArctandouble MathCeil(double x)double MathCeil(double val)MathCeilThe MathCeil function returns a numeric value representing the smallest integer that exceeds or equals to x.MathCeildouble MathCos(double value)double MathCos(double value)MathCosReturns the cosine of the specified angle.MathCosdouble MathExp(double d)double MathExp(double value)MathExpReturns the value of e raised to the power of d.MathExpdouble MathFloor(double x)double MathFloor(double val)MathFloorThe MathFloor function returns a numeric value representing the largest integer that is less than or equal to x.MathFloordouble MathLog(double x)double MathLog(double val)MathLogThe MathLog function returns the natural logarithm of x if successful.MathLogdouble MathMax(double value1,                double value2)double MathMax(double value1,                double value2)MathMaxReturns the maximum value of two numeric values.MathMaxdouble MathMin(double value1,                double value2)double MathMin(double value1,                double value2)MathMinReturns the minimum value of two numeric values.MathMindouble MathMod(double value1,                double value2)double MathMod(double value1,                double value2)MathModThe function returns the floating-point remainder of division of two numbers.MathModdouble MathPow(double base,                double exponent)double MathPow(double base,                double exponent)MathPowReturns the value of the base expression raised to the specified power (exponent value).MathPowint MathRand()int MathRand()MathRandThe MathRand function returns a pseudorandom integer within the range of 0 to 32767.MathRanddouble MathRound(double value)double MathRound(double value)MathRoundReturns value rounded to the nearest integer of the specified numeric value.MathRounddouble MathSin(double value)double MathSin(double value)MathSinReturns the sine of the specified angle.MathSindouble MathSqrt(double x)double MathSqrt(double value)MathSqrtThe MathSqrt function returns the square root of x.MathSqrtvoid MathSrand(int seed)void MathSrand(int seed)MathSrandThe MathSrand() function sets the starting point for generating a series of pseudorandom integers.MathSranddouble MathTan(double x)double MathTan(double rad)MathTanMathTan returns the tangent of x.MathTan15. Object FunctionsMQL4 MQL5Descriptionbool ObjectCreate(string name,                   int type,                   int window,                   datetime time1,                   double price1,                   datetime time2=0,                   double price2=0,                   datetime time3=0,                   double price3=0)bool ObjectCreateMQL4(string name,                       ENUM_OBJECT type,                       int window,                       datetime time1,                       double price1,                       datetime time2=0,                       double price2=0,                       datetime time3=0,                       double price3=0)   {    return(ObjectCreate(0,name,type,window,           time1,price1,time2,price2,time3,price3));   }ObjectCreateCreation of an object with the specified name, type and initial coordinates in the specified window.ObjectCreatebool ObjectDelete(string name)bool ObjectDeleteMQL4(string name)   {    return(ObjectDelete(0,name));   }ObjectDeleteDeletes object having the specified name.ObjectDeletestring ObjectDescription(string name)string ObjectDescriptionMQL4(string name)   {    return(ObjectGetString(0,name,OBJPROP_TEXT));   }ObjectDescriptionReturn object description.ObjectGetStringint ObjectFind(string name)int ObjectFindMQL4(string name)   {    return(ObjectFind(0,name));   }ObjectFindSearch for an object having the specified name.ObjectFinddouble ObjectGet(string name,                  int prop_id)double ObjectGetMQL4(string name,                      int index)   {    switch(index)      {       case OBJPROP_TIME1:          return(ObjectGetInteger(0,name,OBJPROP_TIME));       case OBJPROP_PRICE1:          return(ObjectGetDouble(0,name,OBJPROP_PRICE));       case OBJPROP_TIME2:          return(ObjectGetInteger(0,name,OBJPROP_TIME,1));       case OBJPROP_PRICE2:          return(ObjectGetDouble(0,name,,1));       case OBJPROP_TIME3:          return(ObjectGetInteger(0,name,OBJPROP_TIME,2));       case OBJPROP_PRICE3:          return(ObjectGetDouble(0,name,OBJPROP_PRICE,2));       case OBJPROP_COLOR:          return(ObjectGetInteger(0,name,OBJPROP_COLOR));       case OBJPROP_STYLE:          return(ObjectGetInteger(0,name,OBJPROP_STYLE));       case OBJPROP_WIDTH:          return(ObjectGetInteger(0,name,OBJPROP_WIDTH));       case OBJPROP_BACK:          return(ObjectGetInteger(0,name,OBJPROP_WIDTH));       case OBJPROP_RAY:          return(ObjectGetInteger(0,name,OBJPROP_RAY_RIGHT));       case OBJPROP_ELLIPSE:          return(ObjectGetInteger(0,name,OBJPROP_ELLIPSE));       case OBJPROP_SCALE:          return(ObjectGetDouble(0,name,OBJPROP_SCALE));       case OBJPROP_ANGLE:          return(ObjectGetDouble(0,name,OBJPROP_ANGLE));       case OBJPROP_ARROWCODE:          return(ObjectGetInteger(0,name,OBJPROP_ARROWCODE));       case return(ObjectGetInteger(0,name,OBJPROP_TIMEFRAMES));       case OBJPROP_DEVIATION:          return(ObjectGetDouble(0,name,OBJPROP_DEVIATION));       case OBJPROP_FONTSIZE:          return(ObjectGetInteger(0,name,OBJPROP_FONTSIZE));       case OBJPROP_CORNER:          return(ObjectGetInteger(0OBJPROP_CORNER));       case OBJPROP_XDISTANCE:          return(ObjectGetInteger(0,name,OBJPROP_XDISTANCE));       case OBJPROP_YDISTANCE:          return(ObjectGetInteger(0,name,OBJPROP_YDISTANCE));       case OBJPROP_FIBOLEVELS:          return(ObjectGetInteger(0,name,OBJPROP_LEVELS));       case OBJPROP_LEVELCOLOR:          return(      }   }ObjectGetThe function returns the value of the specified object property.ObjectGetInteger, ObjectGetDoublestring ObjectGetFiboDescription(string name,                                 int index)string ObjectGetFiboDescriptionMQL4(string name,                                     int index)   {    return(ObjectGetString(0,name,OBJPROP_LEVELTEXT,index));   }ObjectGetFiboDescriptionThe function returns the level description of a Fibonacci object.ObjectGetStringint ObjectGetShiftByValue(string name,                           double value)int ObjectGetShiftByValueMQL4(string name,                               double   {    ENUM_TIMEFRAMES timeframe=TFMigrate(PERIOD_CURRENT);    datetime Arr[];    int shift;    MqlRates mql4[];    if(ObjectGetTimeByValue(0,name,value)<0) return(-1);    CopyRates(NULL,timeframe,0,1,mql4);    if(CopyTime(NULL,timeframe,mql4[0].time,       ObjectGetTimeByValue(0,name,value),Arr)>0)       return(ArraySize(Arr)-1);    else return(-1);   }ObjectGetShiftByValueThe function calculates and returns bar index (shift related to the current bar) for the given price.MqlRates, ObjectGetTimeByValue, CopyRates, CopyTime, ArraySizedouble ObjectGetValueByShift(string name,                              int shift)double ObjectGetValueByShiftMQL4(string name,                                  int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(PERIOD_CURRENT);    MqlRates mql4[];    CopyRates(NULL,timeframe,shift,1,mql4);    return(ObjectGetValueByTime(0,name,mql4[0].time,0));   }ObjectGetValueByShiftThe function calculates and returns the price value for the specified bar (shift related to the current bar).MqlRates, CopyRates, ObjectGetValueByTimebool ObjectMove(string name,                 int point,                 datetime time1,                 double price1)bool ObjectMoveMQL4(string name,                     int point,                     datetime time1,                     double price1)   {    return(ObjectMove(0,name,point,time1,price1));   }ObjectMoveThe function moves an object coordinate in the chart. Objects can have from one to three coordinates depending on their types.ObjectMovestring ObjectName(int index)string ObjectNameMQL4(int index)   {    return(ObjectName(0,index));   }ObjectNameThe function returns the object name by its index in the objects list.ObjectNameint ObjectsDeleteAll(int window=EMPTY,                      int type=EMPTY)int ObjectsDeleteAllMQL4(int window=EMPTY,                          int type=EMPTY)   {    return(ObjectsDeleteAll(0,window,type));   }ObjectsDeleteAllRemoves all objects of the specified type and in the specified sub-window of the chart.ObjectsDeleteAllbool ObjectSet(string name,                int prop_id,                double value)bool ObjectSetMQL4(string name,                    int index,                    double value)   {    switch(index)      {       case OBJPROP_TIME1:          ObjectSetInteger(0,name,OBJPROP_TIME,(int)value);return(true);       case OBJPROP_PRICE1:          ObjectSetDouble(0,name,OBJPROP_PRICE,value);return(true);       case OBJPROP_TIME2:          ObjectSetInteger(0,name,OBJPROP_TIME,1,(int)value);return(true);       case OBJPROP_PRICE2:          ObjectSetDouble(0,name,OBJPROP_PRICE,1,value);return(true);       case OBJPROP_TIME3:          ObjectSetInteger(0,name,OBJPROP_TIME,2,(int)value);return(true);       case OBJPROP_PRICE3:          ObjectSetDouble(0,name,OBJPROP_PRICE,2,value);return(true);       case OBJPROP_COLOR:          ObjectSetInteger(0,name,OBJPROP_COLOR,(int)value);return(true);       case OBJPROP_STYLE:          ObjectSetInteger(0,name,OBJPROP_STYLE,(int)value);return(true);       case OBJPROP_WIDTH:          ObjectSetInteger(0,name,OBJPROP_WIDTH,(int)value);return(true);       case OBJPROP_BACK:          ObjectSetInteger(0,name,OBJPROP_BACK,(int)value);return(true);       case OBJPROP_RAY:          ObjectSetInteger(0,name,OBJPROP_RAY_RIGHT,(int)value);return(true);       case OBJPROP_ELLIPSE:          ObjectSetInteger(0,name,OBJPROP_ELLIPSE,(int)value);return(true);       case OBJPROP_SCALE:          ObjectSetDouble(0,name,OBJPROP_SCALE,value);return(true);       case OBJPROP_ANGLE:          ObjectSetDouble(0,name,OBJPROP_ANGLE,value);return(true);       case OBJPROP_ARROWCODE:          ObjectSetInteger(0,name,OBJPROP_ARROWCODE,(int)value);return(true);       case OBJPROP_TIMEFRAMES:          ObjectSetInteger(0,name,OBJPROP_TIMEFRAMES,(int)value);return(true);       case OBJPROP_DEVIATION:          ObjectSetDouble(0,name,OBJPROP_DEVIATION,value);return(true);       case OBJPROP_FONTSIZE:          ObjectSetInteger(0,name,OBJPROP_FONTSIZE,(int)value);return(true);       case OBJPROP_CORNER:          ObjectSetInteger(0,name,OBJPROP_CORNER,(int)value);return(true);       case OBJPROP_XDISTANCE:          ObjectSetInteger(0,name,OBJPROP_XDISTANCE,(int)value);return(true);       case OBJPROP_YDISTANCE:          ObjectSetInteger(0,name,OBJPROP_YDISTANCE,(int)value);return(true);       case OBJPROP_FIBOLEVELS:          ObjectSetInteger(0,name,OBJPROP_LEVELS,(int)value);return(true);       case OBJPROP_LEVELCOLOR:          ObjectSetInteger(0,name,OBJPROP_LEVELCOLOR,(int)value);return(true);       case OBJPROP_LEVELSTYLE:          ObjectSetInteger(0,name,OBJPROP_LEVELSTYLE,(int)value);return(true);       case OBJPROP_LEVELWIDTH:          ObjectSetInteger(0,name,OBJPROP_LEVELWIDTH,(int)value);return(true);       default: return(false);      }    return(false);   }ObjectSetChanges the value of the specified object property.ObjectSetInteger, ObjectSetDoublebool ObjectSetFiboDescription(string name,                               int index,                               string text)bool ObjectSetFiboDescriptionMQL4(string name,                                   int index,                                   string text)   {    return(ObjectSetString(0,name,OBJPROP_LEVELTEXT,index,text));   }ObjectSetFiboDescriptionThe function assigns a new description to a level of a Fibonacci object.ObjectSetStringbool ObjectSetText(string name,                    string text,                    int font_size,                    string font_name=NULL,                    color text_color=CLR_NONE)bool ObjectSetTextMQL4(string name,                        string text,                        int font_size,                        string font="",                        color text_color=CLR_NONE)   {    int tmpObjType=(int)ObjectGetInteger(0,name,OBJPROP_TYPE);    if(tmpObjType!=OBJ_LABEL && tmpObjType!=OBJ_TEXT) return(false);    if(StringLen(text)>0 && font_size>0)      {       if(ObjectSetString(0,name,OBJPROP_TEXT,text)==true          && ObjectSetInteger(0,name,OBJPROP_FONTSIZE,font_size)==true)         {          if((StringLen(font)>0)             && ObjectSetString(0,name,OBJPROP_FONT,font)==false)             return(false);          if(text_color>-1             && ObjectSetInteger(0,name,OBJPROP_COLOR,text_color)==false)             return(false);          return(true);         }       return(false);      }    return(false);   }ObjectSetTextChanges the object description.ObjectGetInteger, ObjectSetString, ObjectSetInteger StringLenint ObjectsTotal(int type=EMPTY)int ObjectsTotalMQL4(int type=EMPTY,                      int window=-1)   {    return(ObjectsTotal(0,window,type));   }ObjectsTotalReturns total amount of objects of the specified type in the chart.ObjectsTotalint ObjectType(string name)int ObjectTypeMQL4(string name)   {    return((int)ObjectGetInteger(0,name,OBJPROP_TYPE));   }ObjectTypeThe function returns the object type value.ObjectGetInteger16. String FunctionsMQL4MQL5 Descriptionstring StringConcatenate(...)int StringConcatenate(string &string_var,                       void argument1                       void argument2                       ...)StringConcatenateForms a string of the data passed and returns it.StringConcatenateint StringFind(string text,                string matched_text,                int start=0)int StringFind(string string_value,                string match_substring,                int start_pos=0)StringFindSearch for a substring. Returns the position in the string from which the searched substring begins, or -1 if the substring has not been found.StringFindint StringGetChar(string text,                   int pos)ushort StringGetCharacter(string string_value,                           int pos)StringGetCharReturns character (code) from the specified position in the string.StringGetCharacterint StringLen(string text)int StringLen(string string_value)StringLenReturns character count in a string.StringLenstring StringSetChar(string text,                      int pos,                      int value)bool StringSetCharacter(string &string_var,                         int pos,                         ushort character)StringSetCharReturns the string copy with changed character in the specified position.StringSetCharacterstring StringSubstr(string text,                     int start,                     int length=0)string StringSubstr(string string_value,                     int start_pos,                     int length=-1)StringSubstrExtracts a substring from text string starting from the given position.StringSubstrstring StringTrimLeft(string text)int StringTrimLeft(string& string_var)StringTrimLeftThe function cuts line feed characters, spaces and tabs in the left part of the string.StringTrimLeftstring StringTrimRight(string text)int StringTrimRight(string& string_var)StringTrimRightThe function cuts line feed characters, spaces and tabs in the right part of the string.StringTrimRight17. Technical IndicatorsThe principles of use of the technical indicators in Expert Advisors are considered in the article MQL5 for Newbies: Guide to Using Technical Indicators in Expert Advisors. The method, used in this reference is sufficient to get the indicator calculation results for the specified price. To use this method, we need the auxiliary function:double CopyBufferMQL4(int handle,int index,int shift)   {    double buf[];    switch(index)      {       case 0: if(CopyBuffer(handle,0,shift,1,buf)>0)          return(buf[0]); break;       case 1: if(CopyBuffer(handle,1,shift,1,buf)>0)          return(buf[0]); break;       case 2: if(CopyBuffer(handle,2,shift,1,buf)>0)          return(buf[0]); break;       case 3: if(CopyBuffer(handle,3,shift,1,buf)>0)          return(buf[0]); break;       case 4: if(CopyBuffer(handle,4,shift,1,buf)>0)          return(buf[0]); break;       default: break;      }    return(EMPTY_VALUE);   }let's declare the following constants:ENUM_MA_METHOD MethodMigrate(int method)   {    switch(method)      {       case 0: return(MODE_SMA);       case 1: return(MODE_EMA);       case 2: return(MODE_SMMA);       case 3: return(MODE_LWMA);       default: return(MODE_SMA);      }   } ENUM_APPLIED_PRICE PriceMigrate(int price)   {    switch(price)      {       case 1: return(PRICE_CLOSE);       case 2: return(PRICE_OPEN);       case 3: return(PRICE_HIGH);       case 4: return(PRICE_LOW);       case 5: return(PRICE_MEDIAN);       case 6: return(PRICE_TYPICAL);       case 7: return(PRICE_WEIGHTED);       default: return(PRICE_CLOSE);      }   } ENUM_STO_PRICE StoFieldMigrate(int field)   {    switch(field)      {       case 0: return(STO_LOWHIGH);       case 1: return(STO_CLOSECLOSE);       default: return(STO_LOWHIGH);      }   } //+------------------------------------------------------------------+ enum ALLIGATOR_MODE  { MODE_GATORJAW=1,   MODE_GATORTEETH, MODE_GATORLIPS }; enum ADX_MODE        { MODE_MAIN,         MODE_PLUSDI, MODE_MINUSDI }; enum UP_LOW_MODE     { MODE_BASE,         MODE_UPPER,      MODE_LOWER }; enum ICHIMOKU_MODE   { MODE_TENKANSEN=1,  MODE_KIJUNSEN, MODE_SENKOUSPANA, MODE_SENKOUSPANB, MODE_CHINKOUSPAN }; enum MAIN_SIGNAL_MODE{ MODE_MAIN,         MODE_SIGNAL };MQL4 MQL5 Decsriptiondouble iAC(string symbol,            int timeframe,            int shift)double iACMQL4(string symbol,                int tf,                int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iAC(symbol,timeframe);    if(handle<0)      {       Print("The iAC object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iACCalculates the Bill Williams' Accelerator/Decelerator oscillator.iACdouble iAD(string symbol,            int timeframe,            int shift)double iADMQL4(string symbol,                int tf,                int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=(int)iAD(symbol,timeframe,VOLUME_TICK);    if(handle<0)      {       Print("The iAD object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iADCalculates the Accumulation/Distribution indicator and returns its value.iADdouble iAlligator(string symbol,                   int timeframe,                   int jaw_period,                   int jaw_shift,                   int teeth_period,                   int teeth_shift,                   int lips_period,                   int lips_shift,                   int ma_method,                   int applied_price,                   int mode,                   int shift)double iAlligatorMQL4(string symbol,                       int tf,                       int jaw_period,                       int jaw_shift,                       int teeth_period,                       int teeth_shift,                       int lips_period,                       int lips_shift,                       int method,                       int price,                       int mode,                       int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iAlligator(symbol,timeframe,jaw_period,jaw_shift,                          teeth_period,teeth_shift,                          lips_period,lips_shift,                          ma_method,applied_price);    if(handle<0)      {       Print("The iAlligator object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode-1,shift));   }iAlligatorCalculates the Bill Williams' Alligator and returns its value.iAlligatordouble iADX(string symbol,             int timeframe,             int period,             int applied_price,             int mode,             int shift)double iADXMQL4(string symbol,                 int tf,                 int period,                 int price,                 int mode,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iADX(symbol,timeframe,period);    if(handle<0)      {       Print("The iADX object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode,shift));   }iADXCalculates the Movement directional index and returns its value.iADXdouble iATR(string symbol,             int timeframe,             int period,             int shift)double iATRMQL4(string symbol,                 int tf,                 int period,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iATR(symbol,timeframe,period);    if(handle<0)      {       Print("The iATR object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iATRCalculates the Indicator of the average true range and returns its value.iATRdouble iAO(string symbol,            int timeframe,            int shift)double iAOMQL4(string symbol,                int tf,                int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iAO(symbol,timeframe);    if(handle<0)      {       Print("The iAO object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iAOCalculates the Bill Williams' Awesome oscillator and returns its value.iAOdouble iBearsPower(string symbol,                    int timeframe,                    int period,                    int applied_price,                    int shift)double iBearsPowerMQL4(string symbol,                        int tf,                        int period,                        int price,                        int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iBearsPower(symbol,timeframe,period);    if(handle<0)      {       Print("The iBearsPower object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iBearsPowerCalculates the Bears Power indicator and returns its value.iBearsPowerdouble iBands(string symbol,               int timeframe,               int period,               int deviation,               int bands_shift,               int applied_price,               int mode,               int shift)double iBandsMQL4(string symbol,                   int tf,                   int period,                   double deviation,                   int bands_shift,                   int method,                   int mode,                   int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    int handle=iBands(symbol,timeframe,period,                      bands_shift,deviation,ma_method);    if(handle<0)      {       Print("The iBands object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode,shift));   }iBandsCalculates the Bollinger bands indicator and returns its value.iBandsdouble iBandsOnArray(double array[],                      int total,                      int period,                      int deviation,                      int bands_shift,                      int mode,                      int shift)-iBandsOnArrayCalculation of the Bollinger Bands indicator on data stored in a numeric array.double iBullsPower(string symbol,                    int timeframe,                    int period,                    int applied_price,                    int shift)double iBullsPowerMQL4(string symbol,                        int tf,                        int period,                        int price,                        int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iBullsPower(symbol,timeframe,period);    if(handle<0)      {       Print("The iBullsPower object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iBullsPowerCalculates the Bulls Power indicator and returns its value.iBullsPowerdouble iCCI(string symbol,             int timeframe,             int period,             int applied_price,             int shift)double iCCIMQL4(string symbol,                 int tf,                 int period,                 int price,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iCCI(symbol,timeframe,period,price);    if(handle<0)      {       Print("The iCCI object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iCCICalculates the Commodity channel index and returns its value.iCCIdouble iCCIOnArray(double array[],                    int total,                    int period,                    int shift)-iCCIOnArrayCalculation of the Commodity Channel Index on data stored in a numeric array.double iCustom(string symbol,                int timeframe,                string name,                ...,                int mode,                int shift)int iCustom(string symbol,             ENUM_TIMEFRAMES period,             string name             ...)iCustomCalculates the specified custom indicator and returns its value.iCustomdouble iDeMarker(string symbol,                  int timeframe,                  int period,                  int shift)double iDeMarkerMQL4(string symbol,                      int tf,                      int period,                      int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iDeMarker(symbol,timeframe,period);    if(handle<0)      {       Print("The iDeMarker object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iDeMarkerCalculates the DeMarker indicator and returns its value.iDeMarkerdouble iEnvelopes(string symbol,                   int timeframe,                   int ma_period,                   int ma_method,                   int ma_shift,                   int applied_price,                   double deviation,                   int mode,                   int shift)double EnvelopesMQL4(string symbol,                      int tf,                      int ma_period,                      int method,                      int ma_shift,                      int price,                      double deviation,                      int mode,                      int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iEnvelopes(symbol,timeframe,                          ma_period,ma_shift,ma_method,                          applied_price,deviation);    if(handle<0)      {       Print("The iEnvelopes object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode-1,shift));   }iEnvelopesCalculates the Envelopes indicator and returns its value.iEnvelopesdouble iEnvelopesOnArray(double array[],                          int total,                          int ma_period,                          int ma_method,                          int ma_shift,                          double deviation,                          int mode,                          int shift)-iEnvelopesOnArrayCalculation of the Envelopes indicator on data stored in a numeric array.double iForce(string symbol,               int timeframe,               int period,               int ma_method,               int applied_price,               int shift)double iForceMQL4(string symbol,                   int tf,                   int period,                   int method,                   int price,                   int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    int handle=iForce(symbol,timeframe,period,ma_method,VOLUME_TICK);    if(handle<0)      {       Print("The iForce object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iForceCalculates the Force index and returns its value.iForcedouble iFractals(string symbol,                  int timeframe,                  int mode,                  int shift)double iFractalsMQL4(string symbol,                      int tf,                      int mode,                      int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iFractals(symbol,timeframe);    if(handle<0)      {       Print("The iFractals object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode-1,shift));   }iFractalsCalculates the Fractals and returns its value.iFractalsdouble iGator(string symbol,               int timeframe,               int jaw_period,               int jaw_shift,               int teeth_period,               int teeth_shift,               int lips_period,               int lips_shift,               int ma_method,               int applied_price,               int mode,               int shift)double iGatorMQL4(string symbol,                   int tf,                   int jaw_period,                   int jaw_shift,                   int teeth_period,                   int teeth_shift,                   int lips_period,                   int lips_shift,                   int method,                   int price,                   int mode,                   int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iGator(symbol,timeframe,jaw_period,jaw_shift,                      teeth_period,teeth_shift,                      lips_period,lips_shift,                      ma_method,applied_price);    if(handle<0)      {       Print("The iGator object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode-1,shift));   }iGatorGator oscillator calculation.iGatordouble iIchimoku(string symbol,                  int timeframe,                  int tenkan_sen,                  int kijun_sen,                  int senkou_span_b,                  int mode,                  int shift)double iIchimokuMQL4(string symbol,                      int tf,                      int tenkan_sen,                      int kijun_sen,                      int senkou_span_b,                      int mode,                      int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iIchimoku(symbol,timeframe,                         tenkan_sen,kijun_sen,senkou_span_b);    if(handle<0)      {       Print("The iIchimoku object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode-1,shift));   }iIchimokuCalculates the Ichimoku Kinko Hyo and returns its value.iIchimokudouble iBWMFI(string symbol,               int timeframe,               int shift)double iBWMFIMQL4(string symbol,                   int tf,                   int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=(int)iBWMFI(symbol,timeframe,VOLUME_TICK);    if(handle<0)      {       Print("The iBWMFI object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iBWMFICalculates the Bill Williams Market Facilitation index and returns its value.iBWMFIdouble iMomentum(string symbol,                  int timeframe,                  int period,                  int applied_price,                  int shift)double iMomentumMQL4(string symbol,                      int tf,                      int period,                      int price,                      int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iMomentum(symbol,timeframe,period,applied_price);    if(handle<0)      {       Print("The iMomentum object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iMomentumCalculates the Momentum indicator and returns its value.iMomentumdouble iMomentumOnArray(double array[],                         int total,                         int period,                         int shift)-iMomentumOnArrayCalculation of the Momentum indicator on data stored in a numeric array.double iMFI(string symbol,             int timeframe,             int period,             int shift)double iMFIMQL4(string symbol,                 int tf,                 int period,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=(int)iMFI(symbol,timeframe,period,VOLUME_TICK);    if(handle<0)      {       Print("The iMFI object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iMFICalculates the Money flow index and returns its value.iMFIdouble iMA(string symbol,            int timeframe,            int period,            int ma_shift,            int ma_method,            int applied_price,            int shift)double iMAMQL4(string symbol,                int tf,                int period,                int ma_shift,                int method,                int price,                int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iMA(symbol,timeframe,period,ma_shift,                   ma_method,applied_price);    if(handle<0)      {       Print("The iMA object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iMACalculates the Moving average indicator and returns its value.iMAdouble iMAOnArray(double array[],                   int total,                   int period,                   int ma_shift,                   int ma_method,                   int shift)double iMAOnArrayMQL4(double &array[],                       int total,                       int period,                       int ma_shift,                       int ma_method,                       int shift)   {    double buf[],arr[];    if(total==0) total=ArraySize(array);    if(total>0 && total<=period) return(0);    if(shift>total-period-ma_shift) return(0);    switch(ma_method)      {       case MODE_SMA :         {          total=ArrayCopy(arr,array,0,shift+ma_shift,period);          if(ArrayResize(buf,total)<0) return(0);          double sum=0;          int    i,pos=total-1;          for(i=1;i<period;i++,pos--)             sum+=arr[pos];          while(pos>=0)            {             sum+=arr[pos];             buf[pos]=sum/period;             sum-=arr[pos+period-1];             pos--;            }          return(buf[0]);         }       case MODE_EMA :         {          if(ArrayResize(buf,total)<0) return(0);          double pr=2.0/(period+1);          int    pos=total-2;          while(pos>=0)            {             if(pos==total-2) buf[pos+1]=array[pos+1];             buf[pos]=array[pos]*pr+buf[pos+1]*(1-pr);             pos--;            }          return(buf[shift+ma_shift]);         }       case MODE_SMMA :         {          if(ArrayResize(buf,total)<0) return(0);          double sum=0;          int    i,k,pos;          pos=total-period;          while(pos>=0)            {             if(pos==total-period)               {                for(i=0,k=pos;i<period;i++,k++)                  {                   sum+=array[k];                   buf[k]=0;                  }               }             else sum=buf[pos+1]*(period-1)+array[pos];             buf[pos]=sum/period;             pos--;            }          return(buf[shift+ma_shift]);         }       case MODE_LWMA :         {          if(ArrayResize(buf,total)<0) return(0);          double sum=0.0,lsum=0.0;          double price;          int    i,weight=0,pos=total-1;          for(i=1;i<=period;i++,pos--)            {             price=array[pos];             sum+=price*i;             lsum+=price;             weight+=i;            }          pos++;          i=pos+period;          while(pos>=0)            {             buf[pos]=sum/weight;             if(pos==0) break;             pos--;             i--;             price=array[pos];             sum=sum-lsum+price*period;             lsum-=array[i];             lsum+=price;            }          return(buf[shift+ma_shift]);         }       default: return(0);      }    return(0);   }double iOsMA(string symbol,              int timeframe,              int fast_ema_period,              int slow_ema_period,              int signal_period,              int applied_price,              int shift)double iOsMAMQL4(string symbol,                  int tf,                  int fast_ema_period,                  int slow_ema_period,                  int signal_period,                  int price,                  int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iOsMA(symbol,timeframe,                     fast_ema_period,slow_ema_period,                     signal_period,applied_price);    if(handle<0)      {       Print("The iOsMA object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iOsMACalculates the Moving Average of Oscillator and returns its value.iOsMAdouble iMACD(string symbol,              int timeframe,              int fast_ema_period,              int slow_ema_period,              int signal_period,              int applied_price,              int mode,              int shift)double iMACDMQL4(string symbol,                  int tf,                  int fast_ema_period,                  int slow_ema_period,                  int signal_period,                  int price,                  int mode,                  int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iMACD(symbol,timeframe,                     fast_ema_period,slow_ema_period,                     signal_period,applied_price);    if(handle<0)      {       Print("The iMACD object is not created: Error ",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode,shift));   }iMACDCalculates the Moving averages convergence/divergence and returns its value.iMACDdouble iOBV(string symbol,             int timeframe,             int applied_price,             int shift)double iOBVMQL4(string symbol,                 int tf,                 int price,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iOBV(symbol,timeframe,VOLUME_TICK);    if(handle<0)      {       Print("The iOBV object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iOBVCalculates the On Balance Volume indicator and returns its value.iOBVdouble iSAR(string symbol,             int timeframe,             double step,             double maximum,             int shift)double iSARMQL4(string symbol,                 int tf,                 double step,                 double maximum,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iSAR(symbol,timeframe,step,maximum);    if(handle<0)      {       Print("The iSAR object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iSARCalculates the Parabolic Stop and Reverse system and returns its value.iSARdouble iRSI(string symbol,             int timeframe,             int period,             int applied_price,             int shift)double iRSIMQL4(string symbol,                 int tf,                 int period,                 int price,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iRSI(symbol,timeframe,period,applied_price);    if(handle<0)      {       Print("The iRSI object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iRSICalculates the Relative strength index and returns its value.iRSIdouble iRSIOnArray(double array[],                    int total,                    int period,                    int shift)-iRSIOnArrayCalculation of the Relative Strength Index on data stored in a numeric array.double iRVI(string symbol,             int timeframe,             int period,             int mode,             int shift)double iRVIMQL4(string symbol,                 int tf,                 int period,                 int mode,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iRVI(symbol,timeframe,period);    if(handle<0)      {       Print("The iRVI object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode,shift));   }iRVICalculates the Relative Vigor index and returns its value.iRVIdouble iStdDev(string symbol,                int timeframe,                int ma_period,                int ma_shift,                int ma_method,                int applied_price,                int shift)double iStdDevMQL4(string symbol,                    int tf,                    int ma_period,                    int ma_shift,                    int method,                    int price,                    int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_APPLIED_PRICE applied_price=PriceMigrate(price);    int handle=iStdDev(symbol,timeframe,ma_period,ma_shift,                       ma_method,applied_price);    if(handle<0)      {       Print("The iStdDev object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iStdDevCalculates the Standard Deviation indicator and returns its value.iStdDevdouble iStdDevOnArray(double array[],                       int total,                       int ma_period,                       int ma_shift,                       int ma_method,                       int shift)-iStdDevOnArrayCalculation of the Standard Deviation indicator on data stored in a numeric array.double iStochastic(string symbol,                    int timeframe,                    int%Kperiod,                    int%Dperiod,                    int slowing,                    int method,                    int price_field,                    int mode,                    int shift)double iStochasticMQL4(string symbol,                        int tf,                        int Kperiod,                        int Dperiod,                        int slowing,                        int method,                        int field,                        int mode,                        int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    ENUM_MA_METHOD ma_method=MethodMigrate(method);    ENUM_STO_PRICE price_field=StoFieldMigrate(field);    int handle=iStochastic(symbol,timeframe,Kperiod,Dperiod,                           slowing,ma_method,price_field);    if(handle<0)      {       Print("The iStochastic object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,mode,shift));   }iStochasticCalculates the Stochastic oscillator and returns its value.iStochasticdouble iWPR(string symbol,             int timeframe,             int period,             int shift)double iWPRMQL4(string symbol,                 int tf,                 int period,                 int shift)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    int handle=iWPR(symbol,timeframe,period);    if(handle<0)      {       Print("The iWPR object is not created: Error",GetLastError());       return(-1);      }    else       return(CopyBufferMQL4(handle,0,shift));   }iWPRCalculates the Larry William's percent range indicator and returns its value.iWPR18. Timeseries AccessMQL4 MQL5 Descriptionint iBars(string symbol,           int timeframe)int iBarsMQL4(string symbol,int tf)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    return(Bars(symbol,timeframe));   } int iBarsMQL4(string symbol,int tf)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    return(Bars(symbol,timeframe));   }BarsReturns the number of bars on the specified chart.Barsint iBarShift(string symbol,               int timeframe,               datetime time,               bool exact=falseint iBarShiftMQL4(string symbol,                   int tf,                   datetime time,                   bool exact=false)   {    if(time<0) return(-1);    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    datetime Arr[],time1;    CopyTime(symbol,timeframe,0,1,Arr);    time1=Arr[0];    if(CopyTime(symbol,timeframe,time,time1,Arr)>0)      {       if(ArraySize(Arr)>2) return(ArraySize(Arr)-1);       if(time<time1) return(1);       else return(0);      }    else return(-1);   }iBarShiftSearch for bar by open time.CopyTime, ArraySizedouble iClose(string symbol,               int timeframe,               int shift)double iCloseMQL4(string symbol,int tf,int index) {    if(index < 0) return(-1);    double Arr[];    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(CopyClose(symbol,timeframe, index, 1, Arr)>0) return(Arr[0]);    else return(-1); }CloseReturns Close value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRatesdouble iHigh(string symbol,              int timeframe,              int shift)double iHighMQL4(string symbol,int tf,int index) {    if(index < 0) return(-1);    double Arr[];    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(CopyHigh(symbol,timeframe, index, 1, Arr)>0)         return(Arr[0]);    else return(-1); } HighReturns High value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRatesint iHighest(string symbol,              int timeframe,              int type,              int count=WHOLE_ARRAY,              int start=0)int iHighestMQL4(string symbol,                  int tf,                  int type,                  int count=WHOLE_ARRAY,                  int start=0)   {    if(start<0) return(-1);    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(count<=0) count=Bars(symbol,timeframe);    if(type<=MODE_OPEN)      {       double Open[];       ArraySetAsSeries(Open,true);       CopyOpen(symbol,timeframe,start,count,Open);       return(ArrayMaximum(Open,0,count)+start);      }    if(type==MODE_LOW)      {       double Low[];       ArraySetAsSeries(Low,true);       CopyLow(symbol,timeframe,start,count,Low);       return(ArrayMaximum(Low,0,count)+start);      }    if(type==MODE_HIGH)      {       double High[];       ArraySetAsSeries(High,true);       CopyHigh(symbol,timeframe,start,count,High);       return(ArrayMaximum(High,0,count)+start);      }    if(type==MODE_CLOSE)      {       double Close[];       ArraySetAsSeries(Close,true);       CopyClose(symbol,timeframe,start,count,Close);       return(ArrayMaximum(Close,0,count)+start);      }    if(type==MODE_VOLUME)      {       long Volume[];       ArraySetAsSeries(Volume,true);       CopyTickVolume(symbol,timeframe,start,count,Volume);       return(ArrayMaximum(Volume,0,count)+start);      }    if(type>=MODE_TIME)      {       datetime Time[];       ArraySetAsSeries(Time,true);       CopyTime(symbol,timeframe,start,count,Time);       return(ArrayMaximum(Time,0,count)+start);       //---      }    return(0);   }iHighestReturns the shift of the maximum value over a specific number of periods depending on type.CopyOpen, CopyLow, CopyHigh, CopyClose, CopyTickVolume, CopyTime, ArrayMaximumdouble iLow(string symbol,             int timeframe,             int shift)double iLowMQL4(string symbol,int tf,int index) {    if(index < 0) return(-1);    double Arr[];    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(CopyLow(symbol,timeframe, index, 1, Arr)>0)         return(Arr[0]);    else return(-1); }iLowReturns Low value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRatesint iLowest(string symbol,             int timeframe,             int type,             int count=WHOLE_ARRAY,             int start=0)int iLowestMQL4(string symbol,                 int tf,                 int type,                 int count=WHOLE_ARRAY,                 int start=0)   {    if(start<0) return(-1);    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(count<=0) count=Bars(symbol,timeframe);    if(type<=MODE_OPEN)      {       double Open[];       ArraySetAsSeries(Open,true);       CopyOpen(symbol,timeframe,start,count,Open);       return(ArrayMinimum(Open,0,count)+start);      }    if(type==MODE_LOW)      {       double Low[];       ArraySetAsSeries(Low,true);       CopyLow(symbol,timeframe,start,count,Low);       return(ArrayMinimum(Low,0,count)+start);      }    if(type==MODE_HIGH)      {       double High[];       ArraySetAsSeries(High,true);       CopyHigh(symbol,timeframe,start,count,High);       return(ArrayMinimum(High,0,count)+start);      }    if(type==MODE_CLOSE)      {       double Close[];       ArraySetAsSeries(Close,true);       CopyClose(symbol,timeframe,start,count,Close);       return(ArrayMinimum(Close,0,count)+start);      }    if(type==MODE_VOLUME)      {       long Volume[];       ArraySetAsSeries(Volume,true);       CopyTickVolume(symbol,timeframe,start,count,Volume);       return(ArrayMinimum(Volume,0,count)+start);      }    if(type>=MODE_TIME)      {       datetime Time[];       ArraySetAsSeries(Time,true);       CopyTime(symbol,timeframe,start,count,Time);       return(ArrayMinimum(Time,0,count)+start);      } //---    return(0);   }iLowestReturns the shift of the lowest value over a specific number of periods depending on type.CopyOpen, CopyLow, CopyHigh, CopyClose, CopyTickVolume, CopyTime, ArrayMinimumdouble iOpen(string symbol,              int timeframe,              int shift)double iOpenMQL4(string symbol,int tf,int index) {      if(index < 0) return(-1);    double Arr[];    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(CopyOpen(symbol,timeframe, index, 1, Arr)>0)         return(Arr[0]);    else return(-1); }iOpenReturns Open value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRatesdatetime iTime(string symbol,                int timeframe,                int shift)datetime iTimeMQL4(string symbol,int tf,int index) {    if(index < 0) return(-1);    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    datetime Arr[];    if(CopyTime(symbol, timeframe, index, 1, Arr)>0)         return(Arr[0]);    else return(-1); }iTimeReturns Time value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRatesdouble iVolume(string symbol,                int timeframe,                int shift)int iVolumeMQL4(string symbol,int tf,int index) {    if(index < 0) return(-1);    long Arr[];    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    if(CopyTickVolume(symbol, timeframe, index, 1, Arr)>0)         return(Arr[0]);    else return(-1); }iVolumeReturns Tick Volume value for the bar of indicated symbol with timeframe and shift. If local history is empty (not loaded), function returns 0.CopyRates, MqlRates19. Chart OperationsMQL4 MQL5Descriptionvoid HideTestIndicators(bool hide)-HideTestIndicatorsThe function sets a flag hiding indicators called by the Expert Advisor.int Period()ENUM_TIMEFRAMES  Period()PeriodReturns the amount of minutes determining the used period (chart timeframe).Periodbool RefreshRates()-RefreshRatesRefreshing of data in pre-defined variables and series arrays.string Symbol()string Symbol()SymbolReturns a text string with the name of the current financial instrument.Symbolint WindowBarsPerChart()int ChartGetInteger(0,CHART_VISIBLE_BARS,0)WindowBarsPerChartFunction returns the amount of bars visible on the chart.ChartGetIntegerstring WindowExpertName()string MQLInfoString(MQL5_PROGRAM_NAME)WindowExpertNameReturns name of the executed expert, script, custom indicator, or library, depending on the MQL4 program, from which this function has been called.MQLInfoStringint WindowFind(string name)int WindowFindMQL4(string name)   {    int window=-1;    if((ENUM_PROGRAM_TYPE)MQLInfoInteger(MQL5_PROGRAM_TYPE)==PROGRAM_INDICATOR)      {       window=ChartWindowFind();      }    else      {       window=ChartWindowFind(0,name);       if(window==-1) Print(__FUNCTION__+"(): Error = ",GetLastError());      }    return(window);   }WindowFindIf indicator with name was found, the function returns the window index containing this specified indicator, otherwise it returns -1.ChartWindowFind, MQLInfoIntegerint WindowFirstVisibleBar()int ChartGetInteger(0,CHART_FIRST_VISIBLE_BAR,0)WindowFirstVisibleBarThe function returns the first visible bar number in the current chart window.ChartGetIntegerint WindowHandle(string symbol,                  int timeframe)int WindowHandleMQL4(string symbol,                      int tf)   {    ENUM_TIMEFRAMES timeframe=TFMigrate(tf);    long currChart,prevChart=ChartFirst();    int i=0,limit=100;    while(i<limit)      {       currChart=ChartNext(prevChart);       if(currChart<0) break;       if(ChartSymbol(currChart)==symbol          && ChartPeriod(currChart)==timeframe)          return((int)currChart);       prevChart=currChart;       i++;      }    return(0);   }WindowHandleReturns the system window handle of the specified chart.ChartFirst, ChartNext, ChartSymbol, ChartPeriodbool WindowIsVisible(int index)bool ChartGetInteger(0,CHART_WINDOW_IS_VISIBLE,index)WindowIsVisibleReturns TRUE if the chart subwindow is visible, otherwise returns FALSE.ChartGetIntegerint WindowOnDropped()int ChartWindowOnDropped()WindowOnDroppedReturns window index where expert, custom indicator or script was dropped.ChartWindowOnDroppeddouble WindowPriceMax(int index=0)double ChartGetDouble(0,CHART_PRICE_MAX,index)WindowPriceMaxReturns maximal value of the vertical scale of the specified subwindow of the current chart (0-main chart window, the indicators' subwindows are numbered starting from 1).ChartGetDoubledouble WindowPriceMin(int index=0)double ChartGetDouble(0,CHART_PRICE_MIN,index)WindowPriceMinReturns minimal value of the vertical scale of the specified subwindow of the current chart (0-main chart window, the indicators' subwindows are numbered starting from 1).ChartGetDoubledouble WindowPriceOnDropped()double ChartPriceOnDropped()WindowPriceOnDroppedReturns the price part of the chart point where expert or script was dropped.ChartPriceOnDroppedvoid WindowRedraw()void ChartRedraw(0)WindowRedrawRedraws the current chart forcedly.ChartRedrawbool WindowScreenShot(string filename,                       int size_x,                       int size_y,                       int start_bar=-1,                       int chart_scale=-1,                       int chart_mode=-1)bool WindowScreenShotMQL4(string filename,                           int size_x,                           int size_y,                           int start_bar=-1,                           int chart_scale=-1,                           int chart_mode=-1)   {    if(chart_scale>0 && chart_scale<=5)       ChartSetInteger(0,CHART_SCALE,chart_scale);    switch(chart_mode)      {       case 0: ChartSetInteger(0,CHART_MODE,CHART_BARS);       case 1: ChartSetInteger(0,CHART_MODE,CHART_CANDLES);       case 2: ChartSetInteger(0,CHART_MODE,CHART_LINE);      }    if(start_bar<0)       return(ChartScreenShot(0,filename,size_x,size_y,ALIGN_RIGHT));    else       return(ChartScreenShot(0,filename,size_x,size_y,ALIGN_LEFT));   }WindowScreenShotSaves current chart screen shot as a GIF file.ChartSetInteger, ChartScreenShotdatetime WindowTimeOnDropped()datetime ChartTimeOnDropped()WindowTimeOnDroppedReturns the time part of the chart point where expert or script was dropped.ChartTimeOnDroppedint WindowsTotal()int ChartGetInteger(0,CHART_WINDOWS_TOTAL)WindowsTotalReturns count of indicator windows on the chart (including main chart).ChartGetIntegerint WindowXOnDropped()int ChartXOnDropped()WindowXOnDroppedReturns the value at X axis in pixels for the chart window client area point at which the expert or script was dropped.ChartXOnDroppedint WindowYOnDropped()int ChartYOnDropped()WindowYOnDroppedReturns the value at Y axis in pixels for the chart window client area point at which the expert or script was dropped.ChartYOnDroppedbool IsTesting()bool MQLInfoInteger(MQL_TESTER) bool IsTradeAllowed()bool MQLInfoInteger(MQL_TRADE_ALLOWED)bool IsVisualMode()bool MQLInfoInteger(MQL_VISUAL_MODE)
7 0 1467天前
admin
6454
MT5与MT4到底哪个好用?MT5比MT4强在哪里?阿右来告诉你。一、技术上,MT5同样的服务器硬件资源,可以支持更多的用户同时在线和并发,而且有十倍以上的性能提升,但个人觉得这些和用户关系不大,或者和最终买单的交易商客户也关系不大,因此MT5的用户包是用来单独销售的,也就意味着,这些性能的提升主要不是给交易商客户带来多少成本降低,而是给迈达克自身带来了更多的成本优势。二、MT5对接口的支持非常丰富,可以提供移动端,网页端等各种应用程序的再次开发拓展需求,同时MT5的技术文档等支持也做的更为专业、规范。对开发人员来说,选择MT5会比MT4有优势的多。三、MT5自身就设计了Gateway模块,用于对接外部的交易所和流动性提供商。也就是说买了MT5的交易商,可以不用购买外部的Bridge了,直接拿MT5的gateway就可以对接更多的流动性提供商,但还是和第一个问题一样,GateWay是需要单独收费的。MT5的历史回测功能比MT4功能更加强大,可调控性更强。一、在MT5模式下的策略测试,是一个独立于编程块、交易块的一个单独模块,重视程度显著提高。二、从我们在本地下单,到服务器接收到下单指令,是有一个网络延迟的,这个在你MT4右下角服务器那里可以查看。为了能够完全检验策略在一定延迟环境下的表现,MT5提供了可以自设延时毫秒的功能,以及在不稳定网络环境下的随机延时,这样对策略逻辑的检验就很有效了,也减少了回测和实盘交易的误差。三、MT5历史回测时可选择浮动点差来进行测试,完全符合每次报价的实时点差。而MT4历史回测时只能选择固定点差来进行测试,相对而言并没有那么人性化。四、MT5可以支持多线程优化测试,可以调用局域网内的闲置电脑,或者网络上的电脑(付费)来做策略测试,极大的提高了效率。五、MT5支持多货币对历史测试,这样的话,在MT5上可以研发多货币对冲模型,并检验其效果,MT4是不支持多货币策略回测的。
10 0 1514天前
快速发帖 高级模式
您的IP:10.1.104.109,2025-10-26 15:51:08,Processed in 0.0625 second(s).
外汇实盘交易、外汇保证金交易、贵金属交易及其他金融投资产品均存在较高风险,并不适合每一位投资者。如有必要,请咨询专业的投资顾问或法律人士。因各国或地区监管规定 不同,本站所提供的广告信息或服务未必适用于所有国家或地区的投资者。投资者进行相关投资,可能不受所在地法律保护,敬请深入研究,审慎决策。本站登载的所有 内容仅出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,也不构成任何投资建议。投资者据此操作,需自行承担由此产生的任何风险。