日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python求点到曲线距离_Python。如何从点和偏移距离的x,y列表中获取偏移样条曲线的x,y坐标...

發布時間:2025/3/20 python 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python求点到曲线距离_Python。如何从点和偏移距离的x,y列表中获取偏移样条曲线的x,y坐标... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在特殊情況下,坡度為無窮大/零,但基本方法是使用插值計算某個點的坡度,然后找到垂直坡度,然后計算該距離處的點。在

我修改了來自here的示例,以添加第二個圖。它與data file you provided一起工作,但您可能需要更改另一個信封的符號計算。在

編輯根據您關于希望信封連續的評論,我在結尾處添加了一個低俗的半圓,使非常接近?;旧?#xff0c;在創建封套時,越圓越凸,效果越好。另外,你需要把開頭和結尾重疊,否則你會有一個間隙。在

而且,幾乎可以肯定的是,它可以變得更有效率我不是一個numpy專家,所以這只是純Python。在def offset(coordinates, distance):

coordinates = iter(coordinates)

x1, y1 = coordinates.next()

z = distance

points = []

for x2, y2 in coordinates:

# tangential slope approximation

try:

slope = (y2 - y1) / (x2 - x1)

# perpendicular slope

pslope = -1/slope # (might be 1/slope depending on direction of travel)

except ZeroDivisionError:

continue

mid_x = (x1 + x2) / 2

mid_y = (y1 + y2) / 2

sign = ((pslope > 0) == (x1 > x2)) * 2 - 1

# if z is the distance to your parallel curve,

# then your delta-x and delta-y calculations are:

# z**2 = x**2 + y**2

# y = pslope * x

# z**2 = x**2 + (pslope * x)**2

# z**2 = x**2 + pslope**2 * x**2

# z**2 = (1 + pslope**2) * x**2

# z**2 / (1 + pslope**2) = x**2

# z / (1 + pslope**2)**0.5 = x

delta_x = sign * z / ((1 + pslope**2)**0.5)

delta_y = pslope * delta_x

points.append((mid_x + delta_x, mid_y + delta_y))

x1, y1 = x2, y2

return points

def add_semicircle(x_origin, y_origin, radius, num_x = 50):

points = []

for index in range(num_x):

x = radius * index / num_x

y = (radius ** 2 - x ** 2) ** 0.5

points.append((x, -y))

points += [(x, -y) for x, y in reversed(points)]

return [(x + x_origin, y + y_origin) for x, y in points]

def round_data(data):

# Add infinitesimal rounding of the envelope

assert data[-1] == data[0]

x0, y0 = data[0]

x1, y1 = data[1]

xe, ye = data[-2]

x = x0 - (x0 - x1) * .01

y = y0 - (y0 - y1) * .01

yn = (x - xe) / (x0 - xe) * (y0 - ye) + ye

data[0] = x, y

data[-1] = x, yn

data.extend(add_semicircle(x, (y + yn) / 2, abs((y - yn) / 2)))

del data[-18:]

from pylab import *

with open('ah79100c.dat', 'rb') as f:

f.next()

data = [[float(x) for x in line.split()] for line in f if line.strip()]

t = [x[0] for x in data]

s = [x[1] for x in data]

round_data(data)

parallel = offset(data, 0.1)

t2 = [x[0] for x in parallel]

s2 = [x[1] for x in parallel]

plot(t, s, 'g', t2, s2, 'b', lw=1)

title('Wing with envelope')

grid(True)

axes().set_aspect('equal', 'datalim')

savefig("test.png")

show()

總結

以上是生活随笔為你收集整理的python求点到曲线距离_Python。如何从点和偏移距离的x,y列表中获取偏移样条曲线的x,y坐标...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在线观看日本一区二区 | www一起操 | 国产麻豆成人精品av | av中文字幕免费观看 | 毛片视| 日韩精彩视频在线观看 | 灌篮高手全国大赛电影 | 波多野结衣视频免费在线观看 | 日韩在线一 | 亚洲精品一区三区三区在线观看 | 亚洲国产99 | 一本一道无码中文字幕精品热 | 久久久久久久久久久久久久久 | 国产ts在线| 女人脱了内裤趴开腿让男躁 | 亚洲第一天堂av | 91亚洲国产成人久久精品网站 | wwwxx国产 | 午夜精品一区二区三 | 极品尤物一区二区 | 成人国产精品久久久网站 | 91色视频在线 | 国产黄网在线观看 | 美女毛片 | 色婷综合 | 手机看片国产1024 | av一二三区| 亚洲免费毛片 | 美女扒开粉嫩的尿囗给男生桶 | 国产对白羞辱绿帽vk | 老女人乱淫 | 国模福利视频 | 尤物网址在线观看 | 国产真人做爰毛片视频直播 | 日本中文在线视频 | 爱爱视频一区二区 | 操操网站 | 日本女优中文字幕 | 96av在线| 亚洲a在线观看 | 国产精品无遮挡 | 日日夜夜国产 | 动漫美女舌吻 | 欧美日韩综合在线观看 | 迈开腿让我尝尝你的小草莓 | 日韩第八页 | 亚洲一区二区在线电影 | 尤物综合网 | 很污的网站 | 国产www免费观看 | www香蕉视频 | 9久9久9久女女女九九九一九 | 中文字幕av观看 | 秋霞影院午夜伦 | wwwxxxx日本| av网站免费在线观看 | 神马久久久久久久 | 日韩高清一区二区 | 成人性生交视频免费观看 | 日本成人中文字幕 | 在线观看你懂的网址 | 超级碰碰97| www.狠狠操 | 日本免费黄网站 | 91人妻一区二区 | 一区两区小视频 | 九热精品 | 国产精品一区二区在线播放 | 久久在线免费 | 九色porn蝌蚪| 狠狠草视频 | 日本性视频网站 | 黄色岛国片 | 免费国产91 | 天天狠狠操 | 午夜三级网站 | 午夜av在线免费观看 | 少妇系列av| 精品人妻少妇一区二区三区 | 尤物在线| 亚洲人在线视频 | 亚洲精品国产精品国自产在线 | 69精品一区二区三区 | 欧美三级在线播放 | 相亲对象是问题学生在线观看 | 91小视频| 亚洲欧洲色 | 最新中文字幕在线播放 | 麻豆视频在线观看免费网站 | a一级视频 | 欧美性白人极品1819hd | 国产精品一区在线免费观看 | 美女一区二区三区视频 | 最好看的电影2019中文字幕 | 亚洲啊啊啊啊啊 | 亚洲熟女少妇一区二区 | 亚洲一区二区精品在线观看 | 动漫美女放屁 | 在线午夜av |