Skip to content

Commit

Permalink
Update align.py
Browse files Browse the repository at this point in the history
  • Loading branch information
Jerome1434 authored Jul 23, 2020
1 parent 9a36410 commit 17e6117
Showing 1 changed file with 22 additions and 2 deletions.
24 changes: 22 additions & 2 deletions ampscan/align.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,13 +53,16 @@ class align(object):
"""

def __init__(self, moving, static, method = 'linPoint2Plane',
*args, **kwargs):
inverse=False, *args, **kwargs):
mData = dict(zip(['vert', 'faces', 'values'],
[moving.vert, moving.faces, moving.values]))
alData = copy.deepcopy(mData)
self.m = AmpObject(alData, stype='reg')
self.s = static
self.runICP(method=method, *args, **kwargs)
if inverse:
self.inverse(method=method, *args, **kwargs)
else:
self.runICP(method=method, *args, **kwargs)


def runICP(self, method = 'linPoint2Plane', maxiter=20, inlier=1.0,
Expand Down Expand Up @@ -160,6 +163,23 @@ def runICP(self, method = 'linPoint2Plane', maxiter=20, inlier=1.0,
self.T = Ts[:, -1]
self.rmse = err[-1]

def inverse(self, method = 'linPoint2Plane', *args, **kwargs):
#inverting the objects
self.temp = self.s
self.s = self.m
self.m = self.temp
self.runICP(method=method, *args, **kwargs)
#resetting the objects
self.temp = self.s
self.s = self.m
self.m = self.temp
del self.temp
#inverting the transformation on both objects
self.R = self.R.transpose()
self.T = -self.T
self.tForm = np.r_[np.c_[self.R, np.zeros(3)], np.append(self.T, 1)[:, None].T]
self.s.rigidTransform(self.R, self.T)
self.m.rigidTransform(self.R, self.T)

@staticmethod
def linPoint2Plane(mv, sv, sn):
Expand Down

0 comments on commit 17e6117

Please sign in to comment.