重发一下之前误删的一篇~


目前大多数元胞自动机模型并没有考虑前车速度,大多数同向行驶的模型中车辆都是处在一个完全跟车的状态,无论前车是加速还是减速,后车驾驶者都只是根据自己的车速判断是减速跟驰还是变换车道来寻求寻求更合理的行驶状态。显然这与实际不符。

驾驶者是一个有自主意识的个体,每个个体都存在差异,即在驾驶过程中都有各自的偏好。对于不同驾驶员有不同的驾驶特性,驾驶员的驾驶特性是受其心理,生理,性格影响的及其复杂的驾驶行为偏好。对驾驶行为起到关键作用的有,反应时间,驾驶员对冒险驾驶行为的偏好,这两点都是引起交通事故的重要因素。驾驶员反应时间越长越易与前车发生碰撞;驾驶员对冒险行为的偏好越高,在驾驶时约越易采取偏激行为,引发交通事故。但值得注意的是,部分驾驶员对冒险驾驶行为的偏好是出于自身性格因素,但也有很大部分驾驶员对冒险驾驶行为的偏好是出于自身驾驶技术较高,也就是驾驶技术较高的驾驶员采取偏激驾驶行为的概率大于新手驾驶员,这是符合常识的。

因此,本模型引入驾驶员反应时间,冒险偏好参数,以及考虑前车速度来使元胞自动机在快速路模型的模拟中更加接近现实。其中,近似认为一个驾驶员其反应时间与冒险偏好参数之和为1。也就是说,用驾驶员反应时间来粗略代表其驾驶技术水平,而认为随着其驾驶水平提高,其对冒险驾驶行为的偏好相应增高。而对前车速度的考虑则通过定义驾驶需要空间和驾驶员预估空间来实现。其中,驾驶需要空间是指,车辆此时刻速度+车辆反应时间*车辆此时速度,即,车辆可以保持速度行为而不发生碰撞所需要的空间;驾驶员预估空间是指,车辆与前车距离+驾驶员冒险偏好参数*前车速度,即,驾驶员对未来车前距离的预估。

依据以上思路,对NaSch模型的加速规则进行更改:

当驾驶需要空间<驾驶员预估空间时,车辆进行减速,即,车辆速度在车辆现速度与驾驶员预估空间减去反应时间走过的距离之间取小。相应的,换道决策过程是,当车辆驾驶所需空间<驾驶员预估空间,而旁边车道的驾驶员预估空间大于本车道时,将以概率换道,这里的概率换道也是模拟驾驶员特性,反应其对速度的追求。

综上,考虑了反应时间后,后车对前方行驶空间要求相对NaSch模型变大,而考虑前车速度让后车在加减速判断时放大了车间距这个概念,而反应时间和驾驶员对前方空间的预估都和驾驶员特性有关,这和实际情况是符合的。而驾驶员对冒险偏好参数是初始化的时候就随机生成不变的,代表不同驾驶员的不同性格,这与实际相符。而反应时间和冒险偏好参数之和为1,是方便编程之举,但粗略来说,也是和实际大致符合的。

值得注意的是,本模型中依据采取先换道再跟驰的方法,而换道是有顺序的,跟驰无顺序,也就是说换道是一辆车换道结束之后,下一辆车再换道,这必然造成一辆车的换道行为将影响之后车辆的换道行为;而跟驰则不然,所有车辆执行完加减速及随机慢化后,同时位置更新,即,所有车辆在一个时间步内行进时无影响。车辆换道对其他车辆换道,跟驰产生影响是符合实际情况的,而在一个时间步对应现实时间比较小的情况下,车辆跟驰行为间无影响也是符合现实的。

除此以外,本模型中头车不受前车影响而减速,也不换道,这也是与实际相符的。

引入前车速度使本模型与NaSch有很大的区别,一是一个位置可能会出现两辆车,所以在位置更新时要防止碰撞而多做一个判断;另一个是一个时间步内可以有多辆车驶出车道。

