基于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,一经查实,立即删除!

相关文章

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

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

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

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

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

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

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

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

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

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

商业决策支持: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. …

前端可观测性系统建设

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

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

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

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

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

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

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

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

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

2024年退休金上调3%后一个扎心的现实。。。

个人原创,手写码字1050 你好,我是郭震 今天正式宣布,退休养老金上调3%: 1 现状分析 我对此做一些分析,从数据中帮助老铁们看清一些事实。 根据去年数据,农村老人1.2亿: 去年数据显示&#xff0c…

扭蛋机小程序:深度探索虚拟寻宝之旅的乐趣

引言 扭蛋机小程序,这个融合了传统与创新的虚拟寻宝乐园,已经吸引了无数玩家的目光。在这个充满惊喜和挑战的虚拟世界里,每一个扭蛋都可能蕴藏着无尽的宝藏。本文将带您深入探索扭蛋机小程序的魅力所在,体验一场别开生面的虚拟寻…

端开发技术——Flutter富文本组件

简介 flutter 富文本组件。 github地址: https://github.com/ThinkerJack/jac_uikit 使用方式 运行 flutter pub add jac_uikit组件文档 使用方式: HighlightedTextWidget.builder(text: "全部文案包含高亮文案测试用",highlights: [Hig…

企业常用的五大源代码加密软件

安秉源代码加密软件: 专注于源代码文件的加密,对编译后的文件不加密。 采用版本管理服务器密文保存方式,不影响员工正常开发流程。 有效防止代码从版本管理服务器下载和上传到私有仓库。 适用于企业环境,保护源代码不被泄露。EXEC…

【机器学习】CART决策树算法的核心思想及其大数据时代银行贷款参考案例——机器认知外界的重要算法

目录 引言 概述 CART决策树的特点 核心思想 减少不确定性的指标 基尼系数(Gini Index) 分类错误率 熵 银行实例 背景 数据准备 模型构建 模型评估与优化 应用与结果 代码示例 ✈✈✈✈引言✈✈✈✈ CART算法既可以用于分类问题&#xff0…

攻防演练“轻装上阵” | 亚信安全信舱ForCloud 打造全栈防护新策略

网络世界攻防实战中,攻击风险已经从代码到云横跨全栈技术点,你准备好了吗 云服务器,攻击众矢之的 2022年超过38万个Kubernetes API服务器暴露公网,成为攻击者目标。云服务器,尤其是开源设施,一直以来不仅是…

Android可穿戴设备世界之旅

人不走空 🌈个人主页:人不走空 💖系列专栏:算法专题 ⏰诗词歌赋:斯是陋室,惟吾德馨 介绍 Android通过在电视、穿戴和汽车等各种电子模块中扩展下一代应用开发概念,扩展了其整个范围和可…

vue大作业-实现学校官网

vue大作业-实现学校官网 基于vue2实现的学校官网 项目展示 学校官网介绍 欢迎访问我们学校的官方网站,这里为您提供了全面的信息和资源,帮助您更好地了解我们的教育理念、教学资源和学术活动。 首页 首页是您了解我们学校的起点。这里展示了学校的最…