Matlab做一个刚体运动仿真,模拟小车避障

由于老师要求不用实现太复杂,自己也没花太多时间,就简单模拟小车(刚体)撞墙自动转弯,效果如下:

核心代码如下,还有几个是前后左右转动的子代码。

clear all;
clc;
close all;
%构造刚体
x=[0 10 -10 0 0];
 y=[10 -10 -10 10 0];
 fill(x,y,'b')
 hold on;
 %画布大小
 axis([-200,200,-200,200])
 g=[x;y];
 %规定运行区域
 center_x = -150;
 center_y = -150;
 center_width = 300;
 center_high = 300;
 rectangle('Position',[center_x,center_y,center_high,center_width],'Curvature', [0 0], 'edgecolor','r')
 right_flag = 0;
 left_flag = 0;
 go_up =1;
 go_flag = 1;
 go_down =0;
 
  for i = 0:1:500
      if(go_up == 1)
          g = go_ahead(g,0,1);
          pause(0.05);
          fill(g(1,:),g(2,:),'b');
      end;
      if(go_down == 1)
          g = go_ahead(g,0,-1);
          pause(0.05);
          fill(g(1,:),g(2,:),'b'); 
      end;
      if(left_flag == 1)
          g = go_ahead(g,-1,0);
          pause(0.05);
          fill(g(1,:),g(2,:),'b');
      end;
      if(right_flag == 1)
         
          g = go_ahead(g,1,0);
          pause(0.05);
          fill(g(1,:),g(2,:),'b'); 
      end;
      %向上走碰到边界左转
      if((go_up == 1) && (150 - g(2,5))<11)
          g = left(g);
          left_flag = 1;
          go_down =0;
          right_flag = 0;
          go_up = 0;
      end;
        %向左走碰到边界左转,向下走
      if((left_flag == 1) && (150-g(2,5))<11 && (g(1,5)+150)<11)
          g = left(g);
          left_flag = 0;
          go_down =1;
          right_flag = 0;
          go_up = 0;
      end;
      %向下走碰到边界左转,向右走
      if((go_down == 1) && (g(2,5)+150)<11 && (g(1,5)+150)<11)
           g = left(g);
          left_flag = 0;
          go_down =0;
          right_flag = 1;
          go_up = 0;
      end;
      %向右走碰到边界左转,向上走
       if((right_flag == 1) && (g(2,5)+150)<11 && (150-g(1,5))<11)
          g = left(g);
          left_flag = 0;
          go_down =0;
          right_flag = 0;
          go_up = 1;
      end;
  end;
          
 
  • 7
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
MATLAB中,可以使用旋转矩阵来实现三维空间的刚体运动。旋转矩阵是一种正交矩阵,它可以保持长度、角度、面积等特征不变的仿射变换,即内积和度量不变。旋转矩阵的逆等于它的转置,同时行列式的值为正负1。 在MATLAB中,可以使用makehgtform函数来创建旋转矩阵。例如,如果给定一个单位向量normal和旋转角度theta,可以使用下面的代码创建旋转矩阵Matrix_Rot: theta=acos(costheta); Matrix_Rot=makehgtform('axisrotate',normal,theta); 其中,normal是旋转轴的单位向量,theta是旋转角度。这样,Matrix_Rot就是表示刚体运动的旋转矩阵。 更多关于旋转矩阵的信息,可以参考维基百科的页面和博客文章。关于MATLAB中的刚体运动和旋转矩阵的应用,还可以参考博客文章。 总结起来,MATLAB中的三维空间刚体运动可以通过旋转矩阵来实现,旋转矩阵是一种正交矩阵,它可以保持长度、角度、面积等特征不变的仿射变换。在MATLAB中,可以使用makehgtform函数来创建旋转矩阵。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [3D视觉(三)刚体运动matlab实现](https://blog.csdn.net/piaoxuezhong/article/details/78524498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值