算法中参数
① 粒子群优化的算法参数
PSO参数包括:群体规模m,惯性权重w,加速常数c1和c2,最大速度Vmax,最大代数Gmax,解空间[Xmin Xmax]。
Vmax决定在当前位置与最好位置之间的区域的分辨率(或精度)。如果Vmax太高,微粒可能会飞过好解,如果Vmax太小,微粒不能进行足够的探索,导致陷入局部优值。该限制有三个目的:防止计算溢出;实现人工学习和态度转变;决定问题空间搜索的粒度。
惯性权重w使微粒保持运动的惯性,使其有扩展搜索空间的趋势,有能力探索新的区域。
加速常数c1和c2代表将每个微粒推向pbest和gbest位置的统计加速项的权重。低的值允许微粒在被拉回来之前可以在目标区域外徘徊,而高的值导致微粒突然的冲向或者越过目标区域。
如果没有后两部分,即c1 = c2 = 0,微粒将一直以当前的速度飞行,直到到达边界。由于它只能搜索有限的区域,将很难找到好的解。
如果没有第一部分,即w = 0,则速度只取决于微粒当前的位置和它们历史最好位置pbest和gbest,速度本身没有记忆性。假设一个微粒位于全局最好位置,它将保持静止。而其它微粒则飞向它本身最好位置pbest和全局最好位置gbest的加权中心。在这种条件下,微粒群将统计的收缩到当前的全局最好位置,更象一个局部算法。
在加上第一部分后,微粒有扩展搜索空间的趋势,即第一部分有全局搜索的能力。这也使得w的作用为针对不同的搜索问题,调整算法全局和局部搜索能力的平衡。
如果没有第二部分,即c1 = 0,则微粒没有认知能力,也就是“只有社会(social-only)”的模型。在微粒的相互作用下,有能力到达新的搜索空间。它的收敛速度比标准版本更快,但是对复杂问题,比标准版本更容易陷入局部优值点。
如果没有第三部分,即c2 = 0,则微粒之间没有社会信息共享,也就是“只有认知(cognition-only)”的模型。因为个体间没有交互,一个规模为m的群体等价于m个单个微粒的运行。因而得到解的几率非常小。
② 各种计算方法中的相关参数
地下水地源热泵适宜区可开采资源量的计算方法有水热均衡法和地下水量折算法,本项目选择地下水量折算法;地埋管地源热泵经济区可开采资源量采用换热量现场测试法计算。对评价方法及相关参数分别介绍如下。
图5-2可开采资源量评价框架图
1.体积法评价方法
利用体积法进行评价计算时,应先确定潜水水位,再确定主要地层厚度、物性参数。
(1)在包气带中,其浅层地温能静态储量按下式计算:
北京浅层地温能资源
式中:QR——浅层地温能储存总量,kJ;
QS——岩土体中的热储存量,kJ;
QW——岩土体所含水中的热储存量,kJ;
QA——岩土中所含空气中的热储存量,kJ。
其中:
北京浅层地温能资源
式中:ρS——岩土体密度,kg/m3;
Cs——岩土体比热容,kJ/(kg·℃);
φ——岩土体的孔隙率;
M——计算面积,m2;
d1——包气带厚度,m;
ΔT——利用温差,℃。
北京浅层地温能资源
式中:ρW——水的密度,取1000kg/m3;
CW——水的比热容,取4.18kJ/(kg·℃);
ω——岩土体的含水率;
北京浅层地温能资源
ρA——空气的密度,取1.29kg/m3;
CA——空气的比热容,1.008kJ/(kg·℃)。
(2)在含水层和相对隔水层中,其地热能储存量按下式计算:
北京浅层地温能资源
式中:QR——浅层地温能储存总量,kJ;
QS——岩土体中的热储存量,kJ;
QW——岩土体所含水中的热储存量,kJ;
北京浅层地温能资源
d2为潜水位至计算下限的岩土体厚度。
通过以上介绍,体积法计算简便、物理意义明确,而且使用范围广泛,不仅适用于松散岩层分布区的浅层地温能静态储量评价,而且同样适用于基岩地区的浅层地温能静态储量评价;不仅适用于地下水地源热泵适宜区静态储量的计算,而且适用于地埋管地源热泵经济区静态储量的计算。由于本次研究工作在国内尚属首次,故选用体积法。在本次工作的基础上,对于浅层地温能资源条件相近区域可以采用类比法进行评价,拓展评价区域范围。
体积法相关参数:根据公式(5-1)~(5-6),可以确定主要参数分为评价范围参数和岩土体物性参数两个方面,分别为:评价区域面积(M,m2)、计算厚度(d2、d2,m)、岩土体孔隙率(φ,%)、岩土体天然含水率(ω,%)、岩土体天然密度(ρs,kg/m3)、岩土体比热容[Cs,kJ/(kg·℃)]、利用温差(ΔT,℃)。
2.地下水热泵适宜区可开采资源量计算方法
(1)水热均衡法:主要通过研究区的水、热均衡计算,了解地下水的水、热储存量和水、热补排情况。
水均衡
北京浅层地温能资源
式中:qin——补给量,m3/d;
qout——排泄量,m3/d;
Δqw——存量的变化量,m3/d。
在包气带中,岩土体水分的补给项有:降水入渗量、灌溉入渗量等;排泄项有:植物蒸腾量、土面蒸发量、下渗补给地下水的量等。
地下水补给项有:降水入渗量、灌溉入渗量、渠系入渗量、河流入渗量、侧向补给量、越流补给量等;排泄项有:潜水蒸发量、人工开采量、侧向排泄量、泉排泄量、河流排泄量、越流排泄量等。
热均衡
北京浅层地温能资源
式中:Qin——热收入量,kW;
Qout——热支出量,kW;
ΔQ——热储存量的变化量,kW。
在包气带,热的收入项有:太阳照射热量、大地热流量、地表水向岩土体散发的热量、侧向传导流入的热量等;支出项有:向大气散发的热量、向地表水散发的热量、侧向传导流出的热量等。
在地下水中,热的收入项有:太阳照射热量、大地热流量、侧向传导流入的热量等;支出项有:向大气散发的热量、水排泄带走的热量、侧向传导流出的热量等。恒温带以下,热收入项没有太阳照射热量。
(2)地下水量折算法:地下水量折算法适用于地下水地源热泵适宜区浅层地温能可开采资源量的计算,其表达式如下:
北京浅层地温能资源
式中:Qq——评价区浅层地温能可开采量,kW;
Qh——单井浅层地温能可开采量,kW;
n——可钻抽水井数;
T——土地利用系数。
其中:
北京浅层地温能资源
式中:Qh——单井浅层地温能可开采量,kW;
qw——单井出水量,m3/d;
△T——地下水利用温差,℃;
Cw——水的比热容,kJ/(kg·℃)。
土地利用系数,居民点、公共用地和其他用地的比例。根据《北京市土地利用现状遥感解译图》中草地、园地、居民及工矿用地和未利用土地面积等占土地面积的27.81%,在以上区域内,开展地下水地源热泵工程时,还要考虑建筑布局、建筑负荷需求、建筑占地面积、资源承载力、地下水连通性等因素的影响,取土地利用系数为22%(27.81%×0.8)。
地下水量折算法相关参数:根据式(5-9)~(5-10),在地下水地源热泵适宜区,利用地下水量折算法评价可开采资源量的相关参数主要有:单井出水量(qw,m3/d)、可钻抽水井数(n)、温差(ΔT,℃)、土地利用系数(T)。
(3)地下水地源热泵适宜区可开采资源量评价方法小结:水热均衡法需要有长期动态监测数据的支撑,适用于评价浅层地温能资源可利用量的保证程度;地下水量折算法可操作性强,较好地反映了地下水地源热泵利用浅层地温能资源的特点,因此本次研究采用该方法。
3.地埋管热泵适宜区可开采资源量评价方法
(1)换热量现场测试法:换热量现场测试法适用于地埋管热泵经济区浅层地温能可开采资源量的计算,其表达式如下:
北京浅层地温能资源
式中:Dq——评价区浅层地温能可开采资源量,kW;
D——单孔换热量,kW;
n——可钻换热孔数;
T——土地利用系数。
北京浅层地温能资源
式中:kz——综合传热系数,W/(m·℃);
ΔT——温差,℃,即为U形管内循环液平均温度与岩土体原始温度之差;
L——双U形地埋管换热孔长度,m。
土地利用系数,居民点、公共用地和其他用地的比例与地下水量折算法相同为27.81%,开展地埋管地源热泵工程时,还要考虑建筑布局、建筑负荷需求、建筑占地面积、资源承载力等因素,取土地利用系数为8.3%(27.81%×0.3)。
(2)换热量现场测试法相关参数:根据式(5-11)~(5-12),在地埋管地源热泵适宜区,利用换热量现场测试法评价可开采资源量的相关参数主要有:综合传热系数[kz,W/(m·℃)]、可钻换热孔数(n)、温差(ΔT)、土地利用系数(T)。
4.浅层地温能资源评价相关参数的分类
由前面评价方法的分析可知,在评价计算浅层地温能资源静态储量和可开采量时需要确定的参数见表5-1。
表5-1资源量评价相关参数分类表
5.浅层地温能资源评价相关参数的意义
(1)区域地质、水文地质条件:浅层地温能资源蕴藏在地下岩土体内,其储藏、运移以及开采利用都受到区域地质、水文地质条件的严格制约,不同区域的资源利用方式和规模存在较大差异,因此,全面了解北京平原区的地质、水文地质条件十分重要。
(2)第四系岩性厚度:北京平原是由多条河流冲洪积作用形成的,在冲洪积扇的顶部至下部,第四系厚度逐渐增大,含水层由单一、厚度较大逐渐过渡为多层、单层厚度较薄,颗粒由粗变细,岩性由砂卵砾石、粘性土互层逐渐过渡为多层的粘砂、粉细砂。
(3)浅层地温能资源条件分区:根据浅层地温能资源开发利用形式的不同,考虑到项目的初投资、运行状况以及地质环境影响等因素,结合北京市不同地区地质、水文地质条件的特点,划分出地下水地源热泵系统的适宜区、较适宜区、一般适宜区和严禁应用区,以及地埋管地源热泵系统的经济区、较经济区和欠经济区。
(4)地下水水位(m):地下水水位是评价浅层地温能资源的一个重要参数。在评价浅层地温能资源静态储量时,将地下水面以上划分为包气带,将地下水面以下划分为饱水带,再分别计算静态储量;在评价地下水地源热泵适宜区可开采资源量时,地下水水位一方面影响单井出水量,一方面也会影响单井回灌量。
(5)变温层厚度(m):地壳按热力状态从上而下分为变温带、常温带、增温带。变温带的地温受气温的控制呈周期性的昼夜变化和年变化,随着深度的增加,变化幅度很快变小。气温的影响趋于零的深度叫常温带,常温带以上地层厚度即为变温层厚度。
(6)岩土体天然密度(g/cm3):单位体积岩土体的质量称为岩土体的密度。
(7)岩土体天然含水率(%):岩土体中水的质量与岩土体颗粒质量之比,称为岩土体的天然含水率。
(8)岩土体孔隙率(%):岩土体中孔隙所占体积与总体积之比称为岩土体的孔隙率。
(9)岩土体热导率[W/(m·℃)]:在岩土体内部垂直于导热方向取两个相距1m,面积为1m2的平行平面,若两个平面的温度相差1℃,则在1秒内从一个平面传导至另一个平面的热量就规定为该岩土体的热导率。
(10)岩土体的比热容[kJ/(kg·℃)]:单位质量的岩土体温度升高1℃吸收的热量(或降低1℃释放的热量)叫做该岩土体的比热容。
(11)单井出水量(qw,m3/d):抽水井的出水量(5m降深)。
(12)单位涌水量[m3/(h·m)]:单位涌水量是井抽水水位降深换算为1m时的单井出水量。
(13)渗透系数(m/d):是综合反映土体渗透能力的一个指标,水力梯度等于1时的渗透流速。
(14)抽水井影响半径(m):机井在抽水时,水位下降,井周围附近含水层的水向井内流动,形成一个以抽水井为中心的水位下降漏斗,这个水位下降漏斗的半径叫影响半径。
(15)土地利用系数(T)[kz,W/(m·℃)]:居民点、公共用地和其他用地的比例。
(16)综合传热系数[kz,W/(m·℃)]:进行换热量现场测试,计量地埋管换热器的进出水温度、流量,在热交换达到稳定的条件下,计算得到钻孔每延长米在温度变化1℃(循环液平均温度与岩土体原始温度比)时的换热量即为综合传热系数。
(17)平均导热系数[kp,W/(m·℃)]:该参数是利用Fluent软件模拟换热孔的温度场影响半径时需要设置的一个重要参数,也是表现当地岩土体平均换热能力的一个重要指标。其定义为在当地水文地质环境下,当传热达到稳定时,假设岩土体是匀质的,在岩土体内部垂直于导热方向取两个相距1m,面积为1m2的平行平面,若两个平面的温度相差1℃,则在1秒内从一个平面传导至另一个平面的热量就是该岩土体的平均导热系数。
③ lasso算法中的y参数指的是什么
比较常用的是auc,这个就是现在比较主流的衡量一个模型好坏的roc所衍生出来的一个值;我们这边用的是class,也就是模型错误分配的概率,结合我这次业务开发的实际业务场景,这个更合适一点;nfolds是指folds数目,也可以通过foldid数来控制每个fold里面的数据数量。
④ PID算法的参数怎么确定
PID是自动控制理论里的一种控制方法,PID的意思分别代表了比例、积分和微分。具体是什么意思呢?解释如下:
首先,我们有一个状态量,这个状态量在整个过程中,我们希望通过输入一个控制量,使这个状态量发生变化,并尽量的接近目标量。比如,在航线控制中,状态量是飞机当前的飞行航向,目标量是飞机为到达目标点而应该飞行的目标航向,控制量则是我们对其进行控制的方向舵面,或横滚角度。我们通过调整方向舵面、横滚角度来控制飞机的当前飞行航向,使之尽量接近为压航线而应该飞行的目标航向。
那么我们如何给出这个控制量,比如给哪个方向的、多大的方向舵量呢?最简单的考虑,是按照当前航向与目标航向的偏差大小来决定给多大的方向舵量:方向舵量p = P * (目标航向 – 当前航向)。这个方向舵量p,就是PID控制里的P部分,即比例部分。
那么,是不是只要有了P,我们的控制就完成了呢?实际上有了P,在大多数情况下,我们可以控制飞机朝目标量去接近,但可能会出现一些情况,比如,当飞机的安装有偏差(我们称之为系统误差),导致我们输出一个左5方向舵给舵机的时候,飞机才能直飞;当不给方向舵,即方向舵放在中位时,飞机会右偏。我们想象一下这个时候如果只有P项控制会有什么后果:假设初始状态是飞机飞行航向和目标航向一致,按P输出飞机方向舵应该在中位。而这时候,由于系统安装误差的存在,会导致飞机偏右,于是偏离了目标航向,然后P项控制会输出一个左舵,来修正航向偏差,刚开始的时候由于偏差量很小,输出的这个左舵也很小,于是飞机继续右偏,然后导致这个左舵加大,最终到达5,使飞机直飞,但这时候的飞行航向与目标航向始终存在一个偏差,这就是P的局限,无法修正系统误差。于是I项积分控制就出场了。
I项的输出这样定义:方向舵量i = I * (偏差和)。偏差和是当前航向和目标航向的偏差,每计算一次累加一次,一直累加到上次的值,再加上这次计算时当前航向和目标航向的偏差。即这个偏差和是跟以前的累积误差有关的。同样是上面的例子,I项的效果就这样体现:当飞机飞行航向与目标航向始终存在偏差时,I项将这个值累加上,比如说是5度吧,于是在P项之上,再叠加一个I*5的修正量,增加了一个左舵,比如说是2,然后导致飞机的飞行航向与目标航向的偏差会小一些。也许这一次计算输出的控制量并没有完全消除误差,但下一次再计算时,如果还有误差,于是会继续再增加输出控制量,使误差再小,于是经过多次计算后,使I项始终输出一个左5的舵量,使误差归零。这就是I项的作用,消除系统误差。
D项的意思是微分。为了便于解释,我们假设不存在系统误差,I项为0。比如当目标航向为0度,当前航向为30度时,根据P项作用,会输出一个左舵,假设为左15吧,使飞机向左转向,于是当前航向逐渐减小,比如减小到20度的时候,P项输出的左舵也会减小到左10。那么,当飞机转到0度时,跟目标航向一致时,P项输出方向舵回到中立位,飞机是否就保持0度直飞了呢?XX是否定的。由于飞机的惯性,飞机在左转弯时产生了一个左转弯的速率,导致飞机航向回到目标航向无偏差且方向舵回中后,仍然还会继续左转,然后产生负的偏差,P项再输出右方向舵,然后再回中。如果P项合适,我们看到的就是一个逐渐收敛于目标航向的飞行航向,即先左过头,然后右过头,再左过头,再右过头……最后过头量越来越小,最终到达目标航向。而D项的作用,就是尽量消除这个过头量,使之尽快贴近目标航向。
D项的定义是:方向舵d = D * (当前状态量 – 上一次的状态量)。在这个例子中,当飞机在从30度的航向,左转弯到0度目标航向的过程中,D项的输出实际上是转弯角速率的比例值,并且方向与P项相反,这样当飞机比较接近0度目标航向时,由于P值已经很小了,而这时候如果转弯速率不小,D项就输出一个右方向舵,抵消过快的转弯速率,阻止飞机航向到达目标航向后继续冲过头。
最后,方向舵量 = 方向舵量p + 方向舵量i + 方向舵量d,为完整的输出。根据飞行的表现,通过对P、I、D系数的调整,最终使输出的控制量能够尽快的控制状态量贴近目标量,并消除系统误差,避免过度震荡。
在完整的固定翼飞控系统中,除了航向通道需要PID控制外,其余需要控制的通道还有:副翼舵->目标横滚角、升降舵->目标俯仰角、目标俯仰角->高度差、油门舵->空速、目标航向->偏航距。
⑤ PID算法的参数怎么确定
不知道你的pid 表是控制什么的,我们用来控制蒸汽薄膜阀动作来控制温度的,而且一般表都有pid 自诊定,表自身能计算出适合的pid 值。我的经迹绝验是,p值最重要,一般p值越小,控制的动作反应越快,I 值和D 值只是帮助控制的效果更好。x0dx0a和你说下在我们设备的一个经验值里,P=3,I=60,D=90,希望对你有所帮助。很多的控制也都是慢慢试验出来的pid 值。因为各种应用场合千差万别,游游不好根据公式计算出pid 值。 x0dx0a以下摘自网络:x0dx0aPID控制方式的具体流程是计算误差和温度的变化速度进行PID计算,先以P参数和误差计算出基础输出量,在根据误差的累积值和I参数计算出修正量,最终找出控制点和温度设定点之间姿磨姿的平衡状态,最后在通过温度的变化速率与D参数控制温度的变化速度以防止温度的剧烈变化。进行整定时先进行P调节,使I和D作用无效,观察温度变化曲线,若变化曲线多次出现波形则应该放大比例(P)参数,若变化曲线非常平缓,则应该缩小比例(P)参数。比例(P)参数设定好后,设定积分(I)参数,积分(I)正好与P参数相反,曲线平缓则需要放大积分(I),出现多次波形则需要缩小积分(I)。比例(P)和积分(I)都设定好以后设定微分(D)参数,微分(D)参数与比例(P)参数的设定方法是一样的。
⑥ 神经网络算法中,参数的设置或者调整,有什么方法可以采用
若果对你有帮助,请点赞。
神经网络的结构(例如2输入3隐节点1输出)建好后,一般就要求神经网络里的权值和阈值。现在一般求解权值和阈值,都是采用梯度下降之类的搜索算法(梯度下降法、牛顿法、列文伯格-马跨特法、狗腿法等等),这些算法会先初始化一个解,在这个解的基础上,确定一个搜索方向和一个移动步长(各种法算确定方向和步长的方法不同,也就使各种算法适用于解决不同的问题),使初始解根据这个方向和步长移动后,能使目标函数的输出(在神经网络中就是预测误差)下降。 然后将它更新为新的解,再继续寻找下一步的移动方向的步长,这样不断的迭代下去,目标函数(神经网络中的预测误差)也不断下降,最终就能找到一个解,使得目标函数(预测误差)比较小。
而在寻解过程中,步长太大,就会搜索得不仔细,可能跨过了优秀的解,而步长太小,又会使寻解过程进行得太慢。因此,步长设置适当非常重要。
学习率对原步长(在梯度下降法中就是梯度的长度)作调整,如果学习率lr = 0.1,那么梯度下降法中每次调整的步长就是0.1*梯度,
而在matlab神经网络工具箱里的lr,代表的是初始学习率。因为matlab工具箱为了在寻解不同阶段更智能的选择合适的步长,使用的是可变学习率,它会根据上一次解的调整对目标函数带来的效果来对学习率作调整,再根据学习率决定步长。
机制如下:
if newE2/E2 > maxE_inc %若果误差上升大于阈值
lr = lr * lr_dec; %则降低学习率
else
if newE2 < E2 %若果误差减少
lr = lr * lr_inc;%则增加学习率
end
详细的可以看《神经网络之家》nnetinfo里的《[重要]写自己的BP神经网络(traingd)》一文,里面是matlab神经网络工具箱梯度下降法的简化代码
若果对你有帮助,请点赞。
祝学习愉快