-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathv2-lola-IPD.py
48 lines (37 loc) · 1.96 KB
/
v2-lola-IPD.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
import numpy as np
import torch
from torch.autograd import Variable
dtype = torch.cuda.FloatTensor
y1 = Variable(torch.zeros(5,1).type(dtype),requires_grad = True)
y2 = Variable(torch.zeros(5,1).type(dtype),requires_grad = True)
r1 = Variable(torch.Tensor([-1,-3,0,-2]).type(dtype))
r2 = Variable(torch.Tensor([-1,0,-3,-2]).type(dtype))
I = Variable(torch.eye(4).type(dtype))
gamma = Variable(torch.Tensor([0.6]).type(dtype))
delta = Variable(torch.Tensor([0.1]).type(dtype))
eta = Variable(torch.Tensor([10]).type(dtype))
V1arr = []
V2arr = []
for epoch in range(5000):
x1 = torch.sigmoid(y1)
x2 = torch.sigmoid(y2)
P = torch.cat((x1*x2,x1*(1-x2),(1-x1)*x2,(1-x1)*(1-x2)),1)
Zinv = torch.inverse(I-gamma*P[1:,:])
V1 = torch.matmul(torch.matmul(P[0,:],Zinv),r1)
V2 = torch.matmul(torch.matmul(P[0,:],Zinv),r2)
V1arr.append(V1)
V2arr.append(V2)
dV1 = torch.autograd.grad(V1,(y1,y2),create_graph = True)
dV2 = torch.autograd.grad(V2,(y1,y2),create_graph = True)
d2V2y1 = [torch.autograd.grad(dV2[1][i], y1, create_graph = True)[0] for i in range(y1.size(0))]
d2V2y2 = [torch.autograd.grad(dV1[1][i], y1, create_graph = True)[0] for i in range(y1.size(0))]
d2V1y2 = [torch.autograd.grad(dV1[0][i], y2, create_graph = True)[0] for i in range(y1.size(0))]
d2V1y1 = [torch.autograd.grad(dV2[0][i], y2, create_graph = True)[0] for i in range(y1.size(0))]
d2V2y1Tensor = torch.cat([d2V2y1[i] for i in range(y1.size(0))],1)
d2V2y2Tensor = torch.cat([d2V2y2[i] for i in range(y1.size(0))],1)
d2V1y2Tensor = torch.cat([d2V1y2[i] for i in range(y1.size(0))],1)
d2V1y1Tensor = torch.cat([d2V1y1[i] for i in range(y1.size(0))],1)
y1.data += (delta*dV1[0] + delta*eta*torch.matmul(d2V2y1Tensor,dV1[1]) + delta*eta*torch.matmul(d2V2y2Tensor,dV2[1])).data
#y1.data += (delta*dV1[0] + delta*eta*torch.matmul(d2V2y1Tensor,dV1[1])).data
#y1.data += (delta*dV1[0]).data
y2.data += (delta*dV2[1] + delta*eta*torch.matmul(d2V1y2Tensor,dV2[0]) + delta*eta*torch.matmul(d2V1y1Tensor,dV1[0])).data