-
Notifications
You must be signed in to change notification settings - Fork 505
/
Copy pathrun.py
99 lines (86 loc) · 3.18 KB
/
run.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
## this file take input from ib and then make vector and run the experiment
##it takes care of filtering epsilon etx
from q_learning.dqn_agent import *
from prepare_data import *
import pdb
class PortfolioAgent:
def __init__(self, data):
self.portfolio = 0
self.total_portfolio_delta = 0
self.stock_data = data[0:1000]
#for training no need for real data
self.other_stored_data = data[1000:]
#todo last action, not sure if required
#85 is input vector length
self.AGENT = Agent([0], input_vector_length = 85)
self.last_buying_price = 0
self.last_selling_price = 0
def make_input_vector(self):
#todo need to write normalization method also
column = self.stock_data.shape[1]
standaridized_data = standardization(self.stock_data)
vector = standaridized_data[-10:].reshape(10*column,)
vector = np.append(vector,find_average(standaridized_data[-200:]))
vector = np.append(vector, find_average(standaridized_data[-1000:]))
portfolio_value = self.portfolio
#for makig sure that network understand it can't go more negative
if (portfolio_value > 1):
portfolio_value = 1
elif (portfolio_value < -1):
portfolio_value = -1
vector = np.append(vector, [portfolio_value])
return vector
def find_reward(self, action):
#Todo fuction should get execution price for IB API
#Todo think more deeply on reward
#leaving short for now as it is making things complicated and also now allowed in market
last_price = self.stock_data[-2][-2]
current_price = self.stock_data[-1][-2]
flag = True
cost = 0
if (action == 1):
transaction_cost = last_price * 0.001
self.last_buying_price = last_price
#punish action not to buy more if already bought
if self.portfolio == 1:
flag = False
elif (action == 2):
transaction_cost = last_price * 0.01
self.last_selling_price = last_price
#punish if selling more what is already sold
if self.portfolio == 0:
flag = False
else:
cost = (last_price - self.last_buying_price)
else:
transaction_cost = 0
if flag:
portfolio_change = self.portfolio * (current_price - last_price)
else:
portfolio_change = -10000
#caluclate total profit and loss also
self.total_portfolio_delta = transaction_cost + cost
#todo need to take care that portfolio don't go much negative
self.portfolio += action
return transaction_cost + portfolio_change
def agent_start(self):
stock_data = self.stock_data
action = self.AGENT.agent_start(self.make_input_vector())
reward = self.find_reward(action)
epoch = 0
n_epoch = 100000
while (epoch < n_epoch):
self.stock_data = np.vstack([self.stock_data, self.other_stored_data[0]])
self.other_stored_data = np.delete(self.other_stored_data, [0],0)
self.stock_data = np.delete(self.stock_data, [0], 0)
#we can put conditional here to start taking from API one csv_data finished
action = self.AGENT.agent_step(reward, self.make_input_vector())
print("epoch is: ", epoch)
print("action is: ", action)
print("reward is: ", reward)
reward = self.find_reward(action)
epoch += 1
print("portfolio: ", self.portfolio)
print("total_portfolio_delta: ", self.total_portfolio_delta)
k = PortfolioAgent(prepare_data("CANFINHOM"))
k.agent_start()