最后,本模型车辆换道时没有考虑目标车道后车影响,但实际换道时肯定受到与后车距离以及后车速度的综合影响,但其影响明显小于前车影响,而为了编程方便并没有考虑。

贴代码哈。

主函数

%%  考虑驾驶员特性和前车速度的单向3车道模型
clc;
clear;
%%  参数设置
lane_length = 100; %车道长度
car_rate = 0.1;  %车辆占有率
v_max = 5; %最大车速
time_max = 1000; %仿真步长
time_span = 0.1; %仿真图片输出间隔
p_slowdown = 0.3; %随机慢化概率
p_changelane = 0.8; %满足换道条件换道概率%%  随机生成初始车辆信息
[space,car,car_number] = initialize(car_rate,lane_length,v_max);%%  显示初始仿真图
figure('doublebuffer','on');%开启双缓存
space = -1*space;
H = imshow(space,[]);
title('考虑驾驶员特性及前车速度的单向3车道模型','color','red');
space = -1*space;%%  开始仿真
for time=1:time_max%%  换道阶段[car,space] = change_lane(space,car,car_number,p_changelane,lane_length,v_max);%%  跟驰阶段[space,car] = follow(space,car,v_max,lane_length,p_slowdown,car_number);%%  显示仿真图space = -1*space;set(H,'CData',space);pause(time_span);space = -1*space;
end

初始化函数

function [space,car,car_number] = initialize(car_rate,lane_length,v_max)
car_number = fix(1+(3*lane_length-1)*car_rate); %按车辆占有率算出的车辆数
%%  创建空间
space = zeros(3,lane_length);%元胞空间
car = struct('v',zeros(1,car_number),'m',zeros(1,car_number),'n',zeros(1,car_number),'r',zeros(1,car_number),'a',zeros(1,car_number));
% 车辆信息结构体从左到右为速度,车道,列,反应时间,驾驶员对冒险驾驶行为的偏好
%%  随机生成初始车辆信息
for id=1:car_number%%  位置信息初始化if  id<=fix(car_number/3)%%  最左边车道随机投放车辆car.m(id) = 1;car.n(id) = fix( 1+rand(1)*(lane_length-1) );while space(car.m(id),car.n(id))==1car.n(id) = fix( 1+rand(1)*(lane_length-1) );endspace( 1,car.n(id) ) = 1;elseif  id<fix( (car_number*2)/3 )%%  中间车道随机投放车辆car.m(id) = 2;car.n(id) = fix( 1+rand(1)*(lane_length-1) );while space(car.m(id),car.n(id))==1car.n(id) = fix( 1+rand(1)*(lane_length-1) );endspace( 2,car.n(id) ) = 1;else%%  最右边车道投放车辆   car.m(id) = 3;car.n(id) = fix( 1+rand(1)*(lane_length-1) );while space(car.m(id),car.n(id))==1car.n(id) = fix( 1+rand(1)*(lane_length-1) );endspace( 3,car.n(id) ) = 1;end%%  车速及驾驶员特性初始化car.v(id) = fix( 1+rand(1)*(v_max-1) ); %速度初始化car.r(id) = rand(1); %随机生成驾驶员反应时间和对冒险驾驶行为的偏好参数,均为0到1间数字car.a(id) = 1-car.r(id);end
end

换道函数

