新人对MQL4和MQL5的任何问题,对算法和代码的帮助和讨论 - 页 566 1...559560561562563564565566567568569570571572573...1953 新评论 Alexey Viktorov 2018.06.11 06:24 #5651 Vitaly Muzichenko:试试这个功能。 如果你在货币和期货上都使用这个功能,就不那么简单了。有一个保证金百分比需要考虑。 Vitaly Muzichenko 2018.06.11 06:57 #5652 Alexey Viktorov:如果你在货币和期货上都使用该功能,就不那么简单了。你必须考虑保证金的百分比。如果我们谈论的是损失百分比,我们对保证金不感兴趣,它将在平仓 时返回。 Alexey Viktorov 2018.06.11 07:17 #5653 Vitaly Muzichenko:如果我们谈论的是损失百分比,我们对保证金不感兴趣,它将在平仓 时回来。 我一定是睡过头了...。或者还没有醒过来...... Roman Sharanov 2018.06.11 13:13 #5654 Alekseu Fedotov:也许 请告诉我!怎么做? PolarSeaman 2018.06.11 20:43 #5655 Nikolay Gaylis:我很抱歉你只注意到这一点)。而且我不是唯一的一个,终端机本身看不出有什么不同。阵列外 的出口仍在那里。 YanSay 2018.06.11 22:30 #5656 Vitaly Muzichenko:试试这个功能。 谢谢你的帮助!不幸的是,不可能实施一个通用的解决方案,我不得不这样做。 input double MaximumRisk=0.02; //Риск в сделке от депозита { double TickValue =MarketInfo(Symbol(),MODE_TICKVALUE), TickSize =MarketInfo(Symbol(),MODE_TICKSIZE), ContractSize=MarketInfo(Symbol(),MODE_LOTSIZE), Min_Lot =MarketInfo(Symbol(),MODE_MINLOT), Max_Lot =MarketInfo(Symbol(),MODE_MAXLOT), Step =MarketInfo(Symbol(),MODE_LOTSTEP); { //Для пар XXXUSD, USDXXX, XAUUSD, XAGUSD, CRYPTO, для кроссов Lots = NormalizeDouble((((AccountBalance()*MaximumRisk)/(MathAbs(Price-SL)/Point))/TickValue),int(MathAbs(log(Step)))); //Для перечисленного в if if (Symbol() == "BRN" || Symbol() == "WTI" || Symbol() == "NG" || Symbol() == "NIKK225" || Symbol() == "SPX500") {Lots = NormalizeDouble(((((AccountBalance()*MaximumRisk))/MathAbs(Price-SL)))/(ContractSize/TickValue),1);} //Для перечисленного в if if (Symbol() == "ASX200" || Symbol() == "CAC40" || Symbol() == "NQ100" || Symbol() == "STOXX50" || Symbol() == "DAX30" || Symbol() == "FTSE100" || Symbol() == "IBEX35") {Lots = NormalizeDouble(((((AccountBalance()*MaximumRisk))/MathAbs(Price-SL)))/(TickValue/TickSize/Point),1);} } } 请告诉我,如果我的经纪人有浮动杠杆,我怎样才能在计算手数时将其考虑在内?或者说,如果你选择上述方案,它将不会受到影响? PolarSeaman 2018.06.13 07:05 #5657 另一个指标,也是阵列的范围之外。 它能顺利进入图表,但当我从EA调用它时,它说......阵列超出了'HiLo.mq4'的范围(121,15)。 有什么问题呢?#property copyright "Copyright © november 2015" #property strict #property indicator_chart_window #property indicator_buffers 6 #property indicator_color1 RoyalBlue //DodgerBlue #property indicator_color2 Crimson //OrangeRed #property indicator_color3 Black //White #property indicator_color4 Black //White #property indicator_color5 Black //White #property indicator_color6 Black //Red #property indicator_width1 2 #property indicator_width2 2 #property indicator_style3 STYLE_DOT #property indicator_style4 STYLE_DOT input int p = 10; // Период input int s = 5; // Угол наклона input double distance = 2.0; // Ширина канала input bool showBb = false; // Границы канала input bool showCl = true; // Центральная линия input int barsig = 1; // Сигнальная свеча (номер) input int arrots = 0; // Стрелка (отступ) input int arrsz = 0; // Стрелка (размер) input int ATR = 1000; // Период ATR input int cb = 1000; // Сколько свечей в истории double fx1[],fx2[],hp[]; double z1,z2,ki; int fs; double upper[],lower[]; double upar[],dnar[]; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int OnInit(void) { //--- indicator buffers mapping IndicatorBuffers(7); SetIndexBuffer(0,fx1); SetIndexBuffer(1,fx2); SetIndexBuffer(2,lower); SetIndexBuffer(3,upper); SetIndexBuffer(4,upar); SetIndexBuffer(5,dnar); SetIndexBuffer(6,hp); SetIndexStyle (4,DRAW_ARROW,0,arrsz); SetIndexArrow (4,233); SetIndexStyle (5,DRAW_ARROW,0,arrsz); SetIndexArrow (5,234); if(showBb) {SetIndexStyle(2,DRAW_LINE); SetIndexStyle(3,DRAW_LINE); } else {SetIndexStyle(2,DRAW_NONE); SetIndexStyle(3,DRAW_NONE); } if(showCl) {SetIndexStyle(0,DRAW_LINE); SetIndexStyle(1,DRAW_LINE); } else {SetIndexStyle(0,DRAW_NONE); SetIndexStyle(1,DRAW_NONE); } SetIndexEmptyValue(0,0.0); SetIndexEmptyValue(1,0.0); //--- return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, const int prev_calculated, const datetime &time[], const double &open[], const double &high[], const double &low[], const double &close[], const long &tick_volume[], const long &volume[], const int &spread[]) { //--- int i; SetIndexDrawBegin(0,Bars-cb); SetIndexDrawBegin(1,Bars-cb); double avg; ki=2.0/(p+1); for (i=cb; i>=0; i--) {fx1[i]=Close[i];} for (int m=0; m<=s; m++) { z1=fx1[0]; for (i=0; i<=cb; i++) {z1=z1+(fx1[i]-z1)*ki; hp[i]=z1;} z2=fx1[cb]; for (i=cb; i>=0; i--) {z2=z2+(fx1[i]-z2)*ki; fx1[i]=(hp[i]+z2)/2;} } fs=0; for (i=cb; i>=0; i--) { if (fx1[i]>fx1[i+1]) fs=1; if (fx1[i]<fx1[i+1]) {if (fs==1) fx2[i+1]=fx1[i+1]; fs=2;} if (fs==2) fx2[i]=fx1[i]; else fx2[i]=0.0; avg = iATR(NULL,0,ATR, i+10); upper[i] = hp[i] + distance*avg; lower[i] = hp[i] - distance*avg; if(Close[i+1+barsig]<upper[i+1+barsig] && Close[i+barsig]>upper[i+barsig]) dnar[i] = High[i]+arrots*Point; else dnar[i] = EMPTY_VALUE; if(Close[i+1+barsig]>lower[i+1+barsig] && Close[i+barsig]<lower[i+barsig]) upar[i] = Low[i]-arrots*Point; else upar[i] = EMPTY_VALUE; } //--- return value of prev_calculated for next call return(rates_total); } Ihor Herasko 2018.06.13 07:15 #5658 PolarSeaman:另一个指标,也是阵列的范围之外。 它能顺利进入图表,但当我从EA调用它时,它说......阵列超出了'HiLo.mq4'的范围(121,15)。 有什么问题呢?它并不检查图表上是否有1000个柱状物。例如,在终端打开的那一刻,所有的图表都是0条,但终端已经开始了指标(我不知道它为什么这样做,但这是一个事实)。因此,对指标缓冲区 的任何访问都会导致时间序列数组的超出。 PolarSeaman 2018.06.13 07:24 #5659 Ihor Herasko:没有检查图表上是否有1000个柱子。例如,在终端打开的那一刻,所有的图表都是0条,但终端已经开始了指标(不清楚它为什么这样做,但这是一个事实)。因此,对指标缓冲区 的任何访问都会导致时间序列阵列的退出。if(Bars<cb)return(0); 它仍然崩溃了。 Ihor Herasko 2018.06.13 07:31 #5660 PolarSeaman: 它仍然崩溃了。因为这张支票从根本上是错误的。比方说,Bars返回1000,cb也返回1000。然后在第一次迭代的循环中,我得到的数值是1000。在循环体的第一个条件中。 if (fx1[i]>fx1[i+1]) fs=1; 一次在数组外有 两个出口: 访问一个索引为1000的酒吧和一个索引为1001的酒吧。如果图表有1000个柱子,第一个柱子的索引是0,最后一个柱子的索引是999。 再往前走,通过环形体,在历史中提到了更遥远的酒吧。 if(Close[i+1+barsig]<upper[i+1+barsig] && Close[i+barsig]>upper[i+barsig]) 所有这些都需要在初步检查中加以考虑。 要进行适当的检查,请参阅MQL4参考中的IndicatorCounted()函数的例子。只是现在,IndicatorCounted()最好被联合使用rate_total(这是Bars)和prev_calculated(这是IndicatorCounted())的变量所取代。 1...559560561562563564565566567568569570571572573...1953 新评论 原因: 取消 您错过了交易机会: 免费交易应用程序 8,000+信号可供复制 探索金融市场的经济新闻 注册 登录 拉丁字符(不带空格) 密码将被发送至该邮箱 发生错误 使用 Google 登录 您同意网站政策和使用条款 如果您没有帐号,请注册 可以使用cookies登录MQL5.com网站。 请在您的浏览器中启用必要的设置,否则您将无法登录。 忘记您的登录名/密码? 使用 Google 登录
试试这个功能。
如果你在货币和期货上都使用这个功能,就不那么简单了。有一个保证金百分比需要考虑。
如果你在货币和期货上都使用该功能,就不那么简单了。你必须考虑保证金的百分比。
如果我们谈论的是损失百分比,我们对保证金不感兴趣,它将在平仓 时返回。
如果我们谈论的是损失百分比,我们对保证金不感兴趣,它将在平仓 时回来。
也许
我很抱歉你只注意到这一点)。
而且我不是唯一的一个,终端机本身看不出有什么不同。阵列外 的出口仍在那里。
试试这个功能。
谢谢你的帮助!不幸的是,不可能实施一个通用的解决方案,我不得不这样做。
请告诉我,如果我的经纪人有浮动杠杆,我怎样才能在计算手数时将其考虑在内?或者说,如果你选择上述方案,它将不会受到影响?
另一个指标,也是阵列的范围之外。
它能顺利进入图表,但当我从EA调用它时,它说......阵列超出了'HiLo.mq4'的范围(121,15)。
有什么问题呢?
另一个指标,也是阵列的范围之外。
它能顺利进入图表,但当我从EA调用它时,它说......阵列超出了'HiLo.mq4'的范围(121,15)。
有什么问题呢?
它并不检查图表上是否有1000个柱状物。例如,在终端打开的那一刻,所有的图表都是0条,但终端已经开始了指标(我不知道它为什么这样做,但这是一个事实)。因此,对指标缓冲区 的任何访问都会导致时间序列数组的超出。
没有检查图表上是否有1000个柱子。例如,在终端打开的那一刻,所有的图表都是0条,但终端已经开始了指标(不清楚它为什么这样做,但这是一个事实)。因此,对指标缓冲区 的任何访问都会导致时间序列阵列的退出。
它仍然崩溃了。
它仍然崩溃了。
因为这张支票从根本上是错误的。比方说,Bars返回1000,cb也返回1000。然后在第一次迭代的循环中,我得到的数值是1000。在循环体的第一个条件中。
一次在数组外有 两个出口: 访问一个索引为1000的酒吧和一个索引为1001的酒吧。如果图表有1000个柱子,第一个柱子的索引是0,最后一个柱子的索引是999。
再往前走,通过环形体,在历史中提到了更遥远的酒吧。
所有这些都需要在初步检查中加以考虑。
要进行适当的检查,请参阅MQL4参考中的IndicatorCounted()函数的例子。只是现在,IndicatorCounted()最好被联合使用rate_total(这是Bars)和prev_calculated(这是IndicatorCounted())的变量所取代。