0

0

如何使用 Matplotlib 动画模拟粒子云运动

聖光之護

聖光之護

发布时间:2025-09-05 19:06:01

|

765人浏览过

|

来源于php中文网

原创

如何使用 matplotlib 动画模拟粒子云运动

本文将指导你如何使用 Matplotlib 库创建粒子云动画,展示粒子在每个时间步的运动状态,而不是追踪它们的轨道。我们将修改现有的轨道模拟代码,使其能够以更直观的方式可视化粒子运动,并最终将动画保存为 MP4 格式。

修改动画代码以显示粒子云

原始代码绘制的是粒子的轨道,为了只显示每个时间步的粒子位置,我们需要修改 orbit_animation.py 文件中的 animate_orbits 函数。关键在于修改 ax.plot 的参数。

将以下代码:

cloud_plot, = ax.plot([], [], [], label='Cloud Particles')

修改为:

cloud_plot, = ax.plot([], [], [], linestyle="none", marker='o', label='Cloud Particles')

这里,linestyle="none" 移除了连接粒子的线条,而 marker='o' 使用圆形标记来表示每个粒子。

调整动画帧率

原始代码中 interval=500 导致动画非常卡顿,这意味着每帧之间有 500 毫秒的延迟,相当于 0.5 帧每秒 (fps)。为了获得更流畅的动画,需要减小这个值。建议将 interval 设置为 50,相当于 20 fps。

在 FuncAnimation 函数调用中进行修改:

巨蟹星云网上商城
巨蟹星云网上商城

一套自助创建网上商店的软件系统,具有界面变幻多彩、功能强大,使用傻瓜化、运行自动化的特点,任何人基本上不用学习,都能快速创建自己的网上商店,用这套系统做一个购物网站,就象做填空题一样容易。采用「巨蟹星云」可以建立诸如:网上花店、网上化妆品店、网上服装店、网上书店、网上点卡店、网上成人用品店、网上玩具店、网上书店、网上手机店、网上数码产品销售店、网上保健品店、网上玩具店、网上车模店、网上音像制品店等

下载
animation = FuncAnimation(fig, update, frames=pos.shape[1], interval=interval, blit=True)

修改为:

animation = FuncAnimation(fig, update, frames=pos.shape[1], interval=50, blit=True)

保存动画为 MP4 文件

Matplotlib 的 FuncAnimation 对象提供了 save 方法,可以方便地将动画保存为多种格式,包括 MP4。只需要将文件路径指定为 .mp4 扩展名即可。

在 orbit_animation.py 文件的末尾添加以下代码:

animation.save("particle_cloud.mp4", fps=20)

这里,"particle_cloud.mp4" 是保存的文件名,fps=20 设置了视频的帧率为 20 fps,与动画的帧率保持一致,以获得最佳效果。

完整修改后的 orbit_animation.py 代码

# orbit_animation.py

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from matplotlib.animation import FuncAnimation

def animate_orbits(pos, intervals=1000000, interval=500):

    fig = plt.figure(figsize=(8, 8))
    ax = fig.add_subplot(111, projection='3d')

    # Scatter plot for Sgr A*
    sgr_a_plot = ax.scatter([0], [0], [0], color='black', marker='o', s=50, label='Sgr A*')

    # Initialize an empty line for the cloud particles
    cloud_plot, = ax.plot([], [], [], linestyle="none", marker='o', label='Cloud Particles')

    # Set plot labels and title
    ax.set_xlabel('X (km)')
    ax.set_ylabel('Y (km)')
    ax.set_zlabel('Z (km)')
    ax.legend(loc='upper right', bbox_to_anchor=(1.1, 1.1))
    ax.set_title('Cloud Particles around Sgr A*')

    # Initialize axis limits
    x_min, x_max = np.min(pos[:, :, 0]), np.max(pos[:, :, 0])
    y_min, y_max = np.min(pos[:, :, 1]), np.max(pos[:, :, 1])
    z_min, z_max = np.min(pos[:, :, 2]), np.max(pos[:, :, 2])

    # Animation update function
    def update(frame):
        # Update Sgr A* position
        sgr_a_plot._offsets3d = ([0], [0], [0])

        # Update cloud particles
        cloud_plot.set_data(pos[:, frame, 0], pos[:, frame, 1])
        cloud_plot.set_3d_properties(pos[:, frame, 2])

        # Update axis limits dynamically
        x_min, x_max = np.min(pos[:, :, 0]), np.max(pos[:, :, 0])
        y_min, y_max = np.min(pos[:, :, 1]), np.max(pos[:, :, 1])
        z_min, z_max = np.min(pos[:, :, 2]), np.max(pos[:, :, 2])

        ax.set_xlim(x_min, x_max)
        ax.set_ylim(y_min, y_max)
        ax.set_zlim(z_min, z_max)

        return sgr_a_plot, cloud_plot

    # Create the animation
    animation = FuncAnimation(fig, update, frames=pos.shape[1], interval=50, blit=True)
    plt.show()
    animation.save("particle_cloud.mp4", fps=20)

总结

通过以上步骤,你就可以成功地将轨道模拟动画修改为粒子云动画,并将其保存为 MP4 格式。关键在于理解 ax.plot 函数的参数,以及 FuncAnimation 对象的 interval 和 save 方法。 请记住,根据你的模拟数据和期望的视觉效果,可能需要进一步调整动画的帧率和保存设置。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

4

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号