如何创建椭圆形状几何图形

2024-10-03 11:25:56 发布

您现在位置:Python中文网/ 问答频道 /正文

如何从已知的轴坐标和峰值半径创建椭圆?在

从下图:

Elips

A点和B点是已知的

R是fresnelZone计算的结果(以米为单位)。在

点X是线串AB的质心

我还读到: thisthis 但我不知道如何实施。在


Tags: ab半径单位this椭圆峰值质心fresnelzone
2条回答

我也在为一个类似的问题而挣扎。 我还想画一个菲涅耳区,但我想把它画在视线范围内,这条线连接着a点和B点

使用ewcz提供的代码,我添加了这条线并绘制了所有内容。在

结果表明,旋转直线与椭圆轴线不对应,因而与视线不一致。在

#!/usr/bin/env python
import math
from shapely.geometry import Point, LineString
from shapely.affinity import scale, rotate
from matplotlib import pyplot as plt

#input parameters
A = Point(0, 0)
B = Point(400, 10)
R = 5

d = A.distance(B)

#first, rotate B to B' around A so that |AB'| = |AB| and B'.y = A.y
#and then take S as midpoint of AB'
S = Point(A.x + d/2, A.y)
#Make a straight line
LOS = LineString([(A.x, A.y), (B.x, A.y)])
#alpha represents the angle of this rotation
alpha = math.atan2(B.y - A.y, B.x - A.x)

#create a circle with center at S passing through A and B'
C = S.buffer(d/2)

#rescale this circle in y-direction so that the corresponding
#axis is R units long
C = scale(C, 1, R/(d/2))

#rotate the ellipse obtained in previous step around A into the
#original position (positive angles represent counter-clockwise rotation)
C = rotate(C, alpha, origin=A, use_radians=True)
f_x, f_y = C.exterior.xy
#plot the ellipse
plt.plot(f_x, f_y)

#rotate the line in the same way as the ellipse
LOS_R = rotate(LOS, alpha, origin=A, use_radians=True)
f_x, f_y = LOS_R.xy
#plot the line
plt.plot(f_x, f_y)

plt.show()

结果图为: Plotted image with matplot

例如,可以这样进行:

#!/usr/bin/env python
import math
from shapely.geometry import Point
from shapely.affinity import scale, rotate

#input parameters
A = Point(1, 1)
B = Point(4, 5)
R = 1

d = A.distance(B)

#first, rotate B to B' around A so that |AB'| = |AB| and B'.y = A.y
#and then take S as midpoint of AB'
S = Point(A.x + d/2, A.y)

#alpha represents the angle of this rotation
alpha = math.atan2(B.y - A.y, B.x - A.x)

#create a circle with center at S passing through A and B'
C = S.buffer(d/2)

#rescale this circle in y-direction so that the corresponding
#axis is R units long
C = scale(C, 1, R/(d/2))

#rotate the ellipse obtained in previous step around A into the
#original position (positive angles represent counter-clockwise rotation)
C = rotate(C, alpha, origin = A, use_radians = True)

for x,y in C.exterior.coords:
    print(x, y)

相关问题 更多 >