0

0

使用Matplotlib动画显示粒子云随时间演化

花韻仙語

花韻仙語

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

|

464人浏览过

|

来源于php中文网

原创

使用matplotlib动画显示粒子云随时间演化

本文档旨在指导读者如何使用 Matplotlib 库创建动画,以显示粒子云在模拟过程中随时间演化的状态,而不是追踪单个粒子的轨迹。通过修改现有的轨道模拟代码,我们将着重于在每个时间步绘制粒子的瞬时位置,并将其保存为 MP4 视频文件。

修改动画代码

原始代码绘制了粒子的轨道,而我们的目标是在每个时间步仅显示粒子的位置,形成一个动态的粒子云。为了实现这一点,我们需要修改 orbit_animation.py 文件中的 cloud_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 设置导致动画非常卡顿。 为了获得更流畅的动画,我们需要减小这个值。 将 interval 设置为 50,相当于每秒 20 帧 (fps),可以显著提高动画的流畅度。

在 animate_orbits 函数中,找到以下代码:

造梦阁AI
造梦阁AI

AI小说推文一键成片,你的故事值得被看见

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

确保 interval 参数设置为一个较小的值,例如 50。

保存动画为 MP4 文件

Matplotlib 提供了将动画保存为视频文件的功能。 为了将动画保存为 MP4 文件,只需在 animation.save() 函数中指定一个以 .mp4 结尾的文件路径即可。

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

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

这里,"particle_cloud.mp4" 是保存动画的文件名,fps=20 设置视频的帧率为每秒 20 帧,与动画的播放帧率保持一致。

完整示例代码

以下是修改后的 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=50):

    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=interval, blit=True)
    animation.save("particle_cloud.mp4", fps=20)
    plt.show()

注意事项

  • 确保安装了 Matplotlib 和 NumPy 库。
  • 调整 interval 和 fps 参数以获得最佳的动画效果。
  • 根据模拟数据的范围,可能需要调整坐标轴的范围。
  • 可以尝试不同的 marker 样式来改变粒子云的外观。

总结

通过修改 Matplotlib 动画代码,我们可以轻松地将粒子轨道模拟转换为粒子云动画,从而更直观地展示模拟结果。 通过调整帧率和保存动画为 MP4 文件,可以方便地分享和展示模拟结果。 这种方法适用于各种类型的粒子模拟,例如分子动力学模拟、星系演化模拟等。

相关标签:

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

相关专题

更多
Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

2

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

13

2026.01.21

Python多线程合集
Python多线程合集

本专题整合了Python多线程相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.21

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

2

2026.01.21

windows激活码分享 windows一键激活教程指南
windows激活码分享 windows一键激活教程指南

Windows 10/11一键激活可以通过PowerShell脚本或KMS工具实现永久或长期激活。最推荐的简便方法是打开PowerShell(管理员),运行 irm https://get.activated.win | iex 脚本,按提示选择数字激活(选项1)。其他方法包括使用HEU KMS Activator工具进行智能激活。

2

2026.01.21

excel表格操作技巧大全 表格制作excel教程
excel表格操作技巧大全 表格制作excel教程

Excel表格操作的核心技巧在于 熟练使用快捷键、数据处理函数及视图工具,如Ctrl+C/V(复制粘贴)、Alt+=(自动求和)、条件格式、数据验证及数据透视表。掌握这些可大幅提升数据分析与办公效率,实现快速录入、查找、筛选和汇总。

6

2026.01.21

毒蘑菇显卡测试网站入口 毒蘑菇测试官网volumeshader_bm
毒蘑菇显卡测试网站入口 毒蘑菇测试官网volumeshader_bm

毒蘑菇VOLUMESHADER_BM测试网站网址为https://toolwa.com/vsbm/,该平台基于WebGL技术通过渲染高复杂度三维分形图形评估设备图形处理能力,用户可通过拖动彩色物体观察画面流畅度判断GPU与CPU协同性能;测试兼容多种设备,但中低端手机易卡顿或崩溃,高端机型可能因发热降频影响表现,桌面端需启用独立显卡并使用支持WebGL的主流浏览器以确保准确结果

12

2026.01.21

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

7

2026.01.21

热门下载

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

精品课程

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

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