function [car,space] = change_lane(space,car,car_number,p_changelane,lane_length,v_max)
%换道函数
for id=1:car_number[cycle,empty]=get_empty_front(car.m(id),car.n(id),lane_length,space);%获取前方车距if cycle  %头车不换道v_front = car.v( logical( (car.n==(car.n(id) +empty+1)) .* (car.m==car.m(id)) ) );%获取前车速度if car.m(id) == 1 %左侧车道换道[cycle_right,empty_right_front] = get_empty_front(car.m(id)+1,car.n(id),lane_length,space);%获取右侧车道车距if cycle_rightv_front_right = car.v( logical( (car.n==(car.n(id) +empty_right_front+1)) .* (car.m==car.m(id)+1) ));%获取右前车速度elsev_front_right = v_max;end%%  换道决策if   empty+car.a(id)*v_front < car.v(id)*(1+car.r(id))%%  前车阻碍车辆对速度的追求if  (v_front_right*car.a(id)+empty_right_front) > (empty+car.a(id)*v_front) && space( car.m(id)+1,car.n(id) )==0  %旁边车道距离更大且旁边无车%%  满足安全条件换道if  rand(1)<p_changelane %满足换道条件以概率换道space(car.m(id),car.n(id)) =0;car.m(id) = car.m(id)+1;space(car.m(id),car.n(id)) =1;endendendelseif car.m(id) == 2 %中间车道换道[cycle_right,empty_right_front] = get_empty_front(car.m(id)+1,car.n(id),lane_length,space);%获取右侧车道车距[cycle_left,empty_left_front] = get_empty_front(car.m(id)-1,car.n(id),lane_length,space);%获取左侧车道车距%获取右前车速度if cycle_rightv_front_right = car.v( logical( (car.n==(car.n(id) +empty_right_front+1)) .* (car.m==car.m(id)+1) ));elsev_front_right = v_max;end%获取左前车速度if cycle_leftv_front_left = car.v( logical( (car.n==(car.n(id) +empty_left_front+1)) .* (car.m==car.m(id)-1) ));elsev_front_left = v_max;end%%  换道决策if  empty+car.a(id)*v_front < car.v(id)*(1+car.r(id))%%  前车阻碍车辆对速度的追求%%  优先左换道if  (v_front_left*car.a(id)+empty_left_front) > (empty+car.a(id)*v_front) && space( car.m(id)-1,car.n(id) )==0  %旁边车道距离更大且旁边无车%%  满足安全条件换道if  rand(1)<p_changelane %满足换道条件以概率换道space(car.m(id),car.n(id)) =0;car.m(id) = car.m(id)-1;space(car.m(id),car.n(id)) =1;endelse%左换道条件不满足则右换道if  (v_front_right*car.a(id)+empty_right_front) > (empty+car.a(id)*v_front) && space( car.m(id)+1,car.n(id) )==0  %旁边车道距离更大且旁边无车%%  满足安全条件换道if  rand(1)<p_changelane %满足换道条件以概率换道space(car.m(id),car.n(id)) =0;car.m(id) = car.m(id)+1;space(car.m(id),car.n(id)) =1;endendendendelse  %右侧车道换道[cycle_left,empty_left_front] = get_empty_front(car.m(id)-1,car.n(id),lane_length,space);%获取左侧车道车距if cycle_leftv_front_left = car.v( logical( (car.n==(car.n(id) +empty_left_front+1)) .* (car.m==car.m(id)-1) ));%获取左前车速度elsev_front_left = v_max;end%%  换道决策if  empty+car.a(id)*v_front < car.v(id)*(1+car.r(id))%%  前车阻碍车辆对速度的追求if  (v_front_left*car.a(id)+empty_left_front) > (empty+car.a(id)*v_front) && space( car.m(id)-1,car.n(id) )==0  %旁边车道距离更大且旁边无车%%  满足安全条件换道if  rand(1)<p_changelane %满足换道条件以概率换道space(car.m(id),car.n(id)) =0;car.m(id) = car.m(id)-1;space(car.m(id),car.n(id)) =1;endendendendend
end

跟驰函数

