基于python的三维装箱可视化

背景介绍

本文主要介绍两种基于python的三维装箱可视化能力,第一种是基于mpl_toolkits的静态三维可视化代码,另外一种是基于matplotlib的动态可视化代码。

mpl_toolkits实现

Axes3D简介

mpl_toolkits 是 matplotlib 库的一个模块集合,它包含了多个为 matplotlib 增加额外功能的工具包。这些工具包提供了扩展 matplotlib 标准功能的方法,允许用户绘制高级图表,以及为图表添加特别的特征和样式。

Axes3D 是 mpl_toolkits.mplot3d 模块中的一个类,用于创建和处理三维坐标轴。该类是 matplotlib 中绘制三维图形的核心,它扩展了 matplotlib 的二维绘图库,实现了三维空间中的可视化。与 matplotlib 二维坐标轴的 Axes 类似,Axes3D 提供一系列标准的三维绘图方法。

使用 Axes3D 可以方便地绘制三维散点图、线图、曲面图、线框图和三维条形图等。除了支持基本的三维绘图,Axes3D 还提供了工具来控制视图角度、缩放级别、以及坐标轴的刻度和标签。此外,Axes3D 支持交互性操作,如旋转和缩放,这些功能使得用户能以直观的方式探索三维数据。

代码实现
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3Ddef plot_3d_boxes(positions, sizes, container_size):fig = plt.figure(figsize=[40,10])ax = fig.add_subplot(111, projection='3d')# 根据盒子尺寸选择颜色colors = plt.cm.viridis(np.linspace(0, 1, len(sizes)))for i, (position, size) in enumerate(zip(positions, sizes)):color = colors[i]x, y, z = positiondx, dy, dz = sizeax.bar3d(x, y, z, dx, dy, dz, color=color)# 设置容器尺寸ax.set_box_aspect([container_size[0], container_size[1], container_size[2]])  # 设置显示的长宽高比例ax.set_xlim(0, container_size[0])ax.set_ylim(0, container_size[1])ax.set_zlim(0, container_size[2])# 设置轴标签ax.set_xlabel('X')ax.set_ylabel('Y')ax.set_zlabel('Z')ax.set_xlim([0, container_size[0]])ax.set_ylim([0, container_size[1]])ax.set_zlim([0, container_size[2]])plt.show()# 示例数据
positions = [[0, 0, 0], [3, 5, 0], [6, 8, 0]]
sizes = [[3, 3, 3], [3, 1, 2], [2, 3, 1]]
container_size = [10, 10, 10]# 绘制三维箱子图
plot_3d_boxes(positions, sizes, container_size)
结果展示

在这里插入图片描述

matplotlib实现

FuncAnimation简介

动画是基于FuncAnimation实现的, FuncAnimation是 matplotlib.animation 包中的一个类,它用于创建基于 matplotlib 的动画。该类通过在绘图元素上进行重复的更新和绘制操作,来生成一系列连续的图像帧,并将它们组合成为动画。使用 FuncAnimation,你可以创建帧序列动画,并定义每帧中发生的变化。这使得它适合于演示数据随时间变化的过程,或是根据一些参数的动态变化来展示数据。

