【优化电价】基于matlab遗传算法求解共享汽车电价优化问题【含Matlab源码 1162期】

本文主要是介绍【优化电价】基于matlab遗传算法求解共享汽车电价优化问题【含Matlab源码 1162期】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

✅博主简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,Matlab项目合作可私信。
🍎个人主页:海神之光
🏆代码获取方式:
海神之光Matlab王者学习之路—代码获取方式
⛳️座右铭:行百里者,半于九十。

更多Matlab仿真内容点击👇
Matlab图像处理(进阶版)
路径规划(Matlab)
神经网络预测与分类(Matlab)
优化求解(Matlab)
语音处理(Matlab)
信号处理(Matlab)
车间调度(Matlab)

⛄一、遗传算法简介

1 遗传算法概述
遗传算法(Genetic Algorithm,GA)是进化计算的一部分,是模拟达尔文的遗传选择和自然淘汰的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法。该算法简单、通用,鲁棒性强,适于并行处理。

2 遗传算法的特点和应用
遗传算法是一类可用于复杂系统优化的具有鲁棒性的搜索算法,与传统的优化算法相比,具有以下特点:
(1)以决策变量的编码作为运算对象。传统的优化算法往往直接利用决策变量的实际值本身来进行优化计算,但遗传算法是使用决策变量的某种形式的编码作为运算对象。这种对决策变量的编码处理方式,使得我们在优化计算中可借鉴生物学中染色体和基因等概念,可以模仿自然界中生物的遗传和进化激励,也可以很方便地应用遗传操作算子。
(2)直接以适应度作为搜索信息。传统的优化算法不仅需要利用目标函数值,而且搜索过程往往受目标函数的连续性约束,有可能还需要满足“目标函数的导数必须存在”的要求以确定搜索方向。遗传算法仅使用由目标函数值变换来的适应度函数值就可确定进一步的搜索范围,无需目标函数的导数值等其他辅助信息。直接利用目标函数值或个体适应度值也可以将搜索范围集中到适应度较高部分的搜索空间中,从而提高搜索效率。
(3)使用多个点的搜索信息,具有隐含并行性。传统的优化算法往往是从解空间的一个初始点开始最优解的迭代搜索过程。单个点所提供的搜索信息不多,所以搜索效率不高,还有可能陷入局部最优解而停滞;遗传算法从由很多个体组成的初始种群开始最优解的搜索过程,而不是从单个个体开始搜索。对初始群体进行的、选择、交叉、变异等运算,产生出新一代群体,其中包括了许多群体信息。这些信息可以避免搜索一些不必要的点,从而避免陷入局部最优,逐步逼近全局最优解。
(4) 使用概率搜索而非确定性规则。传统的优化算法往往使用确定性的搜索方法,一个搜索点到另一个搜索点的转移有确定的转移方向和转移关系,这种确定性可能使得搜索达不到最优店,限制了算法的应用范围。遗传算法是一种自适应搜索技术,其选择、交叉、变异等运算都是以一种概率方式进行的,增加了搜索过程的灵活性,而且能以较大概率收敛于最优解,具有较好的全局优化求解能力。但,交叉概率、变异概率等参数也会影响算法的搜索结果和搜索效率,所以如何选择遗传算法的参数在其应用中是一个比较重要的问题。
综上,由于遗传算法的整体搜索策略和优化搜索方式在计算时不依赖于梯度信息或其他辅助知识,只需要求解影响搜索方向的目标函数和相应的适应度函数,所以遗传算法提供了一种求解复杂系统问题的通用框架。它不依赖于问题的具体领域,对问题的种类有很强的鲁棒性,所以广泛应用于各种领域,包括:函数优化、组合优化生产调度问题、自动控制
、机器人学、图像处理(图像恢复、图像边缘特征提取…)、人工生命、遗传编程、机器学习。

3 遗传算法的基本流程及实现技术
基本遗传算法(Simple Genetic Algorithms,SGA)只使用选择算子、交叉算子和变异算子这三种遗传算子,进化过程简单,是其他遗传算法的基础。

3.1 遗传算法的基本流程
通过随机方式产生若干由确定长度(长度与待求解问题的精度有关)编码的初始群体;
通过适应度函数对每个个体进行评价,选择适应度值高的个体参与遗传操作,适应度低的个体被淘汰;
经遗传操作(复制、交叉、变异)的个体集合形成新一代种群,直到满足停止准则(进化代数GEN>=?);
将后代中变现最好的个体作为遗传算法的执行结果。
在这里插入图片描述
其中,GEN是当前代数;M是种群规模,i代表种群数量。

