java某一点的极坐标,散射极坐标图轮廓

这是一个计算数据凸壳的示例(我不知道应该如何计算矩形)并在 PolyCollection 的帮助下显示凸包 . 由于我没有你的数据,我生成了一些随机数据点,但它应该很容易适应 .

from matplotlib import pyplot as plt

import numpy as np

from scipy.spatial import ConvexHull

from matplotlib.collections import PolyCollection

fig = plt.figure()

ax1 = fig.add_subplot(111, projection='polar')

#generating some data:

C = np.random.rand(30)*15+40

h = np.random.rand(30)*15+290

h = np.radians(h) # convert values of the angle from degrees to radians

#following scipy example

points = np.concatenate([h,C]).reshape((2,30)).T

hull = ConvexHull(points)

ax1.scatter(h,C, s = 5, marker = 'o', color='b')

#adding the convex hull to ax1 as a PolyCollection:

ax1.add_collection(PolyCollection(

[points[hull.vertices,:]],

edgecolors='r',

facecolors='w',

linewidths=2,

zorder=-1,

))

ax1.set_rmax(60)

plt.show()

如果已经计算了矩形,则可以省略凸包计算并从那里生成 PolyCollection . 注意我用来创建 PolyCollection 的 **kwargs . 特别是 zorder 很重要,否则多边形将被绘制在点的顶部 . 结果图看起来像这样:

1a554b00-76d1-45d0-aa5e-59c580cad81e.png

希望这可以帮助 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值