function [space,car] = follow(space,car,v_max,lane_length,p_slowdown,car_number)
%跟驰函数
cycle = zeros(1,car_number);%储存车辆是否为头车
for id = 1:car_number%%  加速car.v(id) = min(car.v(id)+1,v_max);%%  获取车辆前空元胞数以及是否符合满足周期循环[cycle(id),empty]=get_empty_front(car.m(id),car.n(id),lane_length,space);%%  减速if cycle  %头车不受前车影响而减速if cycle(id) %获取前车速度v_front = car.v( logical( (car.n==(car.n(id) +empty+1)) .* (car.m==car.m(id)) ) );%获取前车速度elsev_front = v_max;endcar.v(id) = min (car.v(id) , fix(empty+car.a(id)*v_front-car.v(id)*car.r(id)) );%车速不能超过驾驶员预估空间end%%  概率慢化if  rand(1) <= p_slowdowncar.v(id) = max( car.v(id)-1,0 );end
end%%  位置更新e = 2;f = 2;g = 2;for id = 1:car_numberif  car.n(id)+v_max >= lane_length %会驶出车道%%  周期边界条件将头车以原速度道路最左边if cycle(id)==0 %头车if  car.n(id)+car.v(id)>lane_lengthspace ( car.m(id),car.n(id) ) = 0;car.n(id) = 1;space ( car.m(id),car.n(id) ) = 1;endelse %非头车if  car.n(id)+car.v(id)>lane_lengthspace ( car.m(id),car.n(id) ) = 0;switch car.m(id)case 1car.n(id) = e;e = e+1;case 2car.n(id) = f;f = f+1;case 3car.n(id) = g;g = g+1;endspace ( car.m(id),car.n(id) ) = 1;end  endspace ( car.m(id),car.n(id) ) = 0;car.n(id) = car.n(id) +car.v(id);while  space ( car.m(id),car.n(id) ) == 1car.n(id) = car.n(id) -1;endspace ( car.m(id),car.n(id) ) = 1;else %不可能驶出车道space ( car.m(id),car.n(id) ) = 0;                car.n(id) = car.n(id) +car.v(id);while  space ( car.m(id),car.n(id) ) == 1car.n(id) = car.n(id) -1;endspace ( car.m(id),car.n(id) ) = 1;endend
end

获取前车距离及判断是否头车函数

%用于求m车道n列的前车距以及判断是否为头车,cycle值为0是头车
function [cycle,empty_front] = get_empty_front(m,n,lane_length,space)
empty_front = 1;
cycle=1;
if  n+1 < lane_length%求前车距while space(m,n+empty_front) == 0if n+empty_front<lane_lengthempty_front = empty_front+1;elsecycle = 0;empty_front = empty_front+1;break;endend   empty_front = empty_front-1;
elseempty_front = 0;cycle = 0;
end
end

本来开专栏只是做个笔记,但陆续也有几个小伙伴加我,和他们交流发现了之前发的几个代码的好几处错误,所以希望看到代码中的错误或是某部分代码怎样写更好,希望大家能指点一二,十分感谢!

参考文献

李杰;杨晓芳;付强.分析驾驶行为的快速路交通流元胞自动机模型[J].物流科技,2018,v.41;No.280,69-73.

本模型主要思路就是上面这篇文章,加上知乎的编辑器我不太会用,所以我就没标引用的地方。公式编辑器编辑的公式也没法复制,所以一直都是文字叙述。总之这次模型就是基于上面文章的思路改的,但我感觉这篇文章有前后矛盾的地方,可以交流哈。

