python简单的基于做市商的股票高频交易策略
admin
2023-07-24 06:42:22
0

哈咯!想用python设计一个简单的基于做市商的股票高频交易策略,之前的主要class都已经写好了,现在在主程序里面实现策略,但是始终想不出一个合理的代码结构来实现,有没有哪位大神敢尝试啊哈哈:

先给出模仿的论文策略图:
python简单的基于做市商的股票高频交易策略

python简单的基于做市商的股票高频交易策略

下面是我自己能写出的主程序部分:(如果需要我写的class可以在下面评论)

#Firstly, I load the first day's data from table BHP_data,
#then create two lists for storing the mid price and time,
#and then use for loop to read each events imformation, and store the mid price and time data into list.
#afterwards, plot the first day data and time in a figure.

import mysql.connector
import pyodbc

connection = mysql.connector.connect(user= 'root', password = '51jingtI', host = '127.0.0.1', database = 'HF2')
cursor = connection.cursor()
cursor.execute("select * from BHP_data where date='2007-07-02'")
events_data = cursor.fetchall()

#create two lists for storing the mid price and time,
money = 100
mid_price_list = []
best_ask_price_list = []
best_bid_price_list = []

time_list = []
book = OrderBook()
book_list_bid = []
book_list_ask = []
profit_list = []

for data in events_data:
S_price = float(book.best_ask_price())+0.001
S_PM_price = float(book.best_ask_price())-0.01
B_PM_price = float(book.best_bid_price())+0.01
B_price = float(book.best_bid_price())-0.001

lo = LimitOrder(data[0],data[1],data[2],data[3],data[4],data[5],data[6],data[7],data[8],data[9],data[10],data[11],data[12])
lo_b = LimitOrder(data[0],data[1],data[2],'ENTER',B_price,1,'000','','B',0,0,0,data[12])
lo_s = LimitOrder(data[0],data[1],data[2],'ENTER',S_price,1,'','000','A',0,0,0,data[12])
book.add(lo)
if book.mid_price():
    mid_price_list.append(float(book.mid_price()))
if len(mid_price_list) > 10:

    if ((float(mid_price_list[len(mid_price_list)-1]) - float(mid_price_list[len(mid_price_list)-2]))>0 
        and 
        (float(mid_price_list[len(mid_price_list)-1] - mid_price_list[len(mid_price_list)-2])- 
        float(mid_price_list[len(mid_price_list)-2] - mid_price_list[len(mid_price_list)-1]))> 0
        and 
        len(book_list_bid) == 0):

        book.add(lo_b)
        book_list_bid.append(lo_b.get_id())

    elif((float(mid_price_list[len(mid_price_list)-1]) - float(mid_price_list[len(mid_price_list)-2])) < 0 
        and 
        (float(mid_price_list[len(mid_price_list)-1] - mid_price_list[len(mid_price_list)-2])- 
        float(mid_price_list[len(mid_price_list)-2] - mid_price_list[len(mid_price_list)-1])) < 0
        and
        len(book_list_ask) == 0):

        book.add(lo_b)
        book_list_ask.append(lo_b.get_id())
if len(mid_price_list) > 50:     
    if not (lo_b.get_id() in book.event_dict):
        lo_b_pm = LimitOrder(data[0],data[1],data[2],'ENTER',B_PM_price,1,'','test_ask_new',data[8],1,1,1,1)
        book.add(lo_b_pm)

    if not (lo_s.get_id() in book.event_dict):
        lo_s_pm = LimitOrder(data[0],data[1],data[2],'ENTER',S_PM_price,1,'test_bid_new','',data[8],1,1,1,1)
        book.add(lo_s_pm)

#instrument, date, time, record_type, price, volume,bid_id, ask_id, direction, sameoffset, oppoffset, midoffset, timestamp):

plt.figure(figsize=(20,8))
plt.xlabel('volume')
plt.ylabel('Mid price')
plt.title('Mid price of BHP')
plt.plot(mid_price_list)
plt.show()

相关内容

热门资讯

小车撞断护栏从数米高桥下飞落,... 极目新闻记者 张皓6月26日早上,多名网友发布视频称,山西阳泉市赛鱼大桥,一辆小车撞断石质护栏后,坠...
为流量摆拍“铁笼游街”,法律就... 一次“人狗同笼”低俗摆拍的底线试探,换来1人被刑拘、8人被行拘的法律回应6月26日,针对近日网传“多...
洛阳市最新人事任免:李夏影任市... 6月25日,洛阳市人民政府任免国家工作人员。任命李夏影(女)为洛阳市人民政府国有资产监督管理委员会副...
“蓝色票政”掀动暑期热浪!郑州... 郑州海昌海洋公园以“夏天就要‘泡’在海洋里”为主题,打造的专属海洋的夏日清凉...
7月1日起,郑州市城乡低保标准... 6月26日,记者从郑州市民政局获悉,郑州市民政局、郑州市财政局近日联合下发通知,明确从2026年7月...
学习新语|发挥党建引领作用 建... 6月24日,习近平总书记在山东德州考察时,走进西于架村党群服务中心,细致询问村党组织建设和开展便民服...
城长中的河南宝贝丨“磨”出潮流... 六面顶压机见证老厂新生“磨”出潮流街区新生态磨街文创园入口处,六面顶压机化身艺术装置。 高洋 摄【开...
河南省发展改革委主任马健:做强... 做强开发区主阵地主引擎——访省发展改革委党组书记、主任马健“近年来,我省扎实推进功能布局优化、主导产...
美国250周年在即,民调:近8... 【文/观察者网 齐倩】今年7月4日,美国将迎来独立250周年纪念日。“建国250周年之际,美国人情感...
柯志恩是否能复制韩国瑜当年胜选... 海峡导报综合报道 根据《ETtoday民调云》23日公布的最新高雄市长选战民调,国民党市长参选人柯志...