簡體   English   中英

在離散數據點的點處找到切向量

[英]find tangent vector at a point for discrete data points

我有一個向量,在空間中至少有兩個點,例如:

A = np.array([-1452.18133319  3285.44737438 -7075.49516676])
B = np.array([-1452.20175668  3285.29632734 -7075.49110863])

我想在曲線的離散點處找到向量的切線,gg曲線的起點和終點。 我知道如何在Matlab中做到這一點,但我想在Python中做到這一點。 這是Matlab中的代碼:

A = [-1452.18133319  3285.44737438 -7075.49516676];
B = [-1452.20175668  3285.29632734 -7075.49110863];
points = [A; B];
distance = [0.; 0.1667];
pp = interp1(distance, points,'pchip','pp');
[breaks,coefs,l,k,d] = unmkpp(pp);
dpp = mkpp(breaks,repmat(k-1:-1:1,d*l,1).*coefs(:,1:k-1),d);
ntangent=zeros(length(distance),3);
for j=1:length(distance)
    ntangent(j,:) = ppval(dpp, distance(j));
end

%The solution would be at beginning and end:
%ntangent =
%   -0.1225   -0.9061    0.0243
%   -0.1225   -0.9061    0.0243    

有任何想法嗎? 我試圖通過多種方法使用numpy和scipy找到解決方案,例如

tck, u= scipy.interpolate.splprep(data)

但似乎沒有一種方法可以滿足我的要求。

der=1賦予splev以得到樣條的導數:

from scipy import interpolate
import numpy as np
t=np.linspace(0,1,200)
x=np.cos(5*t)
y=np.sin(7*t)
tck, u = interpolate.splprep([x,y])

ti = np.linspace(0, 1, 200)
dxdt, dydt = interpolate.splev(ti,tck,der=1)

好的,我找到了上面“ pv”的一點修改的解決方案(請注意,splev僅適用於一維矢量)我最初使用“ tck,u = scipy.interpolate.splprep(data)”遇到的一個問題是至少需要4分才能工作(Matlab需要2分)。 我當時使用了兩點。 增加數據點后,它可以按我的要求工作。

這是完整性的解決方案:

import numpy as np
import matplotlib.pyplot as plt
from scipy import interpolate
data = np.array([[-1452.18133319 , 3285.44737438, -7075.49516676],
                 [-1452.20175668 , 3285.29632734, -7075.49110863],
                 [-1452.32645025 , 3284.37412457, -7075.46633213],
                 [-1452.38226151 , 3283.96135828, -7075.45524248]])

distance=np.array([0., 0.15247556, 1.0834, 1.50007])

data = data.T
tck,u = interpolate.splprep(data, u=distance, s=0)
yderv = interpolate.splev(u,tck,der=1)

和切線是(如果使用相同的數據,則匹配Matlab結果):

(-0.13394599723751408, -0.99063114953803189, 0.026614957159932656)
(-0.13394598523149195, -0.99063115868512985, 0.026614950816003666)
(-0.13394595055068903, -0.99063117647357712, 0.026614941718878599)
(-0.13394595652952143, -0.9906311632471152, 0.026614954146007865)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM