【智能优化算法】基于遗传算法实现城市交通信号优化附matlab代码

简介: 【智能优化算法】基于遗传算法实现城市交通信号优化附matlab代码

1 简介

本文设计实时优化的配置方案对道路畅通的应急决策管理具有重要意义.本文在分析交通控制基本理论的基础上,根据交叉口的实际情况并考虑信号灯的转换与车辆的启动损失时间,采用四相位对称式放行方案,以车辆在道口的总等待时间最短为目标建立起基于遗传算法的多个交叉口的面控制数学模型.本文利用MATLAB编程实时产生了基于泊松分布的交通流序列,并且为提高模型效率,使建立的模型更具有实用性,我们用VB可视化编程软件制作了一个简易的道路交通信号实时遗传算法演示平台.本文通过对模型的实时优化,算法计算和仿真,获得了在交通信号实时遗传算法的优化控制下的优化参数.

2 部分代码

%% GA%% 清空环境变量clc,clear,close allwarning offfeature jit off%% 遗传算法参数初始化maxgen = 50;                      % 进化代数,即迭代次数sizepop = 50;                     % 种群规模pcross = [0.7];                    % 交叉概率选择,0和1之间pmutation = [0.01];                 % 变异概率选择,0和1之间% 城市交通信号系统参数C = 140;L = 10;load('data.mat')  % 包含交通流量q以及饱和流量xijq = q./3600;      % 转化为秒sxij = xij./3600;  % 转化为秒s%染色体设置lenchrom=ones(1,3);    % t1、t2、t3bound=[38,59;26,37;33,44;];   % 数据范围%---------------------------种群初始化------------------------------------individuals=struct('fitness',zeros(1,sizepop), 'chrom',[]);  %将种群信息定义为一个结构体avgfitness = [];                      %每一代种群的平均适应度bestfitness = [];                     %每一代种群的最佳适应度bestchrom = [];                       %适应度最好的染色体%% 初始化种群for i=1:sizepop    % 随机产生一个种群    individuals.chrom(i,:)=Code(lenchrom,bound); % 编码(binary和grey的编码结果为一个实数,float的编码结果为一个实数向量)    x=individuals.chrom(i,:);    % 计算适应度    individuals.fitness(i)=fun(x);   % 染色体的适应度 end%% 找最好的染色体[bestfitness bestindex] = min(individuals.fitness);bestchrom = individuals.chrom(bestindex,:);    % 最好的染色体% 记录每一代进化中最好的适应度和平均适应度trace = [bestfitness]; %% 迭代求解最佳初始阀值和权值% 进化开始for i=1:maxgen    disp(['迭代次数:  ',num2str(i)])    % 选择    individuals=Select(individuals,sizepop);    % 交叉    individuals.chrom=Cross(pcross,lenchrom,individuals.chrom,sizepop,bound);    % 变异    individuals.chrom=Mutation(pmutation,lenchrom,individuals.chrom,sizepop,i,maxgen,bound);    % 计算适应度    for j=1:sizepop        x=individuals.chrom(j,:);        % 解码        individuals.fitness(j)=fun(x);   % 染色体的适应度     end    % 找到最小和最大适应度的染色体及它们在种群中的位置    [newbestfitness,newbestindex]=min(individuals.fitness);    [worestfitness,worestindex]=max(individuals.fitness);    % 代替上一次进化中最好的染色体    if bestfitness>newbestfitness        bestfitness=newbestfitness;        bestchrom=individuals.chrom(newbestindex,:);    end    individuals.chrom(worestindex,:)=bestchrom; % 剔除最差个体    trace=[trace;bestfitness]; %记录每一代进化中最好的适应度endx = [bestchrom, C-L-sum(sum(bestchrom))]       % 最佳个体值D = trace(end)       % 延误误差DE = D./sum(sum(q));  % 平均延误E%% 遗传算法结果分析 figure('color',[1,1,1]),plot(1:length(trace),trace(:,1),'b--');title(['适应度曲线  ' '终止代数=' num2str(maxgen)]);xlabel('进化代数');   ylabel('适应度');legend('fz最佳适应度');

3 仿真结果

4 参考文献

[1]陆志猛, 张伟强, 阮日升. 城市道路交通信号实时遗传算法的优化控制[J].  2008.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。


相关文章
|
2月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
2月前
|
数据安全/隐私保护
地震波功率谱密度函数、功率谱密度曲线,反应谱转功率谱,matlab代码
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
|
2月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
2月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
2月前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
|
2月前
|
算法 调度
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
基于多目标粒子群算法冷热电联供综合能源系统运行优化(matlab代码)
|
2月前
|
算法 调度 SoC
电动汽车充放电V2G模型(Matlab代码)
电动汽车充放电V2G模型(Matlab代码)
|
2月前
|
算法
【免费】基于ADMM算法的多微网电能交互分布式运行策略(matlab代码)
【免费】基于ADMM算法的多微网电能交互分布式运行策略(matlab代码)
|
2月前
|
算法 调度 决策智能
基于元模型优化算法的主从博弈多虚拟电厂动态定价和能量管理(matlab代码)
基于元模型优化算法的主从博弈多虚拟电厂动态定价和能量管理(matlab代码)

热门文章

最新文章