42

我有一个图表,根据一些数据计算,在 matplotlib 中绘制。我想在该图的全局最大值周围绘制一个矩形区域。我试过plt.axhspan,了,但是当我打电话时矩形似乎没有出现plt.show()

那么,如何将矩形区域绘制到 matplotlib 图上呢?谢谢!

4

2 回答 2

50

最可能的原因是您在调用 axhspan 时为 x 参数使用了数据单位。从函数的文档(我的重点):

y 坐标以数据单位为单位,x 坐标以轴(相对 0-1)单位为单位

因此,任何从 0 向左或从 1 向右拉伸的矩形都只是在绘图之外绘制。

一个简单的替代方法可能是将 a 添加Rectangle到您的轴(例如,通过plt.gcaadd_patch);Rectangle对两个维度都使用数据单元。以下将添加一个以 (2,3) 为中心的宽度和高度为 1 的灰色矩形:

from matplotlib.patches import Rectangle
import matplotlib.pyplot as plt

fig = plt.figure()
plt.xlim(0, 10)
plt.ylim(0, 12)

someX, someY = 2, 5
currentAxis = plt.gca()
currentAxis.add_patch(Rectangle((someX - .5, someY - .5), 4, 6, facecolor="grey"))

在此处输入图像描述

  • 没有facecolor
currentAxis.add_patch(Rectangle((someX - .5, someY - .5), 4, 6, facecolor="none", ec='k', lw=2))

在此处输入图像描述

于 2012-10-22T15:32:12.377 回答
6

这是一个演示在散点图上绘制矩形边界框的示例:

import matplotlib.pyplot as plt
import matplotlib.patches as patches
import numpy as np

data = np.array([
    [.9, .9], [.85, 2.1], [1.2, 1.], [2.1, .95], [3., 1.1],
    [3.9, .7], [4., 1.4], [4.2, 1.8], [2., 2.3], [3., 2.3],
    [1.5, 1.8], [2., 1.5], [2.2, 2.], [2.6, 1.7], [2.7, 1.85]
])
categories = np.array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1])
color1 = (0.69, 0.34, 0.15, 1.0)
color2 = (0.65, 0.80, 0.89, 1.0)
colormap = np.array([color1, color2])
fig = plt.figure()
ax = fig.add_subplot(111)
ax.scatter(
    x=[data[:, 0]],
    y=[data[:, 1]],
    c=colormap[categories],
    marker='o', alpha=0.9)

margin = .1
min_f0, max_f0 = min(data[10:, 0]) - margin, max(data[10:, 0]) + margin
min_f1, max_f1 = min(data[10:, 1]) - margin, max(data[10:, 1]) + margin
width = max_f0 - min_f0
height = max_f1 - min_f1

ax.add_patch(
    patches.Rectangle(
        xy=(min_f0, min_f1),  # point of origin.
        width=width, height=height, linewidth=1,
        color='red', fill=False))
plt.show()

出去:

在散点图上添加边界框

于 2019-11-09T09:09:12.557 回答