运动学斜抛物体水平射程+竖直射高matlab源码
Posted MatlabQQ1575304183
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了运动学斜抛物体水平射程+竖直射高matlab源码相关的知识,希望对你有一定的参考价值。
一、简介
说明了斜抛物体在斜坡上的射程计算方法,求出了最大射程与坡度关系,详细讨论了射程与坡度的关系。通过图片显示射程与射角的关系,最大射程与坡度的关系。
二、源代码
%斜抛物体的射程,射高和最高点的分布
clear %清除变量
theta=0:90; %物体射角的度数向量
th=theta*pi/180; %物体射角的弧度数
x=sin(2*th); %水平射程(以最大射程为单位)
y=sin(th).^2/2; %竖直射高(以最大射程为单位)
figure %创建图形窗口
plot(theta,x,theta,y,'--','linewidth',2)%画射程和射高曲线
grid on %加网格
legend('射程\\itX/X\\rm_M','射高\\itY/X\\rm_M')%图例
fs=16; %字体大小
title('斜抛物体的水平射程和竖直射高','FontSize',fs)%标题
xlabel('射角\\it\\theta/\\rm(\\circ)','FontSize',fs)%横坐标标签
text(0,0.5,'\\itX\\rm_M=\\itv\\rm_0^2/\\itg','FontSize',fs)%说明最大射程
theta=15:10:75; %物体射角的度数向量
th=theta*pi/180; %物体射角的弧度数
x=linspace(0,1,40); %水平坐标向量(以最大射程为单位)
[TH,X]=meshgrid(th,x); %水平坐标和角度和矩阵
Y=X.*tan(TH)-X.^2/2./cos(TH).^2; %高度位置矩阵
figure %创建图形窗口
%plot(x,Y,'LineWidth',2) %画斜抛运动曲线族
plot(x,Y(:,1),'o-',x,Y(:,2),'d-',x,Y(:,3),'s-',x,Y(:,4),'p-',...
x,Y(:,5),'h-',x,Y(:,6),'<-',x,Y(:,7),'>-','LineStyle','--')%画斜抛运动曲线族
grid on %加网格
axis equal %使坐标刻度相等
axis([0 1 0 0.5]) %曲线范围
n=length(th); %射角的个数
h=legend([num2str(theta'),repmat('\\circ',n,1)]);%插入角度图例
set(h,'FontSize',fs-2) %放大图例
y0=zeros(size(th)); %落点纵坐标向量
x0=sin(2*th); %落点横坐标向量(射高的横坐标的两倍)
text(x0,y0,num2str(x0',3),'FontSize',fs)%标记射程(保留3位)
ym=sin(th).^2/2; %射高
text(x0/2,ym,num2str(ym',3),'FontSize',fs)%标记射高(保留3位)
hold on %保持图像
三、运行结果
四、备注
以上是关于运动学斜抛物体水平射程+竖直射高matlab源码的主要内容,如果未能解决你的问题,请参考以下文章