人工势场法是局部路径规划的一种比较常用的方法。这种方法假设机器人在一种虚拟力场下运动。

一、简介

如图所示,机器人在一个二维环境下运动,图中指出了机器人,障碍和目标之间的相对位置。 

这个图比较清晰的说明了人工势场法的作用,物体的初始点在一个较高的“山头”上,要到达的目标点在“山脚”下,这就形成了一种势场,物体在这种势的引导下,避开障碍物,到达目标点。

人工势场包括引力场合斥力场,其中目标点对物体产生引力,引导物体朝向其运动(这一点有点类似于A*算法中的启发函数h)。障碍物对物体产生斥力,避免物体与之发生碰撞。物体在路径上每一点所受的合力等于这一点所有斥力和引力的和。这里的关键是如何构建引力场和斥力场。下面我们分别讨论一下:

引力场:

常用的引力函数:

这里的ε是尺度因子.ρ(q,q_goal)表示物体当前状态与目标的距离。引力场有了,那么引力就是引力场对距离的导数(类比物理里面W=FX):

关于梯度的算法可以参考相关资料,简单提一下,二元函数梯度是酱紫的[δx,δy],这个符号是偏导数,不太对,见谅。

Fig .引力场模型

斥力场:

公式(3)是传统的斥力场公式,现在还没有搞清楚是怎么推导出来的。公式中η是斥力尺度因子,ρ(q,q_obs)代表物体和障碍物之间的距离。ρ_0代表每个障碍物的影响半径。换言之,离开一定的距离,障碍物就对物体没有斥力影响。

斥力就是斥力场的梯度

Fig 斥力场模型

总的场就是斥力场合引力场的叠加,也就是U=U_att+U_rep,总的力也是对对应的分力的叠加,如下图所示:

二、存在的问题

(a) 当物体离目标点比较远时,引力将变的特别大,相对较小的斥力在甚至可以忽略的情况下,物体路径上可能会碰到障碍物
(b)当目标点附近有障碍物时,斥力将非常大,引力相对较小,物体很难到达目标点
(c)在某个点,引力和斥力刚好大小相等,方向想反,则物体容易陷入局部最优解或震荡

三、各种改进版本的人工势场法

(a)对于可能会碰到障碍物的问题,可以通过修正引力函数来解决,避免由于离目标点太远导致引力过大
     
和(1)式相比,(5)式增加了范围限定。d*_goal 给定了一个阈值限定了目标和物体之间的距离。对应的梯度也就是引力相应变成:
(b)目标点附近有障碍物导致目标不可达的问题,引入一种新的斥力函数
这里在原有斥力场的基础上,加上了目标和物体距离的影响,(n是正数,我看到有篇文献上n=2)。直观上来说,物体靠近目标时,虽然斥力场要增大,但是距离在减少,所以在一定程度上可以起到对斥力场的拖拽作用
相应斥力变成:
所以可以看到这里引力分为两个部分,编程时要格外注意
(c)局部最优问题是一个人工势场法的一个大问题,这里可以通过加一个随机扰动,让物体跳出局部最优值。类似于梯度下降法局部最优值的解决方案。

四、代码整理

网上matlab 写的代码良莠不齐,bug很多,正在验证,通过了会贴上来。
综合了网上的各种代码,发现基本都是出自一个人的matlab code,然后改成自己的。但是最开始哪个版本的code应该是有很多的错误,尤其集中在计算角度和斥力的子函数上,经过很多人的修改,这个代码已经改的相对比较完善了,整理了一下,具体实现可以参考:改进版maltab 程序
国外的一款友好的matlab人工势场法程序(附详细说明文档)

资料链接

路径规划算法初探http://blog.csdn.net/u011978022/article/details/49912515

关于人工势场方法的研http://kovan.ceng.metu.edu.tr/~kadir/academia/courses/grad/cs548/hmws/hw2/report/apf.pdf

人工势场方法整理http://letsmakerobots.com/artificial-potential-field-approach-and-its-problems

人工势场方法的改进版本http://www.doc88.com/p-738493052458.html

人工势场方法论坛版 http://www.ilovematlab.cn/thread-188840-1-1.html

人工势场法matlab 程序末点震荡版:http://download.csdn.net/detail/programming2015/8589191#comment

人工势场法简介PPThttp://www.cs.cmu.edu/~motionplanning/lecture/Chap4-Potential-Field_howie.pdf

人工势场法matlab程序改进成功版本:http://www.ilovematlab.cn/thread-93531-1-1.html