代码实现
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation
from matplotlib.widgets import Button# 绘制单个箱子的函数
def draw_single_box(ax, position, size, color):x, y, z = positiondx, dy, dz = sizeax.bar3d(x, y, z, dx, dy, dz, color=color)# 动画更新函数
def update(frame, positions, sizes, colors, ax, container_size, anim_running):# 在更新时检查动画是否应该继续运行if anim_running[0]:ax.cla()  # 清除旧的帧ax.set_xlim(0, container_size[0])ax.set_ylim(0, container_size[1])ax.set_zlim(0, container_size[2])ax.set_xlabel('X')ax.set_ylabel('Y')ax.set_zlabel('Z')for i in range(frame + 1):draw_single_box(ax, positions[i], sizes[i], colors[i % len(colors)])# 暂停和播放的回调函数
def onClickPause(event, anim_running):anim_running[0] = Falsedef onClickPlay(event, anim_running):anim_running[0] = True# 函数执行绘制动画
def animate_boxes(positions, sizes, container_size):fig = plt.figure(figsize=(20, 10))ax = fig.add_subplot(111, projection='3d')colors = plt.cm.viridis(range(len(sizes)))# 初始化用于控制动画运行状态的列表anim_running = [True]# 设置按钮和事件pause_ax = plt.axes((0.81, 0.05, 0.1, 0.075))pause_button = Button(pause_ax, 'Pause')play_ax = plt.axes((0.7, 0.05, 0.1, 0.075))play_button = Button(play_ax, 'Play')# 绑定回调函数时把 anim_running 作为参数传递pause_button.on_clicked(lambda event: onClickPause(event, anim_running))play_button.on_clicked(lambda event: onClickPlay(event, anim_running))# 创建动画anim = FuncAnimation(fig, update, frames=len(sizes),fargs=(positions, sizes, colors, ax, container_size, anim_running),interval=400, repeat=True)plt.show()# 示例数据
positions = [[0, 22, 0], [0, 0, 0], [40, 37, 14]]
sizes = [[36, 36, 36], [59, 39, 20], [54, 40, 21]]
container_size = [100, 100, 100]  # 假设容器尺寸为 100x100x100# 运行动画
animate_boxes(positions, sizes, container_size)

结果展示

展示过程是循环播放的,可以通过点击pause暂停,点击play继续播放。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/29392.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多项目如何管理?盘点十大主流项目管理软件,轻松管理多个项目

多项目同时进行已经成为很多企业的现状,项目经理手握几个项目成为常态。 多项目管理之所以难,不仅在于项目数量的增加,而且在于项目资源分配不均、多项目进度比较难监控、沟通协作纷繁复杂。 应该如何做好进度管理,力求每个项目…

Java8 新特性 记录【持续更新】

目录 一、Stream 相关 1、findFirst 方法 二、Optional 1、如何构造Optional 2、ifPresent 方法 一、Stream 相关 1、findFirst 方法 Stream的findFirst方法在此流中查找第一个元素作为Optional。 如果流中没有元素,findFirst返回空的Optional。 如果流没…

传统办公电脑效率低怎么办?如何解决?

当传统办公电脑效率太低时,可以考虑转向云电脑作为解决方案。云电脑作为一种基于云计算的新型计算模式,具有许多显著的优势,这些优势可以有效提升办公效率和体验。以下是对云电脑优势的详细分析和总结,跟着小编一起来了解一下吧。…

游泳耳机品牌排行榜,10大实力超群的游泳耳机分享!

在当今快节奏的生活中,运动已成为许多人不可或缺的一部分,不仅为了健康,也是释放压力、提升生活品质的有效方式。而随着科技与健身的深度融合,智能穿戴设备尤其是专为运动设计的耳机,正逐渐成为运动爱好者的新宠。对于…

Windows或Nginx上安装/更新SSL证书,步骤详解

