在上一个教程中,我们讲解了如何开发一个AI StockRanker耍单票策略,今天我们在这个策略上做一个细节的调整:一字涨停取消卖出。本文的目的是做成一个教程示例,让大家了解如何在回测引擎里通过日期索引得到当天的因子值。
因为持仓里的票如果是一字涨停,那么继续拿住也说得过去,因此我们加入这样的一个逻辑。
在历史数据回测中,要实现这样的功能,需要提前拿到次日的数据,包括最高价、最低价、收盘涨跌停状态。这几个因子,我们在输入特征列表里抽取出来,因为是次日数据,所以我们使用m_lead算子来抽取:
![](/wiki/api/attachments.redirec
更新时间:2025-01-12 14:41
如何获取bigm模块中的内容
m1 = M.input_features_dai.v30(
input_1=m7.data,
mode="""表达式""",
expr="",
expr_filters="return",
expr_tables="""cn_stock_prefactors""",
extra_fields="""date, instrument""",
order_by="""date, instrument""",
expr_drop_na=True,
extract_d
更新时间:2025-01-06 01:57
# 在有序数组中找到出现最多的元素
def func() :
num = arr[0]
cnt = arr1
maxNum = arr[0]
maxCnt = 1
for i in arr[1:]:
if i == num :
cnt += 1
else:
if cnt > maxCnt:
maxCnt = cnt
maxNum = num
if cnt > maxCnt:
maxCnt = cnt
maxNum = num
更新时间:2024-12-26 15:11
我在平台进行了数据处理,需要保存到本地运行,如何保存到本地?
更新时间:2024-12-12 01:44
DataSource apply_bdb 修改无权限提示
def fillna_to_zero(df):
return df.fillna(0)
m3.data.apply_bdb(func=fillna_to_zero, as_type=pd.DataFrame)
:::warning
ArrowInvalid Traceback (most recent call last)
Cell In[4], line 3
更新时间:2024-12-10 01:38
导语
平台已经整理好新旧因子对比,可以在基础特征抽取里面直接抽取。
老版因子 | 新版因子 | 字段描述 |
---|---|---|
adjust_factor_* | 当期值: adjust_factor\n滞后值: m_lag(adjust_factor, i),i为滞后期数 | 第前 * 个交易日的复权因子 \n * 取值: 0 .. 20 |
amount_* | 当期值: amount\n滞后值: m_lag(amount, i),i为滞后期数 | 第前 * 个交易日的交易额\n * 取值: 0 .. 120 |
更新时间:2024-12-06 03:36
ORDER BY 报错 帮我看下哪里有问题
import dai
import pandas as pd
# 提取股票数据
stock_sql = """
WITH
zuori1 AS (
SELECT
cn_stock_bar1d.date,
cn_stock_bar1d.instrument,
close,
volume,
volume AS volume_1,
close AS close_1,
pe_ttm,
FRO
更新时间:2024-11-13 03:09
行业中性化
在复现行业中性化的代码报错
## 加载包
import dai
import pandas as pd
import numpy as np
import math
import warnings
from datetime import datetime, timedelta
from bigmodule import M
from bigtrader.finance.commission import PerOrder
niu_date= '2024-11-10'
today = datetime.now().date().strftime(
更新时间:2024-11-13 03:06
又出现一个single positional indexer is out-of-bounds
请帮忙处理:
https://bigquant.com/codesharev3/d5e911e4-51e9-4684-a6f5-25cb97efc1dc
\
更新时间:2024-10-28 01:52
代码报错-Conversion Error: Could not convert string 'Infinity' to INT64
您之前说了是数据里面有inf值,进行处理,替换成0或者nan再进行因子分析,具体怎样修改哪一行代码,我已经剔除了inf,还是不行,能给出具体的操作吗?
https://bigquant.com/codesharev3/3bd6dc8b-8b9e-4207-8d68-fa1d4ce0e162
\
更新时间:2024-10-28 01:42
以下涉及到的流数据暂未开放,后期我们会为大家提供流数据获取服务。
构造这个因子需要用到的数据的表格形式如下:
日期 | 买一量 | 卖一量 |
---|---|---|
t1 | b1 | a1 |
t2 | b2 | a2 |
… | … | … |
tn | bn | an |
首先我们求出截面净委买比例:
最后将分钟内的截面净委买比例求平均即可得到时间加权的净委买比例,所以这
更新时间:2024-10-22 07:09
本文以中证1000的股指期货(IM2503.CFE)与指数(000852.SH)价差为例, 我们来加工股指与期货的价差因子并进行实时可视化操作。以下涉及到的流数据暂未开放,后期我们会为大家提供流数据获取服务。
因子构造思路较为简单,我们需要用到期货l1快照数据以及指数快照数据,首先计算快照上的价差,最后将价差用last
函数聚合成分钟频的数据。
首先导入第三方库,并将数据推送至中间表:
import dai
import time
import plotly.graph_objects as go
from IPython
更新时间:2024-10-22 07:08
这个策略之前模拟正常,现在突然报错:no data left after dropnan
1、截图模拟交易报错的页面,配文:报错内容:[0;31mException[0m: no data left after dropnan
2、粘贴策略链接:https://bigquant.com/codesharev3/9be3987e-8535-4b59-860c-18ccd7b6f917
谢谢支持的老师。
更新时间:2024-10-12 09:05
1、bigtrade的模式和聚宽很大的一个区别就是,策略要用的数据你们是先全部提取好了作为直接输入到回测引擎,这样就可以减少回测引擎每回测一天跑一天数据的麻烦,且再次回测也会有缓存,加快回测效率。我想问的是,我在取数据的时候是取整个回测时间段的,模拟的时候取数是当前的,这两个取数代码的写法肯定不同,不像聚宽,永远取回测日当前时间数据就行,而且我策略要用到的因子数据是需要比较复杂的加工的,有sql,有python,那我提交模拟之后,模拟交易怎么能识别我计算因子的逻辑,然后计算当天的因子值
2.我write_bdb的表是永久有效的么?这个表的存储空间需要付费么?
更新时间:2024-10-10 10:24
1、如果我的因子在sql之外还需要用Python做一些处理,请问提交因子的时候factor_sql 该怎么写?
2、因子分析中是否每个股票每个交易日都要有因子值,我是否可以每个股票只有月末有一个因子,其他时间都是空的。
更新时间:2024-10-10 10:10
老师,请问模块抽取出来的数据是一个大表格,如何才能将下面图示中的M4表格另外下载出来?谢谢
更新时间:2024-10-10 10:03
老师,请问DAI查询出来的数据表太大,如何单独形成一个XLS表格,方便自己进行分析,谢谢
import dai
df = dai.query("""
SELECT
date, instrument,
IF(price_limit_status = 3,1,0) AS _zt,
If(m_sum(_zt,10) = 1,1,0) AS _firstzt,
open/m_lead(close,-1)-1 AS _jump,
If(_jump > 0.04,1,0) AS _jumphigh,
close/ope
更新时间:2024-10-10 09:49
代码如下
import dai
st = ''
sql = f"""
select
date,
instrument,
sw2021_level2,
sw2021_level2_name,
r_ind,
r_mkt,
m_product(r_ind + 1,240)- 1 as r_ind_1y,
m_product(r_mkt + 1,240)- 1 as r_mkt_1y,
r_ind - r_mkt as r_std,
(r_ind_1y - r_m
更新时间:2024-10-09 10:16
行情数据NaN空值处理的bug问题
回测时发现仓位中有些早期时间段(大多2012年前)仓位很轻,按理持仓就为10支,可那些日子里只有1,2支. 后面发现,:\n 因为我代码中有: m_max(close,100). 只要这100前有一个NAN值,这支股票就被无情的排除了.
要是:m_max( close,100, 参数=’ 0’ ).这里加个参数,表示数据中有NAN时填充0计算. 也可以=”停牌前的价格”\n要是能有这选择参数就完美了.
\
更新时间:2024-10-09 09:47
股息率是指公司每年支付的股息与其股票当前市场价格的比率。它是一个重要的投资指标,帮助投资者评估股票的收入潜力,股息率越高,通常表示投资者可以从该股票中获得更多的被动收入。计算公式为:
本文更多介绍如何使用 ASOF JOIN 操作处理日频数据和非日频数据,因此,我们简化股息率的公式,假设分子分母都使用总股本,则上述公式可以简化如下:
![](/wiki/api/attachments.redirect?id=4
更新时间:2024-09-02 08:33
https://bigquant.com/codesharev3/0fcad747-50d5-47b1-81ea-c6d9127ccae5
为何在加入了2个特征表达式,什么值都去不到。谢谢各位
更新时间:2024-07-24 02:18
positions = context.get_account_positions()
for code, position in positions.items():
print(code,position.last_sale_date, context.trading_calendar.session_distance(position.last_sale_date, data.current_dt))
\
更新时间:2024-06-29 00:03
将净利润增长率,净资产收益率,市盈率作为作为输入特征;
将净利润增长率长大于15%,连续3年净资产收益率大于15%,市盈率低于35设置为表达式过滤条件。
\
\
m5
”BigTra更新时间:2024-06-19 06:45
两个“输入特征(DAI SQL)”模块,分别从两个数据表提取数据,之后可以共同连接一个新的“输入特征(DAI SQL)”模块,做到数据连接的功能
我们来看一个具体的例子,在下面这个例子中:
cn_stock_prefactors
表中提取出pe_ttm
和total_market_cap
两个字段,并且过滤掉ST股票cn_stock_money_flow
表中提取出main_flow
和main_rate
两个字段![](/wiki/api/attachments.redirect?id=2d891157-85
更新时间:2024-06-19 02:45
更新时间:2024-06-19 02:41