{"description":"实验创建于2017/8/26","graph":{"edges":[{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-15:instruments","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-8:data"},{"to_node_id":"-215:instruments","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-8:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53:data1","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-15:data"},{"to_node_id":"-647:features_ds","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-24:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60:model","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43:model"},{"to_node_id":"-464:input_1","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53:data"},{"to_node_id":"-209:data1","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60:predictions"},{"to_node_id":"-231:instruments","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62:data"},{"to_node_id":"-172:input_1","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62:data"},{"to_node_id":"-9185:instruments","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43:training_ds","from_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-84:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60:data","from_node_id":"-86:data"},{"to_node_id":"-222:input_data","from_node_id":"-215:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53:data2","from_node_id":"-222:data"},{"to_node_id":"-238:input_data","from_node_id":"-231:data"},{"to_node_id":"-8668:input_1","from_node_id":"-238:data"},{"to_node_id":"-215:features","from_node_id":"-647:data"},{"to_node_id":"-222:features","from_node_id":"-647:data"},{"to_node_id":"-231:features","from_node_id":"-647:data"},{"to_node_id":"-238:features","from_node_id":"-647:data"},{"to_node_id":"-592:input_data","from_node_id":"-464:data_1"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-84:input_data","from_node_id":"-592:data"},{"to_node_id":"-8672:input_data","from_node_id":"-8668:data_1"},{"to_node_id":"-86:input_data","from_node_id":"-8672:data"},{"to_node_id":"-9185:options_data","from_node_id":"-216:sorted_data"},{"to_node_id":"-216:input_ds","from_node_id":"-209:data"},{"to_node_id":"-209:data2","from_node_id":"-172:data_1"},{"to_node_id":"-172:input_2","from_node_id":"-170:data"},{"to_node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43:features","from_node_id":"-191:data"}],"nodes":[{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-8","module_id":"BigQuantSpace.instruments.instruments-v2","parameters":[{"name":"start_date","value":"2008-10-20","type":"Literal","bound_global_parameter":null},{"name":"end_date","value":"2021-03-15","type":"Literal","bound_global_parameter":null},{"name":"market","value":"CN_STOCK_A","type":"Literal","bound_global_parameter":null},{"name":"instrument_list","value":"","type":"Literal","bound_global_parameter":null},{"name":"max_count","value":"0","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"rolling_conf","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-8"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-8"}],"cacheable":true,"seq_num":1,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-15","module_id":"BigQuantSpace.advanced_auto_labeler.advanced_auto_labeler-v2","parameters":[{"name":"label_expr","value":"# 计算收益:2日收盘价(作为卖出价格)除以明日开盘价(作为买入价格)\nshift(close, -2) / shift(open, -1)-1\n\n# 极值处理:用1%和99%分位的值做clip\nclip(label, all_quantile(label, 0.01), all_quantile(label, 0.99))\n\n# 将分数映射到分类,这里使用30个分类\nall_wbins(label, 30)","type":"Literal","bound_global_parameter":null},{"name":"start_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"end_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"benchmark","value":"000300.HIX","type":"Literal","bound_global_parameter":null},{"name":"drop_na_label","value":"True","type":"Literal","bound_global_parameter":null},{"name":"cast_label_int","value":"True","type":"Literal","bound_global_parameter":null},{"name":"user_functions","value":"","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"instruments","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-15"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-15"}],"cacheable":true,"seq_num":2,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-24","module_id":"BigQuantSpace.input_features.input_features-v1","parameters":[{"name":"features","value":"std(turn_0,10)\navg_turn_5\nrank_swing_volatility_60_0\nfe1=sum(max(0,high_0-delay((high_0+low_0+close_0)/3,1)),26)/sum(max(0,delay((high_0+low_0+close_0)/3,1)-1),26)*100\nmean(turn_0*(return_0-1),30)\nstd(return_0-1,60)\nstd(return_0-1,15)\nfe2=((close_0-sum(min(low_0,delay(close_0,1)),6))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),6)*12*24+(close_0-sum(min(low_0,delay(close_0,1)),12))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),12)*6*24+(close_0-sum(min(low_0,delay(close_0,1)),24))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),24)*6*24)*100/(6*12+6*24+12*24)\n#---- 全选小市值的股票?","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"features_ds","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-24"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-24"}],"cacheable":true,"seq_num":3,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43","module_id":"BigQuantSpace.stock_ranker_train.stock_ranker_train-v5","parameters":[{"name":"learning_algorithm","value":"排序","type":"Literal","bound_global_parameter":null},{"name":"number_of_leaves","value":"40","type":"Literal","bound_global_parameter":null},{"name":"minimum_docs_per_leaf","value":"250","type":"Literal","bound_global_parameter":null},{"name":"number_of_trees","value":"80","type":"Literal","bound_global_parameter":null},{"name":"learning_rate","value":0.1,"type":"Literal","bound_global_parameter":null},{"name":"max_bins","value":1023,"type":"Literal","bound_global_parameter":null},{"name":"feature_fraction","value":1,"type":"Literal","bound_global_parameter":null},{"name":"m_lazy_run","value":"False","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"training_ds","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"},{"name":"features","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"},{"name":"test_ds","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"},{"name":"base_model","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"}],"output_ports":[{"name":"model","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"},{"name":"feature_gains","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"},{"name":"m_lazy_run","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-43"}],"cacheable":true,"seq_num":6,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53","module_id":"BigQuantSpace.join.join-v3","parameters":[{"name":"on","value":"date,instrument","type":"Literal","bound_global_parameter":null},{"name":"how","value":"inner","type":"Literal","bound_global_parameter":null},{"name":"sort","value":"False","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"data1","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53"},{"name":"data2","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-53"}],"cacheable":true,"seq_num":7,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60","module_id":"BigQuantSpace.stock_ranker_predict.stock_ranker_predict-v5","parameters":[{"name":"m_lazy_run","value":"False","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"model","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60"},{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60"}],"output_ports":[{"name":"predictions","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60"},{"name":"m_lazy_run","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-60"}],"cacheable":true,"seq_num":8,"comment":"","comment_collapsed":true},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62","module_id":"BigQuantSpace.instruments.instruments-v2","parameters":[{"name":"start_date","value":"2021-01-15","type":"Literal","bound_global_parameter":"交易日期"},{"name":"end_date","value":"2022-10-20","type":"Literal","bound_global_parameter":"交易日期"},{"name":"market","value":"CN_STOCK_A","type":"Literal","bound_global_parameter":null},{"name":"instrument_list","value":"","type":"Literal","bound_global_parameter":null},{"name":"max_count","value":"0","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"rolling_conf","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-62"}],"cacheable":true,"seq_num":9,"comment":"预测数据,用于回测和模拟","comment_collapsed":false},{"node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-84","module_id":"BigQuantSpace.dropnan.dropnan-v1","parameters":[],"input_ports":[{"name":"input_data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-84"}],"output_ports":[{"name":"data","node_id":"287d2cb0-f53c-4101-bdf8-104b137c8601-84"}],"cacheable":true,"seq_num":13,"comment":"","comment_collapsed":true},{"node_id":"-86","module_id":"BigQuantSpace.dropnan.dropnan-v1","parameters":[],"input_ports":[{"name":"input_data","node_id":"-86"}],"output_ports":[{"name":"data","node_id":"-86"}],"cacheable":true,"seq_num":14,"comment":"","comment_collapsed":true},{"node_id":"-215","module_id":"BigQuantSpace.general_feature_extractor.general_feature_extractor-v7","parameters":[{"name":"start_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"end_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"before_start_days","value":"120","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"instruments","node_id":"-215"},{"name":"features","node_id":"-215"}],"output_ports":[{"name":"data","node_id":"-215"}],"cacheable":true,"seq_num":15,"comment":"","comment_collapsed":true},{"node_id":"-222","module_id":"BigQuantSpace.derived_feature_extractor.derived_feature_extractor-v3","parameters":[{"name":"date_col","value":"date","type":"Literal","bound_global_parameter":null},{"name":"instrument_col","value":"instrument","type":"Literal","bound_global_parameter":null},{"name":"drop_na","value":"True","type":"Literal","bound_global_parameter":null},{"name":"remove_extra_columns","value":"False","type":"Literal","bound_global_parameter":null},{"name":"user_functions","value":"","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_data","node_id":"-222"},{"name":"features","node_id":"-222"}],"output_ports":[{"name":"data","node_id":"-222"}],"cacheable":true,"seq_num":16,"comment":"","comment_collapsed":true},{"node_id":"-231","module_id":"BigQuantSpace.general_feature_extractor.general_feature_extractor-v7","parameters":[{"name":"start_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"end_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"before_start_days","value":"120","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"instruments","node_id":"-231"},{"name":"features","node_id":"-231"}],"output_ports":[{"name":"data","node_id":"-231"}],"cacheable":true,"seq_num":17,"comment":"","comment_collapsed":true},{"node_id":"-238","module_id":"BigQuantSpace.derived_feature_extractor.derived_feature_extractor-v3","parameters":[{"name":"date_col","value":"date","type":"Literal","bound_global_parameter":null},{"name":"instrument_col","value":"instrument","type":"Literal","bound_global_parameter":null},{"name":"drop_na","value":"False","type":"Literal","bound_global_parameter":null},{"name":"remove_extra_columns","value":"False","type":"Literal","bound_global_parameter":null},{"name":"user_functions","value":"","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_data","node_id":"-238"},{"name":"features","node_id":"-238"}],"output_ports":[{"name":"data","node_id":"-238"}],"cacheable":true,"seq_num":18,"comment":"","comment_collapsed":true},{"node_id":"-647","module_id":"BigQuantSpace.input_features.input_features-v1","parameters":[{"name":"features","value":"cond28=sum(price_limit_status_0==3,30)>1","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"features_ds","node_id":"-647"}],"output_ports":[{"name":"data","node_id":"-647"}],"cacheable":true,"seq_num":4,"comment":"这里放置要过滤的条件","comment_collapsed":true},{"node_id":"-464","module_id":"BigQuantSpace.filtet_st_stock.filtet_st_stock-v7","parameters":[],"input_ports":[{"name":"input_1","node_id":"-464"}],"output_ports":[{"name":"data_1","node_id":"-464"}],"cacheable":true,"seq_num":5,"comment":"","comment_collapsed":true},{"node_id":"-592","module_id":"BigQuantSpace.filter.filter-v3","parameters":[{"name":"expr","value":"cond28","type":"Literal","bound_global_parameter":null},{"name":"output_left_data","value":"True","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_data","node_id":"-592"}],"output_ports":[{"name":"data","node_id":"-592"},{"name":"left_data","node_id":"-592"}],"cacheable":true,"seq_num":10,"comment":"","comment_collapsed":true},{"node_id":"-8668","module_id":"BigQuantSpace.filtet_st_stock.filtet_st_stock-v7","parameters":[],"input_ports":[{"name":"input_1","node_id":"-8668"}],"output_ports":[{"name":"data_1","node_id":"-8668"}],"cacheable":true,"seq_num":11,"comment":"","comment_collapsed":true},{"node_id":"-8672","module_id":"BigQuantSpace.filter.filter-v3","parameters":[{"name":"expr","value":"cond28","type":"Literal","bound_global_parameter":null},{"name":"output_left_data","value":"True","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_data","node_id":"-8672"}],"output_ports":[{"name":"data","node_id":"-8672"},{"name":"left_data","node_id":"-8672"}],"cacheable":true,"seq_num":12,"comment":"","comment_collapsed":true},{"node_id":"-9185","module_id":"BigQuantSpace.trade.trade-v4","parameters":[{"name":"start_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"end_date","value":"","type":"Literal","bound_global_parameter":null},{"name":"initialize","value":"# 回测引擎:初始化函数,只执行一次\ndef bigquant_run(context):\n # 加载预测数据\n context.ranker_prediction = context.options['data'].read_df()\n\n # 系统已经设置了默认的交易手续费和滑点,要修改手续费可使用如下函数\n context.set_commission(PerOrder(buy_cost=0.0003, sell_cost=0.0013, min_cost=5))\n # 预测数据,通过options传入进来,使用 read_df 函数,加载到内存 (DataFrame)\n # 设置买入的股票数量,这里买入预测股票列表排名靠前的5只\n stock_count = 1\n # 每只的股票的权重,如下的权重分配会使得靠前的股票分配多一点的资金,[0.339160, 0.213986, 0.169580, ..]\n context.stock_weights = [1]\n # 设置每只股票占用的最大资金比例\n context.max_cash_per_instrument = 1\n context.options['hold_days'] = 1\n","type":"Literal","bound_global_parameter":null},{"name":"handle_data","value":"# 回测引擎:每日数据处理函数,每天执行一次\ndef bigquant_run(context, data):\n # 获取当前持仓\n positions = {e.symbol: p.amount * p.last_sale_price\n for e, p in context.portfolio.positions.items()}\n \n today = data.current_dt.strftime('%Y-%m-%d')\n # 按日期过滤得到今日的预测数据\n ranker_prediction = context.ranker_prediction[\n context.ranker_prediction.date == today]\n try:\n #大盘风控模块,读取风控数据 \n benckmark_risk=ranker_prediction['bm_0'].values[0]\n if benckmark_risk > 0:\n for instrument in positions.keys():\n context.order_target(context.symbol(instrument), 0)\n print(today,'大盘风控止损触发,全仓卖出')\n return\n except:\n print('--!')\n \n #当risk为1时,市场有风险,全部平仓,不再执行其它操作 \n # 按日期过滤得到今日的预测数据\n ranker_prediction = context.ranker_prediction[\n context.ranker_prediction.date == data.current_dt.strftime('%Y-%m-%d')]\n\n # 通过positions对象,使用列表生成式的方法获取目前持仓的股票列表\n \n #------------------------获取 持仓信息 环节--------------------------\n # 先定义 我们要用来买卖股票的资金\n cash_for_buy = context.portfolio.cash\n #获取 我们模型今天预测的股票池\n buy_instruments = list(ranker_prediction.instrument)\n #找到我们当前的股票持仓\n current_hold_stock = [equity.symbol for equity in context.portfolio.positions ]\n #定义 一个 列表 用来储存我们今天要卖出的股票\n sell_instruments = [instrument.symbol for instrument in context.portfolio.positions.keys()]\n \n \n\n #----逻辑上 先卖 后买,防止资金不足---产生空单\n # 今天需要卖出的股票 存在于我们 当前的股票持仓中 \n totay_to_sell = [i for i in sell_instruments[:1] ]#这里 因为我们只有1只股票 所以可以直接卖掉 \n \n #使用一个for循环 将持仓的股票全部卖出\n for instrument in totay_to_sell:\n context.order_target(context.symbol(instrument), 0)\n # 今天需要买入的股票 存在于我们 模型当天预测的股票池 buy_instruments 中 \n \n \n totay_to_buy = [i for i in buy_instruments[:1] ]#这里 我们只买 排名最靠前的第一名 \n # 如果想买入多只股票怎么操作呢?------\n #totay_to_sell = [i for i in sell_instruments[:N] ] N=你想要买入的股票数量,比如我想买2只 我就把N改成2\n #使用一个for循环 将预测的股票前 N名 买入\n #为了方便统计,我们直接用所有的钱下单,all in 当天买入的股票\n for instrument in totay_to_buy:\n\n context.order_value(context.symbol(instrument),cash_for_buy)\n \n \n","type":"Literal","bound_global_parameter":null},{"name":"prepare","value":"def bigquant_run(context):\n\n\n # 获取st状态和涨跌停状态\n \n context.status_df = D.features(instruments =context.instruments,start_date = context.start_date, end_date = context.end_date, \n fields=['st_status_0','price_limit_status_0','price_limit_status_1'])\n","type":"Literal","bound_global_parameter":null},{"name":"before_trading_start","value":"def bigquant_run(context, data):\n pass \n# # 获取涨跌停状态数据\n# df_price_limit_status=context.status_df.set_index('date')\n# today=data.current_dt.strftime('%Y-%m-%d')\n# # 得到当前未完成订单\n# for orders in get_open_orders().values():\n# # 循环,撤销订单\n# for _order in orders:\n# ins=str(_order.sid.symbol)\n# try:\n# #判断一下如果当日涨停,则取消卖单\n# if df_price_limit_status[df_price_limit_status.instrument==ins].price_limit_status_0.loc[today]>2 and _order.amount<0:\n# cancel_order(_order)\n# print(today,'尾盘涨停取消卖单',ins) \n# except:\n# continue\n \n \n ","type":"Literal","bound_global_parameter":null},{"name":"volume_limit","value":"0","type":"Literal","bound_global_parameter":null},{"name":"order_price_field_buy","value":"open","type":"Literal","bound_global_parameter":null},{"name":"order_price_field_sell","value":"close","type":"Literal","bound_global_parameter":null},{"name":"capital_base","value":"100000","type":"Literal","bound_global_parameter":null},{"name":"auto_cancel_non_tradable_orders","value":"True","type":"Literal","bound_global_parameter":null},{"name":"data_frequency","value":"daily","type":"Literal","bound_global_parameter":null},{"name":"price_type","value":"真实价格","type":"Literal","bound_global_parameter":null},{"name":"product_type","value":"股票","type":"Literal","bound_global_parameter":null},{"name":"plot_charts","value":"True","type":"Literal","bound_global_parameter":null},{"name":"backtest_only","value":"False","type":"Literal","bound_global_parameter":null},{"name":"benchmark","value":"000300.SHA","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"instruments","node_id":"-9185"},{"name":"options_data","node_id":"-9185"},{"name":"history_ds","node_id":"-9185"},{"name":"benchmark_ds","node_id":"-9185"},{"name":"trading_calendar","node_id":"-9185"}],"output_ports":[{"name":"raw_perf","node_id":"-9185"}],"cacheable":false,"seq_num":20,"comment":"","comment_collapsed":true},{"node_id":"-216","module_id":"BigQuantSpace.sort.sort-v4","parameters":[{"name":"sort_by","value":"date","type":"Literal","bound_global_parameter":null},{"name":"group_by","value":"--","type":"Literal","bound_global_parameter":null},{"name":"keep_columns","value":"--","type":"Literal","bound_global_parameter":null},{"name":"ascending","value":"True","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_ds","node_id":"-216"},{"name":"sort_by_ds","node_id":"-216"}],"output_ports":[{"name":"sorted_data","node_id":"-216"}],"cacheable":true,"seq_num":21,"comment":"","comment_collapsed":true},{"node_id":"-209","module_id":"BigQuantSpace.join.join-v3","parameters":[{"name":"on","value":"date","type":"Literal","bound_global_parameter":null},{"name":"how","value":"left","type":"Literal","bound_global_parameter":null},{"name":"sort","value":"False","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"data1","node_id":"-209"},{"name":"data2","node_id":"-209"}],"output_ports":[{"name":"data","node_id":"-209"}],"cacheable":true,"seq_num":22,"comment":"","comment_collapsed":true},{"node_id":"-172","module_id":"BigQuantSpace.index_feature_extract.index_feature_extract-v3","parameters":[{"name":"before_days","value":"100","type":"Literal","bound_global_parameter":null},{"name":"index","value":"000044.HIX","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"input_1","node_id":"-172"},{"name":"input_2","node_id":"-172"}],"output_ports":[{"name":"data_1","node_id":"-172"},{"name":"data_2","node_id":"-172"}],"cacheable":true,"seq_num":23,"comment":"","comment_collapsed":true},{"node_id":"-170","module_id":"BigQuantSpace.input_features.input_features-v1","parameters":[{"name":"features","value":"# #号开始的表示注释\n# 多个特征,每行一个,可以包含基础特征和衍生特征\nbm_0=where(ta_macd_dif(close,2,4,4)-ta_macd_dea(close,2,4,4)<0,1,0)\n#bm_0=where((ta_macd_dif(close,2,4,4)-ta_macd_dea(close,2,4,4))/shift(ta_macd_dif(close,2,4,4)-ta_macd_dea(close,2,4,4),1)<0,1,0)","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"features_ds","node_id":"-170"}],"output_ports":[{"name":"data","node_id":"-170"}],"cacheable":true,"seq_num":24,"comment":"","comment_collapsed":true},{"node_id":"-191","module_id":"BigQuantSpace.input_features.input_features-v1","parameters":[{"name":"features","value":"std(turn_0,10)\navg_turn_5\nrank_swing_volatility_60_0\nfe1\nmean(turn_0*(return_0-1),30)\nstd(return_0-1,60)\nstd(return_0-1,15)\nfe2","type":"Literal","bound_global_parameter":null}],"input_ports":[{"name":"features_ds","node_id":"-191"}],"output_ports":[{"name":"data","node_id":"-191"}],"cacheable":true,"seq_num":27,"comment":"","comment_collapsed":true}],"node_layout":"<node_postions><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-8' Position='201.42050170898438,4.905195236206055,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-15' Position='16.515289306640625,278.5504608154297,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-24' Position='799,-108,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-43' Position='507,841,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-53' Position='116.77523803710938,468.4556579589844,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-60' Position='923.8731689453125,923.6773681640625,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-62' Position='1527,21,200,200'/><node_position Node='287d2cb0-f53c-4101-bdf8-104b137c8601-84' Position='135.0321044921875,739.133056640625,200,200'/><node_position Node='-86' Position='1331,556,200,200'/><node_position Node='-215' Position='320.5794982910156,179.51683044433594,200,200'/><node_position Node='-222' Position='324.5137634277344,287.12994384765625,200,200'/><node_position Node='-231' Position='1078,236,200,200'/><node_position Node='-238' Position='1081,327,200,200'/><node_position Node='-647' Position='789,-7,200,200'/><node_position Node='-464' Position='111.16207885742188,553.8103942871094,200,200'/><node_position Node='-592' Position='125.9036865234375,648.4235534667969,200,200'/><node_position Node='-8668' Position='1345,420,200,200'/><node_position Node='-8672' Position='1347,482,200,200'/><node_position Node='-9185' Position='846.4510498046875,1334.446533203125,200,200'/><node_position Node='-216' Position='1192.585693359375,1243.29052734375,200,200'/><node_position Node='-209' Position='1201.0030517578125,1144.2261962890625,200,200'/><node_position Node='-172' Position='1192.6788330078125,1027.3883666992188,200,200'/><node_position Node='-170' Position='1232.573486328125,919.9739990234375,200,200'/><node_position Node='-191' Position='636.3532104492188,550.2890014648438,200,200'/></node_postions>"},"nodes_readonly":false,"studio_version":"v2"}
[2022-10-28 11:41:51.196569] INFO: moduleinvoker: instruments.v2 开始运行..
[2022-10-28 11:41:51.205182] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.209657] INFO: moduleinvoker: instruments.v2 运行完成[0.013126s].
[2022-10-28 11:41:51.225228] INFO: moduleinvoker: advanced_auto_labeler.v2 开始运行..
[2022-10-28 11:41:51.234859] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.238252] INFO: moduleinvoker: advanced_auto_labeler.v2 运行完成[0.013011s].
[2022-10-28 11:41:51.244500] INFO: moduleinvoker: input_features.v1 开始运行..
[2022-10-28 11:41:51.252126] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.254434] INFO: moduleinvoker: input_features.v1 运行完成[0.009939s].
[2022-10-28 11:41:51.261020] INFO: moduleinvoker: input_features.v1 开始运行..
[2022-10-28 11:41:51.269128] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.272423] INFO: moduleinvoker: input_features.v1 运行完成[0.011409s].
[2022-10-28 11:41:51.317436] INFO: moduleinvoker: general_feature_extractor.v7 开始运行..
[2022-10-28 11:41:51.325771] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.328121] INFO: moduleinvoker: general_feature_extractor.v7 运行完成[0.010718s].
[2022-10-28 11:41:51.345936] INFO: moduleinvoker: derived_feature_extractor.v3 开始运行..
[2022-10-28 11:41:51.354194] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.357838] INFO: moduleinvoker: derived_feature_extractor.v3 运行完成[0.011915s].
[2022-10-28 11:41:51.372989] INFO: moduleinvoker: join.v3 开始运行..
[2022-10-28 11:41:51.381102] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.384832] INFO: moduleinvoker: join.v3 运行完成[0.011856s].
[2022-10-28 11:41:51.408398] INFO: moduleinvoker: filtet_st_stock.v7 开始运行..
[2022-10-28 11:41:51.417743] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.421012] INFO: moduleinvoker: filtet_st_stock.v7 运行完成[0.012616s].
[2022-10-28 11:41:51.437974] INFO: moduleinvoker: filter.v3 开始运行..
[2022-10-28 11:41:51.449388] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.452444] INFO: moduleinvoker: filter.v3 运行完成[0.014483s].
[2022-10-28 11:41:51.462807] INFO: moduleinvoker: dropnan.v1 开始运行..
[2022-10-28 11:41:51.470179] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.473157] INFO: moduleinvoker: dropnan.v1 运行完成[0.010338s].
[2022-10-28 11:41:51.483771] INFO: moduleinvoker: instruments.v2 开始运行..
[2022-10-28 11:41:51.491875] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.494829] INFO: moduleinvoker: instruments.v2 运行完成[0.011065s].
[2022-10-28 11:41:51.515043] INFO: moduleinvoker: general_feature_extractor.v7 开始运行..
[2022-10-28 11:41:51.524728] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:41:51.527728] INFO: moduleinvoker: general_feature_extractor.v7 运行完成[0.012692s].
[2022-10-28 11:41:51.539871] INFO: moduleinvoker: derived_feature_extractor.v3 开始运行..
[2022-10-28 11:41:58.893337] INFO: derived_feature_extractor: 提取完成 cond28=sum(price_limit_status_0==3,30)>1, 2.072s
[2022-10-28 11:42:00.997223] INFO: derived_feature_extractor: 提取完成 std(turn_0,10), 2.101s
[2022-10-28 11:42:06.678025] INFO: derived_feature_extractor: 提取完成 fe1=sum(max(0,high_0-delay((high_0+low_0+close_0)/3,1)),26)/sum(max(0,delay((high_0+low_0+close_0)/3,1)-1),26)*100, 5.678s
[2022-10-28 11:42:08.829250] INFO: derived_feature_extractor: 提取完成 mean(turn_0*(return_0-1),30), 2.148s
[2022-10-28 11:42:10.889593] INFO: derived_feature_extractor: 提取完成 std(return_0-1,60), 2.058s
[2022-10-28 11:42:13.162929] INFO: derived_feature_extractor: 提取完成 std(return_0-1,15), 2.271s
[2022-10-28 11:42:29.497395] INFO: derived_feature_extractor: 提取完成 fe2=((close_0-sum(min(low_0,delay(close_0,1)),6))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),6)*12*24+(close_0-sum(min(low_0,delay(close_0,1)),12))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),12)*6*24+(close_0-sum(min(low_0,delay(close_0,1)),24))/sum(max(high_0,delay(close_0,1))-min(low_0,delay(close_0,1)),24)*6*24)*100/(6*12+6*24+12*24), 16.333s
[2022-10-28 11:42:30.724762] INFO: derived_feature_extractor: /y_2020, 283706
[2022-10-28 11:42:33.075964] INFO: derived_feature_extractor: /y_2021, 1061527
[2022-10-28 11:42:35.765468] INFO: derived_feature_extractor: /y_2022, 916020
[2022-10-28 11:42:36.708803] INFO: moduleinvoker: derived_feature_extractor.v3 运行完成[45.168858s].
[2022-10-28 11:42:36.731180] INFO: moduleinvoker: filtet_st_stock.v7 开始运行..
[2022-10-28 11:42:50.352635] INFO: moduleinvoker: filtet_st_stock.v7 运行完成[13.621442s].
[2022-10-28 11:42:50.370301] INFO: moduleinvoker: filter.v3 开始运行..
[2022-10-28 11:42:50.425321] INFO: filter: 使用表达式 cond28 过滤
[2022-10-28 11:42:57.469186] INFO: filter: 过滤 /data, 186439/1985268/2171707
[2022-10-28 11:42:57.544294] INFO: moduleinvoker: filter.v3 运行完成[7.173993s].
[2022-10-28 11:42:57.567340] INFO: moduleinvoker: dropnan.v1 开始运行..
[2022-10-28 11:42:58.424633] INFO: dropnan: /data, 177965/186439
[2022-10-28 11:42:58.481578] INFO: dropnan: 行数: 177965/186439
[2022-10-28 11:42:58.491179] INFO: moduleinvoker: dropnan.v1 运行完成[0.923815s].
[2022-10-28 11:42:58.498347] INFO: moduleinvoker: input_features.v1 开始运行..
[2022-10-28 11:42:58.508417] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:42:58.511607] INFO: moduleinvoker: input_features.v1 运行完成[0.01331s].
[2022-10-28 11:42:58.573262] INFO: moduleinvoker: index_feature_extract.v3 开始运行..
[2022-10-28 11:42:58.584785] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:42:58.588651] INFO: moduleinvoker: index_feature_extract.v3 运行完成[0.015393s].
[2022-10-28 11:42:58.598784] INFO: moduleinvoker: input_features.v1 开始运行..
[2022-10-28 11:42:58.612918] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:42:58.616712] INFO: moduleinvoker: input_features.v1 运行完成[0.017927s].
[2022-10-28 11:42:58.634458] INFO: moduleinvoker: stock_ranker_train.v5 开始运行..
[2022-10-28 11:42:58.646505] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:42:58.824751] INFO: moduleinvoker: stock_ranker_train.v5 运行完成[0.190297s].
[2022-10-28 11:42:58.846768] INFO: moduleinvoker: stock_ranker_predict.v5 开始运行..
[2022-10-28 11:42:59.874071] INFO: StockRanker预测: /data ..
[2022-10-28 11:43:00.720204] INFO: moduleinvoker: stock_ranker_predict.v5 运行完成[1.873431s].
[2022-10-28 11:43:00.746295] INFO: moduleinvoker: join.v3 开始运行..
[2022-10-28 11:43:01.425758] INFO: join: /data, 行数=177965/177965, 耗时=0.533761s
[2022-10-28 11:43:01.476488] INFO: join: 最终行数: 177965
[2022-10-28 11:43:01.488418] INFO: moduleinvoker: join.v3 运行完成[0.742119s].
[2022-10-28 11:43:01.510015] INFO: moduleinvoker: sort.v4 开始运行..
[2022-10-28 11:43:03.355374] INFO: moduleinvoker: sort.v4 运行完成[1.845342s].
[2022-10-28 11:43:06.227821] INFO: moduleinvoker: backtest.v8 开始运行..
[2022-10-28 11:43:06.235826] INFO: backtest: biglearning backtest:V8.6.3
[2022-10-28 11:43:10.524591] INFO: backtest: product_type:stock by specified
[2022-10-28 11:43:10.669420] INFO: moduleinvoker: cached.v2 开始运行..
[2022-10-28 11:43:10.678210] INFO: moduleinvoker: 命中缓存
[2022-10-28 11:43:10.681006] INFO: moduleinvoker: cached.v2 运行完成[0.011614s].
bigcharts-data-start/{"__type":"tabs","__id":"bigchart-aa0a6f1dc20242b3a9e0cb4bbd689843"}/bigcharts-data-end