在赫兹期货量化交易系统中创建并测试智能交易存在以下列举特性。编辑切换为居中添加图片注释,不超过 140 字(可选)
在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。if(AccountFreeMargin() < 1000) return(0); // 没有保证金 - 退出
您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。// 如果前一个蜡烛柱的Close少于 // 前者的Close if(Close[1] < Close[2]) return(0);
使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。double eur_close_m1[]; int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, "EURUSD", PERIOD_M1);
智能交易的编写与其他程序创建一样需要一些附加的调试信息。 赫兹期货量化语言提供了几种获取信息的方法。
函数 "Alert" 会出现一个对话窗口显示用户指定数据。Alert("FreeMargin grows to ", AccountFreeMargin(), "!");
函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"\n" 使用于字行的转接。Comment("FreeMargin is ", AccountFreeMargin(), ".");
函数"Print"在系统日志中打印用户指定的数据。Print("FreeMargin is ", AccountFreeMargin(), ".");
程序中错误的获取,函数"GetLastError"的功能非常有用。例如,交易订单经常返回替克数。如果这个替克数字等于 0 (在执行业务过程中出现了错误),获取这个错误的详细信息必须调用函数"GetLastError":int iTickNum = 0; int iLastError = 0; ... iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, Ask + g_TakeProfit * g_Points); if(iTickNum <= 0) { iLastError = GetLastError(); if(iLastError != ERR_NO_ERROR) Alert("Some Message"); }调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。
怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。第一种方法以检测柱的数量为基础:static int prevbars = 0; ... if(prevbars == Bars) return(0); prevbars = Bars; ...这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:if( Volume[0] > 1) return(0); ...这种方法在大量价格替克输入时可能会运行失败。问题在于价格替克的输入时实行单独的作业。如果当下一个替克进入时这个作业处于繁忙状态,那么进入的这个替克则不能进入以避免超载的出现!这种情况下可以使用先前保存的 "Volume"执行检测。第三种方法是以柱的打开时间为基础:static datetime prevtime=0; ... if(prevtime == Time[0]) return(0); prevtime = Time[0]; ... 这种方法是最保险的方法。它能够在任意条件下运行。
"CSV"类型文件运行的范例:int h1; h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE, ";"); if(h1 < 0) { Print("Unable to open file my_data.csv"); return(false); } FileWrite(h1, High[1], Low[1], Close[1], Volume[1]); FileClose(h1);对于代码的一些描述。首先打开"CSV"格式文件。在打开文件时生成错误将会对出程序。在文件成功打开后,清除文件内容并复制数据到文件内,随后关闭文件。如果您需要保存文件原有的内容,可以使用 MODE_READ模式打开:int h1; h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE | MODE_READ, ";"); if(h1 < 0) { Print("Unable to open file my_data.csv"); return(false); } FileSeek(h1, 0, SEEK_END); FileWrite(h1, High[1], Low[1], Close[1], Volume[1]); FileClose(h1);
在开仓之前必须验证账户内是否存在自由保证金。如果账户内的自由保证金不足,开仓交易将失败。您可以测试检验"FreeMargin"值不能够少于1000,因为测试期间一个标准手的的价格为 1000。if(AccountFreeMargin() < 1000) return(0); // 没有保证金 - 退出
您可以通过使用预设定数组Time, Open, Low, High, Close, Volume 获取历史数据。因为历史数据的原因,指数的增长是逐渐递减-指数的最后值为0。指数 1 表示倒数一个时间周期,指数2表示倒数两个时间周期,指数3 倒数三个时间周期以此类推。// 如果前一个蜡烛柱的Close少于 // 前者的Close if(Close[1] < Close[2]) return(0);
使用其他的时间间隔甚至是其他货币对可以获得当前历史的数据。得到这些数据首先需要确定一维数组,并且在函数"ArrayCopySeries"的帮助下完成复制工作。对于函数的调用您可以发送较少数量的参量,并且不指明默认参量。double eur_close_m1[]; int number_copied = ArrayCopySeries(eur_close_m1, MODE_CLOSE, "EURUSD", PERIOD_M1);
智能交易的编写与其他程序创建一样需要一些附加的调试信息。 赫兹期货量化语言提供了几种获取信息的方法。
函数 "Alert" 会出现一个对话窗口显示用户指定数据。Alert("FreeMargin grows to ", AccountFreeMargin(), "!");
函数 "Comment"将会在图表窗口的左上角显示用户指定的数据。符号"\n" 使用于字行的转接。Comment("FreeMargin is ", AccountFreeMargin(), ".");
函数"Print"在系统日志中打印用户指定的数据。Print("FreeMargin is ", AccountFreeMargin(), ".");
程序中错误的获取,函数"GetLastError"的功能非常有用。例如,交易订单经常返回替克数。如果这个替克数字等于 0 (在执行业务过程中出现了错误),获取这个错误的详细信息必须调用函数"GetLastError":int iTickNum = 0; int iLastError = 0; ... iTickNum = OrderSend(Symbol(), OP_BUY, g_Lots, Ask, 3, 0, Ask + g_TakeProfit * g_Points); if(iTickNum <= 0) { iLastError = GetLastError(); if(iLastError != ERR_NO_ERROR) Alert("Some Message"); }调用"GetLastError"函数可以显示错误代码,并且重新设置改值。 因此连续调用这个函数返回的值将是0。
怎样确定开始柱? (必须找到先前柱结束的位置)存在以下几种方法。第一种方法以检测柱的数量为基础:static int prevbars = 0; ... if(prevbars == Bars) return(0); prevbars = Bars; ...这种方法在历史加载的情况下不能运行。在“先前”柱没有完成之间,柱的数量发生改变。这种情况下您可以检查这些值之间的差距等于1。接下来这种方法是以 "Volume" 值为基础取决先前每个柱生成的替克的数量。第一个替克意味着形成柱的"Volume"值等于 1:if( Volume[0] > 1) return(0); ...这种方法在大量价格替克输入时可能会运行失败。问题在于价格替克的输入时实行单独的作业。如果当下一个替克进入时这个作业处于繁忙状态,那么进入的这个替克则不能进入以避免超载的出现!这种情况下可以使用先前保存的 "Volume"执行检测。第三种方法是以柱的打开时间为基础:static datetime prevtime=0; ... if(prevtime == Time[0]) return(0); prevtime = Time[0]; ... 这种方法是最保险的方法。它能够在任意条件下运行。
"CSV"类型文件运行的范例:int h1; h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE, ";"); if(h1 < 0) { Print("Unable to open file my_data.csv"); return(false); } FileWrite(h1, High[1], Low[1], Close[1], Volume[1]); FileClose(h1);对于代码的一些描述。首先打开"CSV"格式文件。在打开文件时生成错误将会对出程序。在文件成功打开后,清除文件内容并复制数据到文件内,随后关闭文件。如果您需要保存文件原有的内容,可以使用 MODE_READ模式打开:int h1; h1 = FileOpen("my_data.csv", MODE_CSV | MODE_WRITE | MODE_READ, ";"); if(h1 < 0) { Print("Unable to open file my_data.csv"); return(false); } FileSeek(h1, 0, SEEK_END); FileWrite(h1, High[1], Low[1], Close[1], Volume[1]); FileClose(h1);