一、Windows系统上导入SSL证书 (1)在安装IIS服务器的Windows系统中,单击开始 > 运行 > MMC打开控制台 (2)单击文件 > 添加/删除管理单元,打开添加/删除管理单元对话框 (3&#xff09…

探索IPython的强大功能:全面指南与高效使用技巧

目录 一 IPython简介 什么是IPython? 安装IPython 二 基础功能 交互式计算 自动补全 历史记录 内置调试器 三 魔术命令 常用魔术命令 %time和%timeit %who和%whos %reset %run %load %matplotlib %%writefile 其他有用的魔术命令 四 扩展功能 IPython中的…

后台管理台字典localStorage缓存删除

localStorage里存放了如以下dictItems_开头的字典数据,localStorage缓存是没有过期时间的,需要手动删除。同时localStorage里还存有其他不需要删除的数据。 这里的方案是遍历localStorage,利用正则和所有key进行匹配,匹配到dict…

富格林:可信守则有效防范暗箱

富格林悉知,黄金具有不错的投资价值,一直以来备受投资者的喜爱,近年来大家也纷纷加入现货黄金市场为其增值财富。但是要有效防范暗箱的前提,是需要投资者使用可信合适的守则以及掌握相对应的投资技巧。下面富格林将总结以下技巧&a…

编程软件是由什么编程的

编程软件是由什么编程的 在数字化的世界里,编程软件作为构建数字生态的基石,其背后所蕴含的奥秘往往令人感到困惑。那么,这些编程软件究竟是由什么编程的呢?这背后隐藏着怎样的逻辑与技术?接下来,我们将从…

商业决策支持:Kompas AI为企业决策赋能

一、引言 在商业世界中,决策是企业成功的关键。正确的决策可以引领企业走向繁荣,而错误的决策则可能导致严重的后果。随着大数据和人工智能技术的发展,Kompas AI在商业领域的应用为商业决策提供了强大的支持,帮助企业在复杂多变的…

【需求管理】软件需求开发和管理文档(原件Word)

1. 目的 2. 适用范围 3. 参考文件 4. 术语和缩写 5. 需求获取的方式 5.1. 与用户交谈向用户提问题 5.1.1. 访谈重点注意事项 5.1.2. 访谈指南 5.2. 参观用户的工作流程 5.3. 向用户群体发调查问卷 5.4. 已有软件系统调研 5.5. 资料收集 5.6. 原型系统调研 5.6.1. …

MMDetection3D学习笔记一:环境搭建

文章目录 1 简介2 最佳环境安装实践2.1 配置conda环境2.2 安装相关依赖2.3 安装mmdet3d2.4 验证 3 通过 Docker 使用 MMDetection3D 1 简介 更推荐直接参考学习官方文档以及官方GitHub仓库,其所包含的内容最全面权威。 MMDetection3D是一个基于PyTorch的开源对象检测…

前端可观测性系统建设

一. 背景 随着前端业务的日趋庞大,及时发现和解决业务中的问题、优化用户体验、实时监控业务健康度变得愈发重要。在业务层面,我们希望能够监控每次发布版本后,核心功能是否有显著提升或至少没有负面影响,核心接口是否正常运作&a…

鸿蒙原生App开发之:套用混合app开发思路

2024年,似乎华为迎来了新的企业机遇--鸿蒙独立操作系统。 受到全球国际形势的影响,加之第四次科技革命(AI革命)冷不丁的出现,在他国AI技术领先的前提下,中国自主研发的独立操作系统再次提上新的战略高度。…

网站的用户留言信息有什么意义

用户在网站上面留言一般都是因为反馈问题或者有什么需求,网站可以通过收集这些用户的留言更够够好的不断优化网站服务用户需求,也可以通过这种方式加强平台与用户的友好关系,有些好心的用户突然发现网站有什么问题,发现哪里不对了…

机器阅读理解技术在电网检修问答系统中的应用与创新

在当今快速发展的人工智能领域,机器阅读理解技术正逐渐成为提升行业工作效率的关键因素。本文将探讨思通数科大模型中的检修问答系统,这一系统通过先进的机器阅读理解技术,优化了电网维修工作的流程和效率。 一、机器阅读理解技术概述 机器…

构建高并发Web应用:基于Gunicorn、Flask和Docker的部署指南

目录 一 理解基础组件 什么是Flask? 什么是Gunicorn? 什么是Docker? 二 环境准备 三 构建Flask应用 创建项目结构 编写Flask应用 app/views.py 四 使用Gunicorn部署Flask应用 配置Gunicorn Gunicorn配置文件 五 使用Docker进行容器化部署 编写Dockerfile 构建…

【C++11】深入剖析lambda仿函数的原理,自己动手实现std::function容器

文章目录 参考 参考 【C11】深入剖析lambda仿函数的原理,自己动手实现std::function容器实现自定义的Function

UDS诊断、ECU刷写、OTA升级、Tbox测试、CANoe实操

每天的直播时间: 周一至周五:20:00-23:00 周六与周日:9:00-12:00,14:00-17:00 TBOX 深圳 涉及过T-BOX测试吗Ota升级涉及的台架环境是什么样的?上…

高通Android 12/13 Launcher3修改RecentView与屏幕方向保持一致

1、背景: 最近同事遇到一个需求说,recentview应用预览与屏幕方向不一致问题,于是加了一些系统日志,实现此需求。简单记录下哈。 源码修改路径汇总如下 packages/apps/Launcher3/quickstep/src/com/android/quickstep/util/Recen…