智能车制作

标题: 神经网络用于小车控制的一点想法之一[原创] [打印本页]

作者: whut_wj    时间: 2009-9-9 21:56
标题: 神经网络用于小车控制的一点想法之一[原创]
对于小车的控制算法,神经网络应该是不错的选择。但是很多人没有用,我想是计算量和收敛特征的问题导致大家在研究算法时不敢越雷池。神经网络的研究一般是基于OFF-LINE的,而飞思卡尔比赛用的只是MCU的ON-LINE模式的,这似乎就有了矛盾;另外,神经网络无论在分类还是拟合作用上,计算精确性并不是100%,这也是航空技术不用神网的原因。 此篇博文主要讨论神经网络用在小车控制算法上的可能性以及如何利用神经网络于小车控制算法。
          想必自动化的学生都对控制模型的建模有很深的印像,有的硕士论文就是研究这些模型。一般用机理分析法和系统辨识法对实验数据建模,得到传递函数,然后通过调试实际系统,从开环到闭环,不断调整参数和控制参数。举个例子:要建立小车直线、弧线行走的控制模型,即通过实测数据建立驱动控制和小车转弯偏移量的关系,那么输入的参数是当前速度,曲率大小,转弯弧度,最大安全速度,目前偏移角度等等参数,而输出的就是目标速度,目标角度。这个输入和输出之间的关系就是控制模型,一般也叫控制器。小车跑得快,跑得稳,主要就是这个”控制器“,控制器拟合得好,适应性强,OK,成绩就不差。
             说了半天,小车控制算法要解决的问题是: 输入——>控制模型——>输出控制参数。 按一般的方法,控制模型的建立需要大量数据,离线在线都必需调试多遍,系统的适应性不佳。而尝试神经网络,这些问题就都可以很大程度地避免了。
        1 首先,有必要介绍一下神经网络,到底神经网络是干什么用的,如何用。神经网络的理论并不复杂,我想是有些书或论文把简单问题复杂化了。大家不要对它恐惧。一堆数据A,通过一个NET不断调整,得到另一堆数据B。而A和目标结果数据C都是已知的,NET是未知的,这个调整NET的过程就是训练,NET训练好的结果是使B和C的误差最小,误差合理就收敛。收敛完了,这个NET就可以用了。神经网格的核心就是得到一个NET。控制模型就是一个NET,NET包含很多参数,如权值,隐含层数,训练方法,神经元模型,传递函数等,只要建立一个NET,那么输入和输出的关系就建立起来了。 神经网络主要有两个作用:一个是分类,另一个是回归(拟合)。如果把它运用于小车控制算法,毫无疑问是用于回归拟合的功能。回归什么呢?对,回归上面所说的控制模型,这个NET就是控制器。 神经网络用于小车控制算法上的优势比较明显,模型可以随时调整,而且模型不是通过公式表示,只是一个NET来表达,避免复杂的参数调整和试算过程。通过新的环境参数得到新的NET,增强系统的适应性。 为什么有些车在自己的场地上跑得好好的,在其它的场地上就不行呢? 为什么有些车不断地调整控制模型,控制效果却不好呢? 如何选择控制器的输入参数,参数的权重如何介定呢? 。。。。。。。。 一系列的问题,神经网络可以给大家答案。
作者: zdhly0401    时间: 2009-9-9 23:46
不知道北科的车用了没有,表现的很出色呀
作者: whut_wj    时间: 2009-9-10 00:11
这个基本没有人用到,一般人会觉得理论太深。
神经网络是我研一时的课程,学自动化的同学最好学习一下。以后工作上会用得着的。
另外,我写的这个东西用了我整整一个晚上时间,怎么没人看?
作者: xiaokk    时间: 2009-9-10 19:12
哪个车队用到了,可否交流一下?
作者: zdhly0401    时间: 2009-9-16 19:42
3# whut_wj
好的想法,给大家一个启迪
作者: librae8226    时间: 2009-9-16 19:54
看到了~~呵呵,谢谢lz分享!!~
新手,很想研究一下~~
作者: halolzx    时间: 2009-9-19 10:00
wj,顶了
作者: 苏苏    时间: 2009-9-27 18:37
LZ,我踩一下
作者: 苏苏    时间: 2009-9-27 18:37
LZ,我踩一下
作者: peilet    时间: 2009-9-28 10:58
神经网络用在智能车上恐怕还需要很长的时间

