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函数画出地球和月球。

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

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

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

效果

相关推荐
机器学习之心1 小时前
风速预测 | 基于MATLAB的无迹卡尔曼滤波算法UKF、SVR-UKF、ANN-Kalman等时间序列风速预测模型
人工智能·算法·matlab
神经网络与智能优化算法探索4 小时前
MATLAB-DBO-CNN-SVM,基于DBO蜣螂优化算法优化卷积神经网络CNN结合支持向量机SVM数据分类(多特征输入多分类)
算法·matlab·cnn
IT猿手6 小时前
2024最新算法:吸血水蛭优化器(Blood-Sucking Leech Optimizer,BSLO)求解23个函数,MATLAB代码
开发语言·算法·matlab·优化算法·最新算法
weixin_430153386 小时前
Stateflow快速入门系列(-):构造并运行 Stateflow 图
matlab
电科_银尘19 小时前
【Matlab】-- BP反向传播算法
开发语言·人工智能·算法·matlab
算法如诗1 天前
【无人机三维路径规划】基于鱼鹰算法OOA实现复杂城市地形下无人机避障三维航迹规划附Matlab代码
算法·matlab·无人机
顶呱呱程序1 天前
2-7 基于matlab实现声纹识别
matlab·声纹识别·mfcc特征
算法如诗1 天前
数据生成 | Matlab实现基于SNN浅层神经网络的数据生成
开发语言·神经网络·matlab
沿街2 天前
基于matlab的不同边缘检测算子的边缘检测
图像处理·计算机视觉·matlab
古-月2 天前
【Tello无人机】使用Matlab完成控制器的设计—建模
开发语言·matlab·无人机