gpt4 book ai didi

python - 如何通过两点(直径端)画圆?

转载 作者:行者123 更新时间:2023-12-01 03:03:18 24 4
gpt4 key购买 nike

立体投影上有两个点如图所示:

enter image description here

这些点应该位于圆直径的端点上。如何画一个经过这两点的圆?

上图的代码:

import matplotlib.pylab as plt
from mpl_toolkits.basemap import Basemap
import numpy as np
from scipy.interpolate import splev, splrep

# create instance of basemap, note we want a south polar projection to 90 = E
myMap = Basemap(projection='spstere',boundinglat=0,lon_0=180,resolution='l',round=True,suppress_ticks=True)
# set the grid up
gridX, gridY = 10.0, 15.0
parallelGrid = np.arange(-90.0,90.0,gridX)
meridianGrid = np.arange(-180.0,180.0,gridY)

# draw parallel and meridian grid, not labels are off. We have to manually create these.
myMap.drawparallels(parallelGrid,labels=[False,False,False,False])
myMap.drawmeridians(meridianGrid,labels=[False,False,False,False],labelstyle='+/-',fmt='%i')


# plot azimuth labels, with a North label.
ax = plt.gca()
ax.text(0.5,1.025,'N',transform=ax.transAxes,horizontalalignment='center',verticalalignment='bottom',size=25)
for para in np.arange(gridY,360,gridY):
x= (1.1*0.5*np.sin(np.deg2rad(para)))+0.5
y= (1.1*0.5*np.cos(np.deg2rad(para)))+0.5
ax.text(x,y,u'%i\N{DEGREE SIGN}'%para,transform=ax.transAxes,horizontalalignment='center',verticalalignment='center')

summerAzi = np.array([0, 360])
summerAlt = np.array([40, 4])
summerX, summerY = myMap(summerAzi, -summerAlt)


summerX_new = np.linspace(summerX.min(), summerX.max(),30)
summerY_smooth = splev(summerX_new, splrep(summerX, summerY, k=1))

myMap.plot(summerX_new, summerY_smooth, 'g')

myMap.plot(summerX, summerY, 'go')
plt.show()

最佳答案

内置的 tissot() 函数足以在等角投影上绘制圆(如本例所示)。在非等角投影上,它绘制椭圆。这里,蒂索指示线的中点是 (0, -22)(以度为单位)。它的半径 = (40-4)/2 = 18(以度为单位)。点数 = 36 即可。

相关代码为:

myMap.tissot(0, -22, 18, 36, \
facecolor='none', \
edgecolor='#ff0000', \
linewidth=1, \
alpha=1)

enter image description here

关于python - 如何通过两点(直径端)画圆?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43642433/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com