硬件上,可以发现神经网络算法大多都是用FPGA实现的,原因是FPGA可以在一定程度上做到架构上的application-specified,而MCU不行。即使是150MHZ的F2812跑一次MPC算法都需要100ms以上的时间,甚至超过1s,这种处理速度,只能在石油化工等非实时行业中应用。而智能车竞赛,以摄像头组为例,控制周期是在50ms,光电组更短。神经网络在控制中更多时候充当前馈补偿或自适应的作用,每经过一次神经元NET都要进行一次非线性运算,而且还要反复迭代,需要大量的CPU运算。HCS12即不programmable也不是floating-point,其频率、架构都不适合跑神经网络算法,远远无法达到智能车竞赛所需要的real-time.为什么模糊控制在智能车竞赛中有应用呢,因为HCS12其底层架构上有专门的模糊指令,大大缩短的运算时间,而且模糊控制大多是线性运算(三角形或梯形隶属度函数)。

嵌入式AI是一个很stimulating的领域,最终方向很可能是ASIC或ASSP。但控制并不是越高级越好,适合的才是最好的,这也是为什么工业控制器大多仍围绕PID和MPC算法来设计的原因。

作者: vic_hong    时间: 2009-10-10 13:14
支持楼上,智能车的实时性要求很高,神经网络的主要优点是能够自适应,自组织,自学习,但是必然的运算量会增大。正如楼上所说“控制并不是越高级越好,适合的才是最好的”。
作者: msds-shelly    时间: 2009-10-22 13:17
神经网络学起来真的很难那,我们大四就开了这门课,用的书就是研究生和博士用的教材。。。。
作者: 20074978    时间: 2010-3-10 14:17
的确难   不过对思维有启发
作者: lurenz7    时间: 2010-3-16 18:33
楼主辛苦了。
作者: huaer1123    时间: 2010-11-23 17:27
回复 3# whut_wj


    看了楼主的想法很受启发,对小车的控制的理解又加深了,
   
   楼主说 自动化将来会用的神经网络 想问问是自动化的哪个方向 或者二级学科 可以用到呢
作者: summer    时间: 2010-11-28 22:17
谢谢LZ,顶了。
作者: thunderbird001    时间: 2011-3-24 11:58
mark
作者: 马合店村    时间: 2012-2-7 00:18

作者: dyingendless    时间: 2012-2-10 22:28
有同样的想法。顶了再看
作者: tujunjie    时间: 2012-2-15 12:04
有时间研究一下
作者: 木未    时间: 2012-3-17 01:56
不懂~
作者: 陈胜利    时间: 2012-4-8 23:19
谢了
作者: 牧℡〆风︶ㄣ    时间: 2013-2-27 20:35
虽然不懂... 顶了!!
作者: 戥家三少    时间: 2013-9-8 09:46
我正在研究这个,我的想法就是把繁重的计算留给个人PC机,车只是收集数据及及传递数据
作者: 九劫岛    时间: 2014-7-11 22:05
大赞楼主和10楼
作者: ???    时间: 2014-7-12 09:10
mark
作者: 徐晋鸿!    时间: 2014-7-12 10:32
楼主分析的很有道理,但若是把眼光放在硬件最高200M的K60上会发现还是力不从心,楼上说摄像头是50ms,那是很客气的说法,我们组摄像头是16.66ms,那根本不可能用到高级算法。。和外人讲智能车,他们会觉得很low,因为他们觉得智能车并没有用什么前沿的算法,但是他们从来没考虑过智能车硬件平台的限定以及它要完成实时性这个目标。
作者: 沙漏、、、    时间: 2014-7-13 11:03
点赞
作者: 板正的    时间: 2014-7-14 17:43
还是没看懂、、
作者: 湖工~浮生若梦    时间: 2014-7-30 11:59
做智能车的一般都是大二大三的,没有这么多时间来研究这个啊。。。。
作者: Ebola2012    时间: 2019-10-21 12:13
十年了,不知道是不是可以实现了




欢迎光临 智能车制作 (http://dns.znczz.com/) Powered by Discuz! X3.2