vecorized pyramid function for lambert projection

This commit is contained in:
Martin Diehl 2020-04-29 17:52:09 +02:00
parent ad312201dd
commit 2df78e4e2f
1 changed files with 36 additions and 29 deletions

View File

@ -1064,8 +1064,7 @@ class Rotation:
if np.allclose(ho_,0.0,rtol=0.0,atol=1.0e-16): if np.allclose(ho_,0.0,rtol=0.0,atol=1.0e-16):
cu = np.zeros(3) cu = np.zeros(3)
else: else:
p = _get_order(ho_) xyz3 = ho_[Rotation._get_order(ho_,'forward')]
xyz3 = ho_[p[0]]
# inverse M_3 # inverse M_3
xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) ) xyz2 = xyz3[0:2] * np.sqrt( 2.0*rs/(rs+np.abs(xyz3[2])) )
@ -1087,7 +1086,7 @@ class Rotation:
# inverse M_1 # inverse M_1
cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc cu = np.array([ Tinv[0], Tinv[1], (-1.0 if xyz3[2] < 0.0 else 1.0) * rs / np.sqrt(6.0/np.pi) ]) /_sc
# reverse the coordinates back to the regular order according to the original pyramid number # reverse the coordinates back to the regular order according to the original pyramid number
cu = cu[p[1]] cu = cu[Rotation._get_order(ho_,'backward')]
return cu return cu
else: else:
@ -1141,8 +1140,7 @@ class Rotation:
ho = np.zeros(3) ho = np.zeros(3)
else: else:
# get pyramide and scale by grid parameter ratio # get pyramide and scale by grid parameter ratio
p = _get_order(cu_) XYZ = cu_[Rotation._get_order(cu_,'forward')] * _sc
XYZ = cu_[p[0]] * _sc
# intercept all the points along the z-axis # intercept all the points along the z-axis
if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16): if np.allclose(XYZ[0:2],0.0,rtol=0.0,atol=1.0e-16):
@ -1164,14 +1162,15 @@ class Rotation:
ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ]) ho = np.array([ T[order[1]] * q, T[order[0]] * q, np.sqrt(6.0/np.pi) * XYZ[2] - c ])
# reverse the coordinates back to the regular order according to the original pyramid number # reverse the coordinates back to the regular order according to the original pyramid number
ho = ho[p[1]] ho = ho[Rotation._get_order(cu_,'backward')]
return ho return ho
else: else:
raise NotImplementedError raise NotImplementedError
def _get_order(xyz): @staticmethod
def _get_order(xyz,direction=None):
""" """
Get order of the coordinates. Get order of the coordinates.
@ -1189,12 +1188,20 @@ def _get_order(xyz):
https://doi.org/10.1088/0965-0393/22/7/075013 https://doi.org/10.1088/0965-0393/22/7/075013
""" """
if (abs(xyz[0])<= xyz[2]) and (abs(xyz[1])<= xyz[2]) or \ order = {'forward':np.array([[0,1,2],[1,2,0],[2,0,1]]),
(abs(xyz[0])<=-xyz[2]) and (abs(xyz[1])<=-xyz[2]): 'backward':np.array([[0,1,2],[2,0,1],[1,2,0]])}
return [[0,1,2],[0,1,2]] if len(xyz.shape) == 1:
elif (abs(xyz[2])<= xyz[0]) and (abs(xyz[1])<= xyz[0]) or \ if np.maximum(abs(xyz[0]),abs(xyz[1])) <= xyz[2] or \
(abs(xyz[2])<=-xyz[0]) and (abs(xyz[1])<=-xyz[0]): np.maximum(abs(xyz[0]),abs(xyz[1])) <=-xyz[2]:
return [[1,2,0],[2,0,1]] p = 0
elif (abs(xyz[0])<= xyz[1]) and (abs(xyz[2])<= xyz[1]) or \ elif np.maximum(abs(xyz[1]),abs(xyz[2])) <= xyz[0] or \
(abs(xyz[0])<=-xyz[1]) and (abs(xyz[2])<=-xyz[1]): np.maximum(abs(xyz[1]),abs(xyz[2])) <=-xyz[0]:
return [[2,0,1],[1,2,0]] p = 1
elif np.maximum(abs(xyz[2]),abs(xyz[0])) <= xyz[1] or \
np.maximum(abs(xyz[2]),abs(xyz[0])) <=-xyz[1]:
p = 2
else:
p = np.where(np.maximum(np.abs(xyz[...,0]),np.abs(xyz[...,1])) <= np.abs(xyz[...,2]),0,
np.where(np.maximum(np.abs(xyz[...,1]),np.abs(xyz[...,2])) <= np.abs(xyz[...,0]),2,3))
return order[direction][p]