3.2 遗传算法的实现技术
基本遗传算法(SGA)由编码、适应度函数、遗传算子(选择、交叉、变异)及运行参数组成。
3.2.1 编码
(1)二进制编码
二进制编码的字符串长度与问题所求解的精度有关。需要保证所求解空间内的每一个个体都可以被编码。
优点:编、解码操作简单,遗传、交叉便于实现
缺点:长度大
(2)其他编码方法
格雷码、浮点数编码、符号编码、多参数编码等
3.2.2 适应度函数
适应度函数要有效反映每一个染色体与问题的最优解染色体之间的差距。
3.2.3选择算子
在这里插入图片描述
3.2.4 交叉算子
交叉运算是指对两个相互配对的染色体按某种方式相互交换其部分基因,从而形成两个新的个体;交叉运算是遗传算法区别于其他进化算法的重要特征,是产生新个体的主要方法。在交叉之前需要将群体中的个体进行配对,一般采取随机配对原则。
常用的交叉方式:
单点交叉
双点交叉(多点交叉,交叉点数越多,个体的结构被破坏的可能性越大,一般不采用多点交叉的方式)
均匀交叉
算术交叉
3.2.5 变异算子
遗传算法中的变异运算是指将个体染色体编码串中的某些基因座上的基因值用该基因座的其他等位基因来替换,从而形成一个新的个体。

就遗传算法运算过程中产生新个体的能力方面来说,交叉运算是产生新个体的主要方法,它决定了遗传算法的全局搜索能力;而变异运算只是产生新个体的辅助方法,但也是必不可少的一个运算步骤,它决定了遗传算法的局部搜索能力。交叉算子与变异算子的共同配合完成了其对搜索空间的全局搜索和局部搜索,从而使遗传算法能以良好的搜索性能完成最优化问题的寻优过程。

3.2.6 运行参数
在这里插入图片描述
4 遗传算法的基本原理
4.1 模式定理

在这里插入图片描述
4.2 积木块假设
具有低阶、定义长度短,且适应度值高于群体平均适应度值的模式称为基因块或积木块。
积木块假设:个体的基因块通过选择、交叉、变异等遗传算子的作用,能够相互拼接在一起,形成适应度更高的个体编码串。
积木块假设说明了用遗传算法求解各类问题的基本思想,即通过积木块直接相互拼接在一起能够产生更好的解。

⛄二、部分源代码

%Run NAA;
function OUT = MO_NAA( funcName_adjustInd, funcName_fitness, userObj, controlParams)
%user parameters;
NOBJ = userObj.NOBJ;
popSize = userObj.popSize;
dimension = userObj.dimension;
bounds = userObj.bounds;
types = userObj.types;
MAXGEN = userObj.MAXGEN;
MAXFUNEVALS = userObj.MAXFUNEVALS;

CounterGEN = userObj.CounterGEN;
CounterFES = userObj.CounterFES;

%control parameters;
shelterNum = controlParams.shelterNum;
shelterCap = zeros(1, shelterNum) + controlParams.shelterCap;
scale_local = controlParams.scale_local;
Cr_local = controlParams.Cr_local;
alpha = controlParams.alpha;
Cr_global = controlParams.Cr_global;

bounceBack = controlParams.bounceBack;

%initiallize the population;
[swarm] = MO_initializeSwarm(popSize, dimension, bounds); %initialize the individuals. Each individual represents a solution; %% is a popSize*dimension matrix
%initialize the shelters;
[swarm, swarmFitnesses, shelterIndexes, shelterLeaders, normalizedLeaderFitnesses, userObj] = MO_formShelters(swarm, dimension, bounds, types, popSize, shelterNum, shelterCap, funcName_adjustInd, funcName_fitness, userObj);
CounterFES = userObj.CounterFES;

PFront = zeros(popSize,NOBJ);
PSet = zeros(popSize,dimension);

%start the iteration process;
for i=1:MAXGEN

indNumbers_shelters = MO_calculateIndNumberInShelters(shelterNum, shelterIndexes); %Calculate the number of individuals present in the shelters;

%scan the individuals to do the search;
for p=1:popSize
shelterIndex = shelterIndexes§;

    if(shelterIndex >0) %if the individual is currently in a shelter;theta = normalizedLeaderFitnesses(1,shelterIndex); %get the shelter quality value;  %% size(theta) = 1*1[swarm, shelterIndexes, swarmFitnesses, userObj, P, S] = MO_decideLeave(bounds, types, popSize, dimension, shelterIndex, theta, indNumbers_shelters(shelterIndex), shelterIndexes, swarm, p, shelterLeaders, swarmFitnesses, funcName_adjustInd, funcName_fitness, controlParams, userObj);CounterFES = userObj.CounterFES;PFront(p,:) = P;   %% pareto frontPSet(p,:) = S;    %%  state variable for pareto front else  %if the cockroach is currently doing the exploring;theta = zeros(1,1);r_c = 0;numberInCorner = 0;if (shelterNum>0)r_c = unidrnd(shelterNum);theta = normalizedLeaderFitnesses(1,r_c);  %% size(theta) = NOBJ*1numberInCorner = indNumbers_shelters(r_c);end[swarm, shelterIndexes, swarmFitnesses, userObj, P, S] = MO_decideEnter(bounds, types, popSize, dimension, theta, r_c, numberInCorner, shelterIndexes, swarm, p, shelterLeaders, swarmFitnesses, funcName_adjustInd, funcName_fitness, controlParams, userObj);CounterFES = userObj.CounterFES;PFront(p,:) = P;   %% pareto frontPSet(p,:) = S;    %%  state variable for pareto front end       

