matlab演示地月碰撞

代码

matlab 复制代码
function EarthMoonCollisionSimulation()
    % 初始化参数
    earth_radius = 6371; % 地球半径,单位:公里
    moon_radius = 1737;  % 月球半径,单位:公里
    distance = 384400;   % 地月距离,单位:公里
    collision_time = 50; % 碰撞所需时间,单位:秒
    time_steps = 100;    % 时间步数

    % 初始化位置
    earth_position = [0, 0];
    moon_position = [distance, 0];

    % 初始化图形
    figure;
    hold on;
    axis equal;
    xlim([-distance, distance]);
    ylim([-distance/2, distance/2]);
    xlabel('X (km)');
    ylabel('Y (km)');
    title('Earth-Moon Collision Simulation');

    % 画地球和月球
    earth = rectangle('Position', [earth_position - earth_radius, 2*earth_radius, 2*earth_radius], 'Curvature', [1, 1], 'FaceColor', 'b');
    moon = rectangle('Position', [moon_position - moon_radius, 2*moon_radius, 2*moon_radius], 'Curvature', [1, 1], 'FaceColor', 'k');

    % 模拟运动
    for t = 1:time_steps
        % 计算当前时间的位移
        current_time = t / time_steps * collision_time;
        displacement = (distance / collision_time) * current_time;

        % 更新月球位置
        new_moon_position = [distance - displacement, 0];

        % 更新图形
        set(moon, 'Position', [new_moon_position - moon_radius, 2*moon_radius, 2*moon_radius]);

        % 暂停以创建动画效果
        pause(0.05);
    end

    % 显示碰撞结束
    title('Collision Occurred');
    hold off;
end

说明

初始化参数:设置地球和月球的半径、地月距离、碰撞所需时间和时间步数。

初始化位置:设置地球和月球的初始位置。

初始化图形:创建一个图形窗口,并设置坐标轴和标题。

画地球和月球:使用rectangle函数画出地球和月球。

模拟运动:通过循环更新月球的位置,模拟地月碰撞的过程。

更新图形:在每个时间步中更新月球的位置,并暂停一段时间以创建动画效果。

显示碰撞结束:在碰撞结束时,更新标题以显示碰撞已发生

效果

相关推荐
机器学习之心10 小时前
MATLAB基于改进云物元的模拟机协同训练质量评价
matlab·改进云物元
ytttr87310 小时前
MATLAB实现经验模态分解(EMD)与希尔伯特变换获取能量谱
人工智能·python·matlab
t1987512812 小时前
基于多假设跟踪(MHT)算法的MATLAB实现
开发语言·matlab
机器学习之心15 小时前
MATLAB多子种群混沌自适应哈里斯鹰算法优化BP神经网络回归预测
神经网络·算法·matlab
π同学19 小时前
基于Matlab的递推最小二乘法参数估计
matlab·最小二乘法
小喵要摸鱼1 天前
【MATLBA】使用教程
matlab
listhi5201 天前
基于空时阵列最佳旋转角度的卫星导航抗干扰信号处理的完整MATLAB仿真
开发语言·matlab·信号处理
88号技师1 天前
2025年7月一区SCI优化算法-Logistic-Gauss Circle optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
yugi9878382 天前
基于MATLAB的心电信号去噪
开发语言·matlab
gihigo19982 天前
MATLAB使用遗传算法解决车间资源分配动态调度问题
算法·matlab