几天前就编好了程序,一直没顾上上传。 (1)求猎狗最小速度的问题:理论分析请参考下述文献:钱杏芳,导d飞行力学,北理工出版社,20008p97,式4-11追踪法,从开始到命中目标所需时间为 tk=r0(p+cos(q0))/((p^-1)Vt)取基准线平行于兔子运动方向,则q0=-pi/2,cos(q0)=0,所以 tk=r0/Vtp/(p^2-1)所需最小速度即为,兔子刚好在tk时间内跑到A点,即求解下面的方程: s =r0p/(p^2-1)其中s=120为OA长度,r0=200为OB长度。解出p(注意取正数解)再乘以兔子速度即可。r0 = 200;Vt = 8;% 兔子移动的距离s = 120;% (1)猎狗最小速度% 钱杏芳,导d飞行力学,北理工出版社,20008% p97,式4-11% 追踪法,从开始到命中目标所需时间为% tk = r0 ( p + cos(q0) ) / ( ( p^-1 ) Vt )% 取基准线平行于兔子运动方向,则q0=-pi/2,cos(q0)=0,所以% tk = r0/Vt p/(p^2-1)syms pp = solve( s - r0 p/(p^2-1) );p = double(p);p = p(p>=0);V = Vt p答案为V = 170803 (2)猎狗跑过的时间和路程由上一步的结果很容易求出:tk = r0/Vt p/(p^2-1)S = V tk答案为tk = 150000S = 2562050 (3)画出猎狗奔跑的曲线图可以用ode45求解,需要注意适当减小求解器的误差控制参数RelTol和AbsTol。代码在下一步统一给出。(4)这一步的要求已经很难通过理论分析来做了。可以用数值方法解微分方程,但所涉及的问题对于一般的初学者应该是比较难以处理的。我把主要涉及的问题尽量提到,但不会详细讲解。题主既自称“小白”,就请不要就这个问题问太多了,否则讲太繁琐了。 主要涉及到的问题:a、速度是变化的,需要把两个速度也作为状态变量,相应增加两个微分方程。b、需要设置结束事件,让猎狗追到兔子后就停止仿真。c、此处特别需要减小求解器的误差控制参数RelTol和AbsTol,否则在猎狗接近兔子时,相对方位几乎成了随机数,最后的一段时间差不多在做布朗运动了。d、程序采用嵌套函数的结构,以方便函数间共享几个相关的变量。 参考代码:function dog_chase_rabbitr0 = 200;Vt = 8;% 兔子移动的距离s = 120;% (1)猎狗最小速度syms pp = solve( s - r0 p/(p^2-1) );p = double(p);p = p(p>=0);V = Vt p% (2)猎狗跑过的时间和路程tk = r0/Vt p/(p^2-1)S = V tk% (3)曲线图psi1 = pi / 4;psi2 = pi 3 / 4;X0 = [r0cos(psi1+pi); r0sin(psi1+pi); 0; 0];opt = odeset('reltol',1e-6,'abstol',1e-7);[t,X] = ode45(@chase, [0 tk], X0,opt);plot_res(1) function dX = chase(t, X) % X(1,2) - x1 y1 x1 = X(1); y1 = X(2); x2 = X(3); y2 = X(4); Q = atan2(y2-y1, x2-x1); dX = [ V cos(Q); V sin(Q); Vt cos(psi2); Vt sin(psi2) ]; end function plot_res(i) figure(i) clf hold on plot(scos(psi2),ssin(psi2),'go') text(scos(psi2),ssin(psi2),'A ','Horiz','right','color','g') plot(X0(1),X0(2),'rv') text(X0(1),X0(2),'B ','Horiz','right','color','r') plot(X0(3),X0(4),'b>') text(X0(3),X0(4),' O','Horiz','left','Vert','top','color','b') plot(X(:,1),X(:,2),'r-',X(:,3),X(:,4),'b--') axis equal off plot([0 0],ylim,'k') plot(xlim,[0 0],'k') end% (4)如果距离为30米时,兔子速度每秒减半,猎狗速度每秒增加11倍% 此时应考虑把两个速度也作为状态变量,并且设置结束事件X0 = [r0cos(psi1+pi); r0sin(psi1+pi); 0; 0; V; Vt];opt = odeset('reltol',1e-6,'abstol',1e-7,'Events',@events);[t,X] = ode45(@chase2, [0 tk], X0,opt);plot_res(2)S = sum(sqrt(diff(X(:,1))^2+diff(X(:,2))^2))tk = t(end)figure(3)plot(t,X(:,5:6))legend('猎狗速度','兔子速度',0) function dX = chase2(t, X) % 提取状态变量 x1 = X(1); y1 = X(2); x2 = X(3); y2 = X(4); V = X(5); Vt = X(6); Q = atan2(y2-y1, x2-x1); % 考虑速度变化 d = sqrt((x2-x1)^2+(y2-y1)^2); dV = 01 V (d <= 30); dVt = -05 Vt (d <= 30); % 微分方程 dX = [ V cos(Q); V sin(Q); Vt cos(psi2); Vt sin(psi2); dV; dVt ]; end function [value,isterminal,direction] = events(t,X) % 距离小于0001时结束仿真 value = sqrt((X(3)-X(1))^2+(X(4)-X(2))^2) - 1e-3; isterminal = 1; direction = -1; endend
加密过程为:C=Ek3(Dk2(Ek1(P)))
3DES解密过程为:P=Dk1((EK2(Dk3(C)))
具体的加/解密过程如图2所示。K1、K2、K3决定了算法的安全性,若三个密钥互不相同,本质上就相当于用一个长为168位的密钥进行加密。多年来,它在对付强力攻击时是比较安全的。若数据对安全性要求不那么高,K1可以等于K3。在这种情况下,密钥的有效长度为112位。
1、首先选取密匙并去除重复字符。
2、其次设置密匙,密钥共有10个单词,从第11个字符开始,用universty按顺序进行代替配置。
3、最后将其余17个字母按自然顺序排列即可。
1、题目:
把1-10的整数,先判断是否为偶数,并计算它们的和,最后做一下验证
2、程序:
clc;clear;
sum0=0;
for
i=1:10
%循环
if(mod(i,2)==0)%分支
sum0=sum0+i;
end
end
%检测
test_data=[2:2:10];%顺序
test=sum(test_data);
[sum0
test]
3、运行结果:
ans
=
30
30
matlab设置的密码格式要求是英文大小写和数字组成的密码,一般密码为8—20位数字
MATLAB是美国MathWorks公司出品的商业数学软件,用于数据分析、无线通信、深度学习、图像处理与计算机觉、信号处理、量化金融与风险管理、机器人,控制系统等领域。
MATLAB是matrix&laboratory两个词的合,意为矩阵工厂(矩阵实验室),软件主要面对科学计算、可视化以及交互式程序设计的高科技计算环境。
以上就是关于大神指点,我在matlab中设计一个登录界面,但是我想设计密码和用户名,全部的内容,包括:大神指点,我在matlab中设计一个登录界面,但是我想设计密码和用户名,、懂MATLAB和AES加密算法的高手来帮我!怎么用MATLAB语言编程AES加密算法、matlab如何设置口令等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)