车辆跟驰模型matlab代码实现_MATLAB——考虑驾驶员特性及前车速度的快速路模型...相关推荐

  1. SIR传染模型Matlab代码,sir传染病模型 MATLAB代码运行不了,

    问题描述: sir传染病模型 MATLAB代码运行不了, function y=ill(t,x) a=1;b=0.3; y=[a*x(1)*x(2)-b*x(1),-a*x(1)*x(2)]'; ts ...

  2. 【路径规划】基于头脑风暴优化算法求解带时间窗和同时取送货的车辆路径问题附matlab代码

    1 内容介绍 本文主要研究广州番禺配送中心的车辆路径规划问题,首先针对之前车辆运行中的先送货后取货模式,产生车辆运行路线的迂回,以及车辆在回程中的空载,路径规划不合理,送货时间长的问题,采用集成的观点 ...

  3. arima模型matlab代码_PSTR面板平滑转换模型简介(附Matlab代码分享)

    写论文的时候用到的~相关的资料太少了,做一些简单内容和资料的分享.(PSTR模型的Matlab代码分享在最后)本文主要为简单理论和粗暴实操~ 有用的话可以点个赞哟(知乎小白卑微求赞) 嘻嘻下面进入正题 ...

  4. 基于双参数蜜蜂算法解决车辆路径问题(Matlab代码实现)

    目录 1 概述    1.1研究背景 2 运行结果 3 Matlab代码实现 4 参考文献 1 概述 群智能起源于自然环境中生物群体经过长期自然进化后具有的解决问题的能力,其中的许多问题在人类看来可以 ...

  5. 【路径规划】基于蚁群算法的多配送中心车辆路径优化方法matlab代码

    1模型介绍 一种基于蚁群算法的多配送中心车辆路径优化方法,首先,针对多配送中心车辆路径优化问题,对各个客户点设计了以最近配送中心为启发式信息的惩罚函数;其次,将具有上述启发式信息的罚函数加入到各配送点 ...

  6. matlab iri模型,IRI2012电离层模型 matlab代码

    [实例简介] IRI2012电离层模型 International Reference Ionosphere (IRI) Model Computes the International Refere ...

  7. 多元线性回归matlab代码例题_matlab多元线性回归

    1.matlab多元回归示例如下: 解决问题:油价预测 方法:多元线性回归 实现:matlab regress()函数 技巧:通过增加X1^2,X2^2,或者X1*X2等构造的特征项,可以提高回归模型 ...

  8. 非期望产出超效率SBM模型MATLAB代码

    目前CSDN里面几乎没有一个正确的该模型代码,本人分享代码的测算结果已发表在C刊. clc clear X =[];%投入指标数据 Y = [];%期望产出指标数据 Z = [];%非期望产出指标数据 ...

  9. dla模型 matlab代码,在MATLAB平台下实现DLA分形聚集生长的模拟

    第30卷 第1期 西南师范大学学报(自然科学版)2005年2月Vol.30 N o.1Journal of Southwest China Normal University (Natural Sci ...

最新文章

  1. DevOps是软件研发的洗碗机
  2. 分布式理论、架构设计(自定义RPC)
  3. Hive笔记之严格模式(strict mode)
  4. AVFoundation – AVAssetTrack 获取视频 音频信息
  5. ES6学习--Javascript中的那三个点(...)
  6. 每个日期新用户的次日留存率
  7. linux socket编程:简易客户端与服务端
  8. 要管理组策略 您必须以域用户账户登录此计算机,让AD域用户账户只能登陆管理员指定的客户端计算机...
  9. 无言以队Alpha阶段项目复审
  10. 非专业学生如何系统的学习计算机编程?
  11. 远程小组软件开发过程(1):流程
  12. 联想笔记本电脑昭阳k2450关机这个灯一直闪烁,而且还消耗电量
  13. 沟通的艺术02 同理心对话 亲子沟通实例
  14. 有趣的HTML实例(七) 注册登录界面Ⅱ(css+js)
  15. 黑马程序员博学谷Java就业班课程
  16. iOS第三方登录之Twitter(登录,获取用户信息)含demo
  17. VS2013编译libjpeg库
  18. mysql 迪卡尔运算_「笛卡尔乘积」mysql笛卡儿积 - seo实验室
  19. 用inno Setup做应用程序安装包的示例脚本(.iss文件)(
  20. 飞信消息通道服务器,和飞信_服务中心_中国移动通信

热门文章

  1. iOS10 权限访问崩溃
  2. d3.js 实现烟花鲜果
  3. mysql 各个版本驱动jar包
  4. (九)模板方法模式详解(包含与类加载器不得不说的故事)
  5. php中rsa加密及解密和签名及验签
  6. TF-IDF理解及其Java实现
  7. JS一维数组转化为三维数组有这个方法就够了
  8. 在多种浏览器中嵌入Applet
  9. [异步、tensorflow] - 子线程操作tensor,主线程处理tensor
  10. koa --- [MVC实现之五]Model层的实现