- 主题:我的python股票回测引擎用numba重写了,速度提高百倍
计算指标可用numpy,但是用numba写策略更灵活,很多策略不好向量化
【 在 yatobiaf 的大作中提到: 】
:
: 厉害了楼主,正好最近打算写个python股票回测模块,看到楼主的帖子打算试试numba。
: 请问numba为啥会比python快那么多?
: 股票回测大部分底层是矩阵乘法,python的numpy模块做了很多的优化,我感觉速度和c也差不多,楼主之前的python股票回测引擎是用了
: ..................
发自「今日水木 on iPhone 12」
--
FROM 223.72.44.*
numba调用llmv,实现jit
【 在 yatobiaf 的大作中提到: 】
:
: 厉害了楼主,正好最近打算写个python股票回测模块,看到楼主的帖子打算试试numba。
: 请问numba为啥会比python快那么多?
: 股票回测大部分底层是矩阵乘法,python的numpy模块做了很多的优化,我感觉速度和c也差不多,楼主之前的python股票回测引擎是用了
: ..................
发自「今日水木 on iPhone 12」
--
FROM 223.72.44.*
网上可以找到腾讯得接口
【 在 NiuBei 的大作中提到: 】
: 老哥,回测数据哪里来的
发自「快看水母 于 iPhone 14 Plus」
--
FROM 223.104.150.*
高兴的太早了, 发现在jit函数内部,调用原来的numpy数组运算,结果跟不用jit不一样!!!
在jit函数中,numpy有的计算会出错
这是一个计算移动平均的函数
@njit
def ma(a:float64[:], n:int32)->float64[:] :
r=np.cumsum(a)
r[n:] -= r[0:-n].copy() #这里如果不调用copy(),两边的内存重叠,计算就会出错。不用numba没问题
r[n:] /= n
r[0:n] /= np.arange(1,n+1)
return r
但是本来就是numpy向量计算,jit加速不多,又多了一次copy,这种情况可能还不如不用jit
或者为下一步计算单独分配内存,这样也增加了开销,也不合算。
另一个办法是完全不用numpy计算,直接循环。 这样最能体现numba的优势。
【 在 finlab 的大作中提到: 】
: numba真是神器。
: 以前回测功能在dotnet平台实现,现在可以都放在python啦
--
FROM 223.72.44.*
他们的数据也是不知道哪里抓来的,他们小成本运行,也不可能花太多人力检查数据
为了省钱,只能凑合着用了。
wind的数据质量好,但是太贵了。
【 在 beanpole 的大作中提到: 】
: 两年前不用tushare了
: 它家数据有问题,我提一次,他qq说检查一下,然后告诉我改好了,让我重新读取
: 我问出错原因找到了,是啥,拒不回答,就说改好了
: ...................
--
FROM 223.72.44.*
都用numpy,自己不做循环,只能做一些粗略的统计。
要想比较精细的控制策略,只能用循环。这时候python性能就很低了,就需要numba加速。
我更习惯用下面这种写策略的方式。如果有交易接口,可以方便的直接拿去做程序化交易。
# 单均线策略
@njit
def sma(acc:Account, q:Quote, args):
n=args[0]
c=q.close
o=q.open
ma= fm.ma(c,n)
for i in range(n,len(c)):
if fm.cross_up(c,ma,i-1): # 上日收盘价上穿均线,
acc.buy(i,o[i]) # 则在当日以开盘价买入
elif acc.total_count()>0 and fm.cross_down(c,ma,i-1):
acc.sell(i,o[i])
【 在 yatobiaf 的大作中提到: 】
: 厉害了楼主,正好最近打算写个python股票回测模块,看到楼主的帖子打算试试numba。
: 请问numba为啥会比python快那么多?
: 股票回测大部分底层是矩阵乘法,python的numpy模块做了很多的优化,我感觉速度和c也差不多,楼主之前的python股票回测引擎是用了矩阵乘法吗?
: ...................
--
FROM 223.72.44.*
如果只是分钟线日线,自己解析通达信本地数据就好了,快太多太多了
【 在 finlab 的大作中提到: 】
: 他们的数据也是不知道哪里抓来的,他们小成本运行,也不可能花太多人力检查数据
: 为了省钱,只能凑合着用了。
: wind的数据质量好,但是太贵了。
: ...................
--
FROM 223.160.233.*
很早以前抓过tdx本地数据, 好久没用了,不知道格式是不是有变化?
【 在 beanpole 的大作中提到: 】
: 如果只是分钟线日线,自己解析通达信本地数据就好了,快太多太多了
:
--
FROM 223.72.44.*
确实是,python的优势是不写循环,如果写循环那确实差点意思。
不过你这策略,不能叫股票策略,只能叫CTA策略,只针对单只股票的时序做判断的。对于这类策略,速度压根不会是瓶颈。如果是批量买入一大篮子股票,那速度要求才高,才用的上矩阵乘法,那才是是python的优势。
【 在 finlab 的大作中提到: 】
: 都用numpy,自己不做循环,只能做一些粗略的统计。
: 要想比较精细的控制策略,只能用循环。这时候python性能就很低了,就需要numba加速。
: 我更习惯用下面这种写策略的方式。如果有交易接口,可以方便的直接拿去做程序化交易。
: ...................
--
FROM 111.207.148.*
单个股票时间是不多,但是全市场5000多只股票呢
一般回测一个策略,都要在一个相对大的股票集上测试,比如沪深300, 不排除全市场
策略开发中,也需要不断修改策略、调整参数,反复测试。
所以回测速度是很重要的。
【 在 yatobiaf 的大作中提到: 】
: 确实是,python的优势是不写循环,如果写循环那确实差点意思。
: 不过你这策略,不能叫股票策略,只能叫CTA策略,只针对单只股票的时序做判断的。对于这类策略,速度压根不会是瓶颈。如果是批量买入一大篮子股票,那速度要求才高,才用的上矩阵乘法,那才是是python的优势。
:
--
FROM 223.72.44.*