Rss & SiteMap

金字塔客服中心 - 专业程序化交易软件提供商 http://www.weistock.com/bbs/

专业程序化软件提供商
共6 条记录, 每页显示 10 条, 页签: [1]
[浏览完整版]

标题:信号怎么不一致呀

1楼
qq代人发帖 发表于:2016/6/14 10:23:10

Sub ema5()
Testreport.StartAndInit '开始测评系统的准备工作
Testreport.InitCash=100*10000 '初始资金100万

Set Formula = marketdata.STKINDI("if00","zj","ema5()",0,5) '调用中金所IF00合约的日线自定义指标
Set HistroyData = Formula.ParentGrid.GetHistoryData '直接得到公式区的数据对象,提高运行效率

If TestReport.AddTestStock(HistroyData,"if00","zj",0) < 1 Then '向测试报告系统添加一个新测试品种
    MsgBox "请正确添加品种"
End if

'下面的代码控制循环测试
'使用PEL策略的信号进行交易
For i = 0 to HistroyData.Count-1
    if Formula.GetBufData("开多",i) = 1 And TestReport.Holding = 0 Then '开多
        TestReport.Buy 1, HistroyData.Close(i)
    End if
 if Formula.GetBufData("开空",i) = 1 And TestReport.Holding = 0 Then '开空
        TestReport.Sell 1, HistroyData.Close(i)
    End if
    if Formula.GetBufData("平多",i) = 1 And TestReport.Holding > 0 Then '平多
        TestReport.Sell 0, HistroyData.Close(i)
    End if
 if Formula.GetBufData("平空",i) = 1 And TestReport.Holding > 0 Then '平空
        TestReport.Sell 0, HistroyData.Close(i)
    End if

'显示测试时当前的资产
Application.msgout TestReport.ASSET

'为步进下一个数据做准备
TestReport.StepIt i
Next

'测试完毕显示测试报告
Testreport.ShowReport

End Sub


图片点击可在新窗口打开查看此主题相关图片如下:h1q1{_il$8f_~y%5yx6)f~q.png
图片点击可在新窗口打开查看

图片点击可在新窗口打开查看此主题相关图片如下:ls43@@{p{4jiea)_`u)2`jj.png
图片点击可在新窗口打开查看
2楼
王锋 发表于:2016/6/14 10:48:40
学会一些基本的条件技巧,常见问题检查除权是否一致,参数是否一致,测试时段是否一致
3楼
zhou 发表于:2016/6/14 11:04:43
这个参数就固定了,没改过,肯定一致,股指主连怎么会有除权问题?你以为是股票,时段也一致
4楼
王锋 发表于:2016/6/14 11:14:11

关于期货的除权概念,请参考 http://www.weistock.com/bbs/dispbbs.asp?boardid=16&Id=88505 问题43

5楼
zhou 发表于:2016/6/14 11:23:08
For i = 0 to HistroyData.Count-1 
    if Formula.GetBufData("开多",i) = 1 And TestReport.Holding = 0 Then '开多 
        TestReport.Buy 1, HistroyData.Close(i) 
    End if
 if Formula.GetBufData("开空",i) = 1 And TestReport.Holding = 0 Then '开空 
        TestReport.Sell 1, HistroyData.Close(i) 
    End if
    if Formula.GetBufData("平多",i) = 1 And TestReport.Holding > 0 Then '平多
        TestReport.Sell 0, HistroyData.Close(i)
    End if
 if Formula.GetBufData("平空",i) = 1 And TestReport.Holding > 0 Then '平空
        TestReport.Sell 0, HistroyData.Close(i)
    End if
那这段代码没问题吧
6楼
王锋 发表于:2016/6/14 12:12:27

 if Formula.GetBufData("平空",i) = 1 And TestReport.Holding < 0 Then '平空

 

空头仓时仓位是负值

共6 条记录, 每页显示 10 条, 页签: [1]


Powered By Dvbbs Version 8.3.0
Processed in 0.02148 s, 2 queries.