当前位置: 首页 > news >正文

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()  # 显示图形

http://www.lryc.cn/news/544400.html

相关文章:

  • 华为 VRP 系统简介配置SSH,TELNET远程登录
  • 1.14 重叠因子:TRIMA三角移动平均线(Triangular Moving Average, TRIMA)概念与Python实战
  • 【tplink】校园网接路由器如何单独登录自己的账号,wan-lan和lan-lan区别
  • PC 端连接安卓手机恢复各类数据:安装、操作步骤与实用指南
  • 【折线图 Line】——1
  • SpringBoot 整合mongoDB并自定义连接池,实现多数据源配置
  • TCP/IP的分层结构、各层的典型协议,以及与ISO七层模型的差别
  • FreeRTOS-中断管理
  • ShenNiusModularity项目源码学习(15:ShenNius.Admin.API项目分析)
  • Express + MongoDB 实现文件上传
  • 计算机毕业设计SpringBoot+Vue.js作业管理系统(源码+文档+PPT+讲解)
  • Odoo免费开源CRM技术实战:从商机线索关联转化为售后工单的应用
  • 2025年如何实现安卓、iOS、鸿蒙跨平台开发
  • 萌新学 Python 之 os 模块
  • IPoIB源码深度解析:如何基于TCP/IP协议栈实现高性能InfiniBand通信
  • 本地部署阿里万象2.1文生视频模型(Wan2.1-T2V)完全指南
  • information_schema.processlist 表详解
  • P8623 [蓝桥杯 2015 省 B] 移动距离
  • 2025年Linux主力系统选择指南:基于最新生态的深度解析(附2025年发行版对比速查表)
  • [密码学实战]Java实现国密(SM2)密钥协商详解:原理、代码与实践
  • 015--基于STM32F103ZET6的智能风扇设计
  • 基于YOLO11深度学习的遥感视角农田检测与分割系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分割、人工智能
  • RBF神经网络+NSGAII多目标优化算法,工艺参数优化、工程设计优化(Matlab)
  • Zookeeper(79)如何进行Zookeeper的监控?
  • 运动想象 (MI) 分类学习系列 (17) : CCSM-FT
  • start DL from stratch (2)!!!
  • 【深入浅出:Core-JS Legacy 的降级兼容指南】
  • 通义灵码插件安装入门教学 - IDEA(安装篇)
  • STM32之时钟树
  • Unity插件-Mirror使用方法(一)Mirror介绍