Matlab学习(追击走私船问题(包括动态显示其图像)和最小二乘法直线拟合)

本文主要是介绍Matlab学习(追击走私船问题(包括动态显示其图像)和最小二乘法直线拟合),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 追击走私船题目
    • 代码及其详解
      • 实现效果
  • 最小二乘法直线拟合题目
    • 代码及其详解
      • 实现效果

追击走私船题目

在这里插入图片描述 2.将曲线画为动态曲线

代码及其详解

%Ships pursuit
clc
clear
x0=zeros(1,1);y0=zeros(1,1);    %违法船只初始位置
x1=zeros(1,1);y1=zeros(1,1);    %值法船只初始位置
dt=0.01;               %离散化时间,时间变成一个很小的间隔
v0=30;v1=40;           %违法船只和执法船只的初始速度
x1(1,1)=20;            %初始化执法船只的初始位置
i=1;
while abs(x0(1,i)-x1(1,i)) > 1e-4   %当两者的距离小于极小值,代表追上了d=sqrt((x1(1,i)-x0(1,i))^2+(y1(1,i)-y0(1,i))^2);%两船之间的距离cosx=(x1(1,i)-x0(1,i))/d;        %两船连线与x轴的余弦sinx=(y0(1,i)-y1(1,i))/d;        %两船连线与x轴的正弦x0(1,1+i)=0;                     %更新一次数据,违法船只x不变y0(1,1+i)=y0(1,i)+v0*dt;         %违法船只y经过t后,y1=y0+vtx1(1,1+i)=x1(1,i)-v1*dt*cosx;    %执法船只朝着违法船只运动就是把xy分解,然后按照cos sin运动y1(1,1+i)=y1(1,i)+v1*dt*sinx;plot(x0(1,i),y0(1,i),'go',x1(1,i),y1(1,i),'ro')%go ro代表了绿色和红色hold on    %保持图像,让图像不被刷新xlim([0 50])
ylim([-55 79])%x y轴上限限制,也就是让最后显示图像出现的范围pause(0.1)%延时函数 让图像延时0.1s再进行i=i+1;    %点数加1
end
d1 = sqrt((x1(1,i)-x1(1,1))^2+(y1(1,i)-y1(1,1))^2)
t = dt*i %单位小时

动态曲线代码

%Ships pursuit
clc
clear
x0=zeros(1,1);y0=zeros(1,1);    %违法船只初始位置
x1=zeros(1,1);y1=zeros(1,1);    %值法船只初始位置
dt=0.01;               %离散化时间,时间变成一个很小的间隔
v0=30;v1=40;           %违法船只和执法船只的初始速度
x1(1,1)=20;            %初始化执法船只的初始位置
i=1;
writerObj = VideoWriter('Pursuit.avi')      %写入文件
open(writerObj)         %打开文件
while abs(x0(1,i)-x1(1,i)) > 1e-4   %当两者的距离小于极小值,代表追上了xlabel('东')ylabel('北')d=sqrt((x1(1,i)-x0(1,i))^2+(y1(1,i)-y0(1,i))^2);%两船之间的距离cosx=(x1(1,i)-x0(1,i))/d;        %两船连线与x轴的余弦sinx=(y0(1,i)-y1(1,i))/d;        %两船连线与x轴的正弦x0(1,1+i)=0;                     %更新一次数据,违法船只x不变y0(1,1+i)=y0(1,i)+v0*dt;         %违法船只y经过t后,y1=y0+vtx1(1,1+i)=x1(1,i)-v1*dt*cosx;    %执法船只朝着违法船只运动就是把xy分解,然后按照cos sin运动y1(1,1+i)=y1(1,i)+v1*dt*sinx;plot(x0(1,i),y0(1,i),'go',x1(1,i),y1(1,i),'ro')%go ro代表了绿色和红色axis([-10,50,-55,79])            %设置座标的xmin xmax ymin ymaxframe = getframe                 %获得一帧图像writeVideo(writerObj,frame)      %把这一帧显示到图像里面hold off    %保持图像,让图像不被刷新%如果把这里改为hold on 那么轨迹路线也会显示出来pause(0.1)%延时函数 让图像延时0.1s再进行i=i+1;    %点数加1
end
xlim([-10 50])
ylim([-55 79])%x y轴上限限制,也就是让最后显示图像出现的范围
d1 = sqrt((x1(1,i)-x1(1,1))^2+(y1(1,i)-y1(1,1))^2)
t = dt*i %单位小时

实现效果

在这里插入图片描述

最小二乘法直线拟合题目

在这里插入图片描述

代码及其详解

clc
clear
x = [1.3, 2.0, 3.6, 4.2, 5.3, 6.6, 7.8, 8.3, 9.1, 10.2];
y = [1.2, 3.2, 5.9, 6.5, 10.3, 11.2, 13.0, 14.6, 16.9, 18.3];
plot(x,y,'s')
a1 = polyfit(x,y,1);    % n=1 x一次拟合
%polyfit用来拟合散点图
x1 = [1.0:0.1:11.0];    %x的取值范围
y1 = a1(1)*x1 + a1(2);  %y的数值
%polyfit的1次拟合的第一个数据是斜率 第二个数据是常数
plot(x,y,'*')
hold on
plot(x1,y1,'ro')
k = a1(1)
b = a1(2)

实现效果

在这里插入图片描述

这篇关于Matlab学习(追击走私船问题(包括动态显示其图像)和最小二乘法直线拟合)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/328624

相关文章

解决Failed to get nested archive for entry BOOT-INF/lib/xxx.jar问题

《解决FailedtogetnestedarchiveforentryBOOT-INF/lib/xxx.jar问题》解决BOOT-INF/lib/xxx.jar替换异常需确保路径正确:解... 目录Failed to get nested archive for entry BOOT-INF/lib/xxx

解决hive启动时java.net.ConnectException:拒绝连接的问题

《解决hive启动时java.net.ConnectException:拒绝连接的问题》Hadoop集群连接被拒,需检查集群是否启动、关闭防火墙/SELinux、确认安全模式退出,若问题仍存,查看日志... 目录错误发生原因解决方式1.关闭防火墙2.关闭selinux3.启动集群4.检查集群是否正常启动5.

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对