-
Notifications
You must be signed in to change notification settings - Fork 3
/
interactionmatrix.py
38 lines (30 loc) · 1.54 KB
/
interactionmatrix.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
import numpy as np
class InteractionMatrix():
def getData(self, f12, d1):
Cy = d1.shape[1] / 2
Cx = d1.shape[0] / 2
ky = d1.shape[1] / 2
kx = d1.shape[0] / 2
xyz = np.zeros([d1.shape[0],d1.shape[1],3])
Lsx = np.zeros([d1.shape[0],d1.shape[1],6])
Lsy = np.zeros([d1.shape[0],d1.shape[1],6])
#d1 = d1/255.
med = np.median(d1)
for row in range(xyz.shape[0]):
for col in range(xyz.shape[1]):
if(d1[row,col]==0):
d1[row,col]= med
xyz[row,col,:] = [(col-Cx)/kx,(row-Cy)/ky,d1[row,col]]
Lsx[row,col,:] =[-1/xyz[row,col,2],0,xyz[row,col,0]/xyz[row,col,2],xyz[row,col,0]*xyz[row,col,1],
-(1+xyz[row,col,0]**2), xyz[row,col,1]]
Lsy[row,col,:] =[0,-1/xyz[row,col,2],xyz[row,col,1]/xyz[row,col,2],(1+xyz[row,col,1]**2),
-xyz[row,col,0]*xyz[row,col,1], -xyz[row,col,0]]
#lamda = 0.01
#mu = 0.03
#Lps = np.vstack([np.reshape(Lsx,[Lsx.shape[0]*Lsx.shape[1],6]),np.reshape(Lsy,[Lsy.shape[0]*Lsy.shape[1],6])])
#H=np.matmul(Lps.T,Lps)
#Hps = np.matmul(Lps.T,Lps) + 0.01*np.diag(np.matmul(Lps.T,Lps))
#fps = np.hstack([np.reshape(f12[...,0],[f12.shape[0]*f12.shape[1]]),np.reshape(f12[...,1],[f12.shape[0]*f12.shape[1]])])
#vps = - np.matmul(np.linalg.pinv(Lps),fps)
#vps=-lamda*np.matmul(np.matmul(np.linalg.pinv(H+mu*H.diagonal()),Lps.T),fps)
return None, Lsx, Lsy