は、通常、純粋なリストのアプローチが高速です。しかし、numpy
関数にはasarray
が入力されているので、配列転置の方法をお勧めします。
arr = np.array(pts) # 2x3x2 array
arr = arr.reshape(6,2)
x, y = arr.T # unpack a 2x6 array
テスト:
order = int(deg) + 1
x = NX.asarray(x) + 0.0
y = NX.asarray(y) + 0.0
の場合:と
In [614]: pts
Out[614]:
[[(120, 1200), (121, 1201), (122, 1202)],
[(130, 1300), (131, 1301), (132, 1302)]]
In [615]: np.array(pts).shape
Out[615]: (2, 3, 2)
In [616]: np.array(pts).reshape(-1,2).T
Out[616]:
array([[ 120, 121, 122, 130, 131, 132],
[1200, 1201, 1202, 1300, 1301, 1302]])
In [617]: y, x = np.array(pts).reshape(-1,2).T
In [618]: y
Out[618]: array([120, 121, 122, 130, 131, 132])
In [619]: x
Out[619]: array([1200, 1201, 1202, 1300, 1301, 1302])
np.polyfit
開始0がextend
で作成された共通zip*
は十分
In [625]: pts = []
...: y = [120, 121, 122]
...: x = [1200, 1201, 1202]
...: pts.extend(list(zip(y, x)))
...: x = [1300, 1301, 1302]
...: y = [130, 131, 132]
...: pts.extend(list(zip(y, x)))
...:
In [626]: pts
Out[626]: [(120, 1200), (121, 1201), (122, 1202), (130, 1300), (131, 1301), (132, 1302)]
In [627]: y,x = list(zip(*pts))
In [628]: y
Out[628]: (120, 121, 122, 130, 131, 132)
In [629]: x
Out[629]: (1200, 1201, 1202, 1300, 1301, 1302)
chain
平坦化は任意のリストの内包の必要性を排除し、*zip
転置と組み合わせることができますされていたであろう。
In [642]: pts
Out[642]:
[[(120, 1200), (121, 1201), (122, 1202)],
[(130, 1300), (131, 1301), (132, 1302)]]
In [643]: y,x=list(zip(*chain(*pts)))
In [644]: y
Out[644]: (120, 121, 122, 130, 131, 132)
In [645]: x
Out[645]: (1200, 1201, 1202, 1300, 1301, 1302)
このケースには追加のレベルのネスティングがあるため、重複は直接適用できません。 – hpaulj