end
function [newInd, newUserObj] = MO_adjustInd_test(ind, userObj)
NOBJ = userObj.NOBJ;
popSize = userObj.popSize;
dimension = userObj.dimension;

k=6;
n=2*combntns(k,2);
t_number=3;
car_tnumber=100;
E_Demand=-2.0;
E_Time=-2.5;
C_mv=0.007;
C_mp=0.0013;
C_v=0.012;
p_charging=20;
P0=0.3;
B_v=30;
B_v_LT=0.5;
B_v_UT=0.95;
R_dc=0.1;
PEC=0.0032;
Z_k = [24 22 21 22 22 21];
a_kt = [5,6,3,2,4,7;7,6,2,1,6,4;1,4,5,5,6,4];
PEL=0.15;
R_vdc=0.1;

X=ind;

P_kj=X(1,1:n);
P_kjt(1,:)=X(1,n+1:2n);
P_kjt(2,:)=X(1,2
n+1:3n);
P_kjt(3,:)=X(1,3
n+1:4*n);

%% calculated parameters

%% t0
t0_lower=10;
t0_upper=30;
t0_kj=t0_lower + (t0_upper-t0_lower).*rand([t_number n]);

%% t0ktv
t0ktv_lower=4;
t0ktv_upper=10;
t0_ktv=t0ktv_lower + (t0ktv_upper-t0ktv_lower).*rand([t_number k car_tnumber]);

%% D0
%different area
D01_lower=2;
D01_upper=5;
D02_lower=6;
D02_upper=9;
D03_lower=10;
D03_upper=16;
D0_kj1=round(D01_lower + (D01_upper-D01_lower).*rand([3 n/3]));
D0_kj2=round(D02_lower + (D02_upper-D02_lower).*rand([3 n/3]));
D0_kj3=round(D03_lower + (D03_upper-D03_lower).*rand([3 n/3]));
D0_kj=[D0_kj1,D0_kj2,D0_kj3];
%diferent time
d1=D0_kj(1,:)+2;
d2=D0_kj(2,:)+10;
d3=D0_kj(3,:)+4;
D0_kj=[d1;d2;d3];

%% soc0
soctv_lower=0.3;
soctv_upper=0.9;
SOC_tv=soctv_lower + (soctv_upper-soctv_lower).*rand([t_number car_tnumber]);

%% t_kj
for t=1:3
for i=1:n
t_kj(t,i)=((((P_kjt(t,i)-P0)/P0)E_Timet0_kj(t,i))+t0_kj(t,i));
end
end
for t=1:3
for i=1:k
t_kjnew(t,i)=t_kj(t,i);
t0_kjnew(t,i)=t0_kj(t,i);
end
end

%% D_kj
for t=1:3
for i=1:n
D_kj(t,i)=((((P_kj(1,i)-P0)/P0)*E_Demand)*D0_kj(t,i)+D0_kj(t,i));
end
end

%% t_ktv
for t=1:3
for station=1:k
for car=1:car_tnumber
t_ktv(t,station,car)=t_kjnew(t,station)./t0_kjnew(t,station).*t0_ktv(t,station,car);
end
end
end

%% check constraints.

%% constraint (23)-(25)
%(23)
for t = 1:3
for j = 1:n
if D_kj(t,j)>=D0_kj(t,j)+((D0_kj(t,j)*(P_kj(1,j)-P0)*E_Demand)/(P0))-0.5;
success_23(t,j)=1;
else
success_23(t,j)=0;
end
end
end

%
%
%(24)
for t = 1:3
for j = 1:n
if D_kj(t,j)<=D0_kj(t,j)+((D0_kj(t,j)*(P_kj(1,j)-P0)E_Demand)/(P0))+0.5;
success_24(t,j)=1;
else
success_24(t,j)=0;
end
end
end
%
%
%(25)
for t = 1:3
for j = 1:n
if D0_kj(t,j)+((D0_kj(t,j)
(P_kj(1,j)-P0)*E_Demand)/(P0))>=0;
success_25(t,j)=1;
else
success_25(t,j)=0;
end
end
end

⛄三、运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]朱家家,王红蕾.基于遗传算法的电动汽车实时优化模型与实现[J].软件. 2020,41(12)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

🍅 仿真咨询
1 各类智能优化算法改进及应用

生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化

2 机器学习和深度学习方面
卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断

3 图像处理方面
图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知

4 路径规划方面
旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化

5 无人机应用方面
无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配

6 无线传感器定位及布局方面
传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化

7 信号处理方面
信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化

8 电力系统方面
微电网优化、无功优化、配电网重构、储能配置

9 元胞自动机方面
交通流 人群疏散 病毒扩散 晶体生长

10 雷达方面
卡尔曼滤波跟踪、航迹关联、航迹融合

这篇关于【优化电价】基于matlab遗传算法求解共享汽车电价优化问题【含Matlab源码 1162期】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893314

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k