路径规划-人工势场法(Artifical Potential Field)相关推荐

  1. 人工势场法路径规划算法(APF)

       本文主要对人工势场法路径规划算法进行介绍,主要涉及人工势场法的简介.引力和斥力模型及其推导过程.人工势场法的缺陷及改进思路.人工势场法的Python与MATLAB开源源码等方面    一.人工势 ...

  2. matlab人工势场法三维演示图,人工势场法(Artificial Potential Field Method)的学习

    最近的工作重心回到到算法上之后,陆陆续续开始学习一些自动驾驶的控制算法.目前工作的方向主要是online trajectory generation和底层控制. 对于在线路径规划,一个重要的概念是其应 ...

  3. 基于人工势场法的二维平面内无人机的路径规划的matlab仿真,并通过对势场法改进避免了无人机陷入极值的问题

    目录 1.算法描述 2.matlab算法仿真效果 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 人工势场法原理是:首先构建一个人工虚拟势场,该势场由两部分组成,一部分是目标点对移动机器 ...

  4. 路径规划算法3 改进的人工势场法(Matlab)

    目录 传统人工势场 引力势场 斥力势场 合力势场 传统人工势场法存在的问题 改进的人工势场函数 Matlab代码实现 参考链接: [1]朱伟达. 基于改进型人工势场法的车辆避障路径规划研究[D]. 江 ...

  5. 基于人工势场法的路径规划

    基于人工势场法的路径规划 \qquad 路径规划是移动机器人领域的一个重要组成部分,人工势场法是机器人路径规划算法中一种简单有效的方法. \qquad 势场法的基本思想是在移动机器人的工作环境中构造一 ...

  6. 机器人路径规划_人工势场法

    机器人路径规划_人工势场法 原理 人工势场法是由Khatib提出的一种虚拟力法.原理是:将机器人在环境中的运动视为一种机器人在虚拟的人工受力场的运动.障碍物对机器人产生斥力,目标点对机器人产生引力,引 ...

  7. matlab人工势场法三维演示图,运动规划入门 | 5. 白话人工势场法,从原理到Matlab实现...

    如何利用人工势场进行运动规划? 1.1 引力势场(Attractive Potential Field) 人工势场这个特殊的势场并不是一个单一的场,其实它是由两个场叠加组合而成的,一个是引力场,一个是 ...

  8. 路劲规划与轨迹跟踪学习4——人工势场法

    本文参考(85条消息) [路径规划]局部路径规划算法--人工势场法(含python实现 | c++实现)_CHH3213的博客-CSDN博客_人工势场法路径规划 路径规划与轨迹跟踪系列算法学习_第6讲 ...

  9. 【全局规划】人工势场法(APF)

    人工势场法APF clc clear close all%% 初始化车的参数 d = 3.5; % 道路标准宽度 W = 1.8; % 汽车宽度 L = 4.7; % 车长P0 = [0,-d/2,1 ...

  10. 多机器人编队人工势场法协同避障算法原理及实现

    多机器人编队(二)多机器人编队人工势场法协同避障算法原理及实现 避障算法原理 避障算法仿真 多机器人协同编队需要将理论和实践紧密地结合起来,其应用包括编队队形生成.保持.变换和路径规划与避障等等都是基 ...

最新文章

  1. Fliptile POJ - 3279 (翻转)(二进制+对第一行暴力遍历翻转的位置)
  2. gerber文件怎么导贴片坐标_利用Gerber文件生成贴片坐标及元件位置图的方法技巧...
  3. redis源码剖析(七)—— Redis 数据结构dict.c
  4. CentOS 7 gedit编辑器中文乱码解决方法
  5. JS中的数据类型(见《Jquery实战附录》)
  6. spring controller 增加header字段forward_Spring 注解编程之模式注解
  7. POJ1067 取石子游戏 跪跪跪,很好的博弈论
  8. 最佳牛围栏题解 二分答案
  9. gbase mysql数据库_mysql/gbase数据库全库库表记录数统计
  10. 网购心脏起搏器存在多达8000个程序漏洞
  11. 高考作文也被AI攻克?B站UP主爆肝100天,开发会写高考作文的AI
  12. ipynb转pdf的一种较完美解决方案
  13. 软件著作权个人申请全套攻略
  14. 写了四十篇办公自动化文章后,我整理了这十个常用操作,代码拿走就用!
  15. 张飞实战电子硬件工程师90天学习资料及笔记汇总
  16. 网络机顶盒服务器响应超时怎么办,教你如何处理网络机顶盒常见问题
  17. 学Python真的好找工作吗?工作多年的程序员为你解答
  18. EOS竞猜游戏SKR EOS遭黑客攻击,成都链安已于前天发出预警
  19. matlab 牛顿法 非线性方程,Matlab学习手记——非线性方程组求解:牛顿法
  20. chosen(下拉列表带搜索插件)和layer(弹出框插件)在一起使用会有冲突,解决办法

热门文章

  1. 博途V16软件官方下载和安装
  2. 记一次ARM CHINA面试
  3. Activiti6自学之路(一)—— Activiti6介绍
  4. python 进阶_GitHub - eastlakeside/interpy-zh: 《Python进阶》(Intermediate Python 中文版)...
  5. git日志 每天导出 shell脚本
  6. python标注_python怎么标注
  7. Linux vi命令详解与使用教程
  8. idea2020更新功能_idea2020 插件备份
  9. 威纶通触摸屏与2台台达温控器modbus rtu 通讯程序
  10. 25款实用的桌面版博客编辑器