python绘图之灰度图

灰度图(Gray Scale Image)是一种将图像中的像素值映射到灰度范围(通常是0到255)的图像表示方式。它在图像处理和计算机视觉中具有重要作用.本节学习使用python绘制灰度图

# 导入必要的库
import numpy as np
import matplotlib.pyplot as plt

# 随机生成数据
np.random.seed(0)  # 设置随机种子以保证结果可复现
num_samples = 1000  # 样本数量
age = np.random.uniform(18, 80, num_samples)  # 随机生成年龄,范围为18到80
bmi = np.random.uniform(15, 40, num_samples)  # 随机生成BMI,范围为15到40
density = np.random.rand(num_samples)  # 随机生成密度值(0到1之间的随机数)

# 将数据分组到网格中
x_edges = np.linspace(age.min(), age.max(), 10)  # 年龄分组,将年龄范围分为10个区间
y_edges = np.linspace(bmi.min(), bmi.max(), 10)  # BMI分组,将BMI范围分为10个区间
density_matrix, _, _ = np.histogram2d(age, bmi, bins=[x_edges, y_edges], weights=density)
# 使用np.histogram2d计算每个网格中的密度值,返回一个二维矩阵

# 计算灰度值(沿y轴方向求和)
gray_values = density_matrix.sum(axis=1)  # 对密度矩阵沿y轴方向(BMI方向)求和,得到灰度值

# 绘制灰度图
fig2 = plt.figure()  # 创建一个图形窗口
ax2 = fig2.add_subplot(111, projection='3d')  # 添加一个3D子图
X, Y = np.meshgrid(y_edges[:-1], x_edges[:-1])  # 生成网格坐标,用于3D绘制
# np.meshgrid生成网格点坐标,y_edges[:-1]和x_edges[:-1]是为了去掉最后一个边界点

# 使用plot_surface绘制3D曲面图
ax2.plot_surface(X, Y, np.outer(gray_values, np.ones_like(y_edges[:-1])), cmap='gray')
# np.outer将灰度值扩展为与网格大小匹配的矩阵,cmap='gray'设置颜色映射为灰度

# 设置坐标轴标签和标题
ax2.set_xlabel('BMI')  # 设置x轴标签为BMI
ax2.set_ylabel('Age')  # 设置y轴标签为
Ageax2.set_zlabel('Gray values')  # 设置z轴标签为灰度值
ax2.set_title('3D Gray Value Plot')  # 设置图形标题

plt.show()  # 显示图形

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值