以下是作者的描述以及我的小改动,因为现在五位数字已经用于货币对。 EA 的目标如下:假设我们有一个基本的交易系统( BTS )。我们应该设计和训练一个神经网络( NN ),以便它可以通过执行 BTS 无法访问的动作来补充 BTS。因此,我们将得到一个由两个组合和互补的 BTS 和 NN 组成的交易系统。 轮子早就发明了,没必要重新发明。如果有汽车,教任何人跑得快,或者如果你有直升机,教任何人飞快有什么意义?
! J6 X* ~+ g/ ^( P' x 如果我们有趋势 TS,则有必要只教神经网络一个反趋势策略。用于趋势的系统不能在横盘期间交易,也不能充分定义回滚和反转。当然,我们可以使用两种交易策略(趋势和反趋势)并在一个图表上启动它们。另一方面,我们可以训练一个神经网络,使其补充交易系统。 为此,我们开发了由两个底层感知器和一个上层感知器组成的两层神经网络。
5 x2 M5 o. z" D3 \, x7 U神经网络可能处于以下三种状态之一: - 进入长
- 输入短
- 不明确的
- P& F1 H# I3 ?' a+ m! D, o0 F
& c. K8 |$ o8 h4 O6 j第三种状态意味着控制权被传递给 BTS,而交易信号是由网络在前两种状态下产生的。神经网络训练分为三个阶段。每个人都训练了一个感知器。优化的 BTS 出现在每个阶段,让感知器知道它可以做什么。 使用遗传算法对感知器进行单独训练是由该算法的缺点引起的,即在其帮助下可以选择的参数数量有限。无论如何,每个训练阶段在逻辑上是一致的,并且神经网络不会太大,因此整个优化过程发生在合理的时间内。 但 NN 训练之前的第一阶段是针对 BTS 优化的。 为避免混淆,在 EA 输入中使用“通过”ID 指定阶段编号。与阶段编号对应的输入 ID 以该确切编号结尾。 让我们为神经网络优化和训练做初步准备。 将测试器中的初始存款设置为 100 美元(优化期间不创建人为追加保证金),优化“余额 + 最大夏普比率”参数,“快速遗传算法”优化类型。 现在,转到 EA 属性的 Inputs 选项卡。 通过将值 0.01 分配给 " lots " ID0 @; r, I& T/ b* y- }# J
来设置开仓的手数。 将根据“仅开盘价”模型进行优化。该方法因其高速而被选中。此外,EA 算法具有新的柱管理功能。 第一优化阶段。基站优化: 将 pass 设置为 1。
- U, g/ U/ M6 Z8 p- D! S仅优化与第一阶段相对应的输入,其所有 ID 都以一个结尾。因此,在它们上设置优化标记,仅从其余参数中删除标记。 tp1 - BTS 获利。使用 100 到 1000 的值进行优化,步长为 10
/ R. W6 ~+ A( o* m4 I' S& K2 Bsl1 - BTS 止损。使用 100 到 1000 的值进行优化,步长为 10
# B7 j( c* T" x! qp1 - BTS 中应用的 CCI 振荡器周期。使用从 3 到 100 的值进行优化,步长为 1 通过遗传算法优化开始训练。 第二阶段。训练负责空头头寸的感知器: 将“通过”输入设置为 2(使其与阶段编号匹配)。 " G/ D0 P8 K c$ _: G$ ], q
去除上一阶段设置的优化标记。将上一阶段获得的输入保存到文件中以防万一。 为第二阶段参数设置优化标记(ID 以两个结尾): x12, x22, x32, x42 - 感知器识别空头头寸的权重比。使用从 0 到 200 的值进行优化,步长为 1。
! w" W/ e7 F' U q8 O2 C4 Ctp2 - 由感知器打开的头寸获利。使用 100 到 1000 的值进行优化,步长为 102 Y0 o7 Y* Q/ D+ r0 T8 O
sl2 - 感知器开仓的止损。使用 100 到 1000 的值进行优化,步长为 10
1 R& R( M4 L$ Rp2 - 感知器分析的价格差异值周期。使用从 3 到 100 的值进行优化,步长为 1。 通过遗传算法优化开始训练。 第三阶段。训练负责多头头寸的感知器: 将“通过”输入设置为 3(使其与阶段编号匹配)。
( g* W# s# x& ]% o' R* ~8 ?去除上一阶段设置的优化标记。 ) I" W* N& u! [0 [2 q4 F
将上一阶段获得的输入保存到文件中以防万一。 为第三阶段参数设置优化标记(ID以三结尾): x13, x23, x33, x43 - 感知器识别多头头寸的权重比。使用从 0 到 200 的值进行优化,步长为 1。# @, A5 S! B0 L
tp3 - 由感知器打开的头寸获利。使用 100 到 1000 的值进行优化,步长为 10
C* g& a8 P' r4 Rsl3 - 感知器开仓的止损。使用从 100 到 1000 的值进行优化,步长为 10
; Z4 T$ n+ n* g+ X# i* {p3 - 感知器分析的价格差异值周期。使用从 3 到 100 的值进行优化,步长为 1。 通过遗传算法优化开始训练。 最后第四阶段。 训练第一层(上层感知器): 将“pass”输入设置为 4(使其与阶段编号匹配)。 " y) n" ?. ^- m1 h6 }( A1 @
去除上一阶段设置的优化标记。
: p" M, W/ f# L% h7 k' T& u7 M将上一阶段获得的输入保存到文件中以防万一。 为第四阶段参数设置优化标记(ID 以四结尾): x14, x24, x34, x44 - 第一层感知器的权重比。使用 0 到 200 的值进行优化,步长为 1。3 u. \( ]% q$ x! u! J( o% C" y
p4 - 感知器分析的价格差异值周期。使用从 3 到 100 的值进行优化,步长为 1。 通过遗传算法优化开始训练。 & [1 t7 z" [, G7 J1 | L( b
就这些。神经网络经过训练。 EA 具有另一个不可优化的“mn”输入 - 幻数允许系统在手动或其他 EA 打开的订单中区分自己的订单。幻数应该是唯一的。 附言 - 初始存款规模定义为绝对回撤乘以 2(安全边际)。
- EA 的源代码尚未优化
- 如果您想用另一个交易系统的算法替换内置的 BTS,请更改 basicTradingSystem() 函数的内容
- 如果前一周的结果无利可图,则在周末重新优化 EA。市场变化和需要重新优化的损失信号。如果 EA 盈利,则不需要重新优化,因为机器人可以很好地识别市场模式。
, u D$ I6 D. M) b* z& b
4 p9 I1 q Q9 R& H3 W0 _ |