CN109347913B - 一种基于智能遗传算法的web服务协同调度方法及系统 - Google Patents

一种基于智能遗传算法的web服务协同调度方法及系统 Download PDF

Info

Publication number
CN109347913B
CN109347913B CN201811066866.7A CN201811066866A CN109347913B CN 109347913 B CN109347913 B CN 109347913B CN 201811066866 A CN201811066866 A CN 201811066866A CN 109347913 B CN109347913 B CN 109347913B
Authority
CN
China
Prior art keywords
service
individuals
population
cooperative
fitness
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201811066866.7A
Other languages
English (en)
Other versions
CN109347913A (zh
Inventor
郭伟
徐卫霞
葛伟
闫中敏
崔立真
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shandong Gaoxintong Network Technology Co ltd
Original Assignee
Shandong University
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shandong University filed Critical Shandong University
Priority to CN201811066866.7A priority Critical patent/CN109347913B/zh
Publication of CN109347913A publication Critical patent/CN109347913A/zh
Application granted granted Critical
Publication of CN109347913B publication Critical patent/CN109347913B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/61Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources taking into account QoS or priority requirements
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/12Computing arrangements based on biological models using genetic models
    • G06N3/126Evolutionary algorithms, e.g. genetic algorithms or genetic programming
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/104Peer-to-peer [P2P] networks
    • H04L67/1044Group management mechanisms 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests

Abstract

本发明公开了一种基于智能遗传算法的web服务协同调度方法及系统,确定协同服务中的服务之间的偏序关系、可用资源数、执行时间和花费,表示协同服务调度的各个元素,确定每个协同服务数组的约束限制条件;对可用资源和协同服务数组分别进行染色体编码;确定协同服务执行成本、整个协同服务执行所需的总时间和协同服务数组的服务质量函数,以协同服务调度目标即是在保证服务质量的前提下,成本并协同服务的执行时间最少为目标,确定目标函数;利用智能遗传算法对目标函数进行求解,对种群进行初始化,在初始种群选取时采用确定初始内点对内修正的方式,进行种群的迭代和选择,在迭代中的选择过程中保留部分低适应度个体并自适应变异率,得到目标结果。

Description

一种基于智能遗传算法的web服务协同调度方法及系统
技术领域
本发明涉及一种基于智能遗传算法的web服务协同调度方法及系统。
背景技术
随着Web服务技术的快速发展和普及,企业内部及企业之间的协同服务得到了快速发展及应用,在协同服务执行中需要根据当前可用资源的情况得到高效的调度方案,从而使得协同服务的执行效率及成本满足用户的需求。因此,在协同服务执行过程中就需要基于用户的QoS(Quality of Service,服务质量)需求对协同服务进行调度来获取最优化执行方案。
对协同服务进行调度来获取最优化执行方案,可以采用蚁群算法、粒子群优化算法、遗传算法等来解决这一类多目标优化问题。但是现有的方法在解决本文所述协同服务调度问题上存在一定的局限性,在解决多目标时序性优化问题上会出现陷于局部最优解、无法解决众多变量的问题等,不适合当前所描述的web服务的协同服务调度问题的解决。
基于这些问题,我们提出了基于传统遗传算法进行改进的智能遗传算法来解决web服务的协调调度问题,在种群初始化、种群间交叉、变异率确定等方面进行了改进。
发明内容
本发明为了解决上述问题,提出了一种基于智能遗传算法的web服务协同调度方法及系统,本发明在传统遗传算法的基础上提高了算法的灵活性和多样性,在初始种群选取时采用确定初始内点对内修正的方式,且将迭代中的选择过程优化为基于种群交流的选择方法来实现选择方式。变异环节中变异因子根据个体的基因质量进行自适应的选取,增强种群的多样性。本发明的技术方案既可以保持个体的多样性,增大优秀个体的概率,加快收敛速度,又不会导致最终结果趋向局部最优解,在解决此类优化问题时具备一定的优势,在解决协同服务调度问题时,可以在保证服务质量的前提下,降低成本,提高协同服务的执行。
为了实现上述目的,本发明采用如下技术方案:
一种基于智能遗传算法的web服务协同调度方法,包括以下步骤:
确定协同服务中的服务之间的偏序关系、可用资源数、执行时间和花费,表示协同服务调度的各个元素,确定每个协同服务数组的约束限制条件;
对可用资源和协同服务数组分别进行染色体编码;
确定协同服务执行成本、整个协同服务执行所需的总时间和协同服务数组的服务质量函数,以协同服务调度目标即是在保证服务质量的前提下,成本并协同服务的执行时间最少为目标,确定目标函数;
利用智能遗传算法对目标函数进行求解,对种群进行初始化,在初始种群选取时采用确定初始内点对内修正的方式,进行种群的迭代和选择,在迭代中的选择过程中保留部分低适应度个体并自适应变异率,得到目标结果。
作为进一步的限定,表示协同服务调度过程中,若协同服务中Web服务数为n且服务之间存在偏序关系、可用资源数为m,并且各可用资源可以执行的Web服务及可执行的最大Web服务数目存在差异,各可用资源执行相同Web服务所需时间、花费和及其可用性也各不相同,则协同服务调度问题的可行解为包含n个元素的一维数组,称之为协同服务数组X。
作为进一步的限定,协同服务数组约束条件包括:每个可用资源执行的Web服务数需要小于等于对应可用资源所能执行的最大服务数;
每个服务都只由一个可用资源执行;
可用资源i执行各服务的服务质量需要高于最低服务质量。
作为进一步的限定,染色体编码中,首先需要对每个可用资源进行染色体编码,定义N为可用资源的数目,则染色体上每个可用资源所占基因位数C为
Figure BDA0001798516920000031
作为进一步的限定,染色体编码中,对可用资源进行编码后,根据协同服务数组中各个元素的赋值情况对染色体进行编码,定义M为协同服务中web服务的数目,则染色体的长度L为L=M·C=Mlog2N,N为可用资源的数目,C为染色体上每个可用资源所占基因位数。
作为进一步的限定,协同服务执行的成本为执行每一web服务的花费之和,每个web服务在所有可用资源上执行的成本表示为矩阵Quote,其中Quoteij表示web服务j在可用资源i上执行的成本,定义协同服务数组X中web服务j在可用资源i上执行得到最终的执行协同服务的总成本Cost:
Figure BDA0001798516920000032
其中Xj=i。
作为进一步的限定,根据协同服务数组X后及协同服务中Web服务之间的偏序关系,以及可用资源执行不同web服务所需时长Tij得最后一个web服务的完成时间Tf,则整个协同服务执行所需的总时间为最后一个web服务的完成时间与第一个web服务的开始执行时间的差值。
作为进一步的限定,协同服务数组的服务质量为该数组内各个可用资源执行各个web服务的服务质量之和。
作为进一步的限定,种群初始化过程中,设置初始种群的数量,先根据随机初始点所占百分比,产生随机初始点,对于每一个随机初始点随机产生一定数量的个体,将个体中满足约束条件的个体保留到初始种群。
作为进一步的限定,对初始点的修正过程为:种群中其余的个体初始化时需要向已产生的个体靠近直到满足约束条件并保留到初始种群中,以此类推直到产生的个体数为设置的种群数量,其中不满足所有约束条件的个体向满足所有约束条件的个体靠近的方法是取两者的中点作为该个体的新值,若仍不满足所有约束条件则再次取两者中点作为自己的新值直到满足所有的约束条件。
作为进一步的限定,对修正后的种群取中点操作,对两个个体中每个服务提供商所提供的服务数目进行统计,然后对每个服务提供商的服务数目进行取中点操作,对未分配出去的任务采用随机生成服务提供商编号的形式产生服务的提供商。
作为进一步的限定,对种群的选择过程包括以下步骤:
对种群个体进行随机四等分,分成A1,A2,B1,B2四个子种群;
选择A1,B1子种群进行基于轮盘赌的种群间交叉;
选择A2,B2子种群进行基于锦标赛的种群间交叉。
作为更进一步的限定,基于轮盘赌的种群间交叉的具体过程包括:
a.轮盘赌选择个体:根据个体的适应度值确定个体被选择的概率,适应度越大的个体被选择的概率就越大,按照种群中个体的适应度为个体分配在随机数区间的位置,根据随机数确定要获取的个体,重复该操作,直到种群中全部个体都被取出。
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变。
作为更进一步的限定,基于锦标赛的种群间交叉的具体过程包括:
a.基于锦标赛方法选择个体:每次从种群中取出一定数量个体且不放回抽样,然后选择其中最好的一个进入子代种群,重复该操作,直到种群中的个体被全部取出;
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变。
保留部分低适应度个体并自适应变异率方法,包括以下步骤:
留部分低适应度个体:根据实验结果来动态调整定义低适应度的阈值及其保留比例;
根据上一代的适应度进行判定子代的突变率要,具体的突变率确定方法如表所示,其中S表示正常状态下的突变率,确定个体的适应度高或低的阈值需要根据实验数据来动态确定。
F_Entity适应度高于设定值 F_Entity适应度低于设定值
M_Entity适应度高于设定值 S/2 S
M_Entity适应度低于设定值 S 4S
一种基于智能遗传算法的web服务协同调度系统,运行于处理器或存储器上,被配置为执行以下指令:
确定协同服务中的服务之间的偏序关系、可用资源数、执行时间和花费,表示协同服务调度的各个元素,确定每个协同服务数组的约束限制条件;
对可用资源和协同服务数组分别进行染色体编码;
确定协同服务执行成本、整个协同服务执行所需的总时间和协同服务数组的服务质量函数,以协同服务调度目标即是在保证服务质量的前提下,成本并协同服务的执行时间最少为目标,确定目标函数;
利用智能遗传算法对目标函数进行求解,对种群进行初始化,在初始种群选取时采用确定初始内点对内修正的方式,进行种群的迭代和选择,在迭代中的选择过程中保留部分低适应度个体并自适应变异率,得到目标结果。
与现有技术相比,本发明的有益效果为:
本发明采用的是协同服务数组来表示每一次协调调度的结果,每个协同服务数组都需要满足一定的约束条件。通过对染色体进行二进制编码来降低染色体所占空间;
本发明提出的i-GA中采用自适应突变率的方法来动态确定个体的突变率,进一步提高种群的多样性和进化速度。在确定个体的突变率时,会搜索该个体的父亲、母亲(即交叉产生该个体的两个个体),根据其父母亲的适应度确定该个体的突变率。
本发明可以保持个体的多样性,增大优秀个体的概率,加快收敛速度,又不会导致最终结果趋向局部最优解,在解决此类优化问题时具备一定的优势,针对协同服务调度问题,可以在保证服务质量的前提下,大幅降低成本。
附图说明
构成本申请的一部分的说明书附图用来提供对本申请的进一步理解,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。
图1是本发明的流程示意图;
图2是本发明的基于种群交流的选择方法模型图;
具体实施方式:
下面结合附图与实施例对本发明作进一步说明。
应该指出,以下详细说明都是例示性的,旨在对本申请提供进一步的说明。除非另有指明,本文使用的所有技术和科学术语具有与本申请所属技术领域的普通技术人员通常理解的相同含义。
需要注意的是,这里所使用的术语仅是为了描述具体实施方式,而非意图限制根据本申请的示例性实施方式。如在这里所使用的,除非上下文另外明确指出,否则单数形式也意图包括复数形式,此外,还应当理解的是,当在本说明书中使用术语“包含”和/或“包括”时,其指明存在特征、步骤、操作、器件、组件和/或它们的组合。
在本发明中,术语如“上”、“下”、“左”、“右”、“前”、“后”、“竖直”、“水平”、“侧”、“底”等指示的方位或位置关系为基于附图所示的方位或位置关系,只是为了便于叙述本发明各部件或元件结构关系而确定的关系词,并非特指本发明中任一部件或元件,不能理解为对本发明的限制。
本发明中,术语如“固接”、“相连”、“连接”等应做广义理解,表示可以是固定连接,也可以是一体地连接或可拆卸连接;可以是直接相连,也可以通过中间媒介间接相连。对于本领域的相关科研或技术人员,可以根据具体情况确定上述术语在本发明中的具体含义,不能理解为对本发明的限制。
本发明主要包括协同服务调度的表示方法、目标模型确定、种群初始化、种群间交叉、保留部分低适应度个体并自适应变异率五个部分。
1.协同服务调度的表示方法,步骤如下:
步骤一:确定表示方法。
若协同服务中Web服务数为n且服务之间存在偏序关系、可用资源数为m,并且各可用资源可以执行的Web服务及可执行的最大Web服务数目存在差异,各可用资源执行相同Web服务所需时间、花费和及其可用性也各不相同,则协同服务调度问题的可行解为包含n个元素的一维数组,本文中称之为协同服务数组X。定义i为执行第j个Web服务的资源编号,则协同服务数组的任意元素Xj可表示为:Xj=i
步骤二:确定约束条件。
对于每一个协同服务数组X有如下限制:
条件1:将可用资源所能执行的Web服务的最大数目表示为集合M,其中Mi表示可用资源i所能执行的最大服务数。集合C用于表示当前协同服务数组X中各个可用资源执行的服务数目,其中Ci表示可用资源i执行的服务总数,则i执行的Web服务数需满足以下条件:Si≤Mi
条件2:由于协同服务数组X为线性结构,每个位置只会存在一个元素,故直接满足了每个服务都只由一个可用资源执行的约束条件。所以在之后的内容和实验中不再考虑该条件对结果的约束作用。
条件3:将可用资源执行的Web服务的质量表示为矩阵T,其中Tij表示可用资源i执行服务j的服务质量。用户对于服务质量的最低要求表示为集合Y,其中Yj表示用户对于服务j的最低服务质量。定义协同服务数组X中由i执行服务j,则可用资源执行服务需要满足以下条件:Yj≤Tij
步骤三:染色体编码
①首先需要对每个可用资源进行染色体编码。定义N为可用资源的数目,则染色体上每个可用资源所占基因位数C如下式确定:
Figure BDA0001798516920000091
在传统表达方式中上述染色体需要N位来分别表示每个可用资源,采用上述公式的方式可以在传统表达方式基础上压缩染色体的长度,减少实验中的内存消耗,提升整个种群的进化速度。
②对每个协同服务数组X进行染色体编码。对可用资源进行编码后,根据X中各个元素的赋值情况对染色体进行编码。定义M为协同服务中web服务的数目,则染色体的长度L如下所示:L=M·C=M log2N
例如,可用资源的数目N=6,则根据公式(4)确定染色体上每个可用资源所占基因位数C=3,则其中一种对可用资源的编码如下:
可用资源 1 2 3 4 5 6
编码 000 001 010 011 100 101
定义协同服务中web服务数目M=9,则整体染色体长度为27,染色体编码如下:
000101000011010001000101100
2.目标模型的确定包括以下几个步骤:
步骤一:成本模型。
协同服务执行的成本为执行每一web服务的花费之和。每个web服务在所有可用资源上执行的成本可表示为矩阵Quote,其中Quoteij表示web服务j在可用资源i上执行的成本。定义协同服务数组X中web服务j在可用资源i上执行,可以得到最终的执行协同服务的总成本Cost:
Figure BDA0001798516920000101
其中Xj=i
当产生一个协同服务数组X后做如上运算,即得到执行协同服务的总成本,根据每个协同服务数组X所得的Cost可以比较得到最小成本及最小成本对应的最优协同服务调度方案。
步骤二:时间模型
在协同服务调度问题中将协同服务中第一个web服务的开始执行时间Ts设置为0。根据协同服务数组X后及协同服务中Web服务之间的偏序关系,以及可用资源执行不同web服务所需时长Tij可得最后一个web服务的完成时间Tf。矩阵T存储每个可用资源执行每个web服务的完成时长,其为一个N*M的矩阵,其中Tij为可用资源i执行web服务j的完成时长,矩阵的M列对应于M个web服务,M个web服务存在时间上的拓扑序列。整个协同服务执行所需的总时间Time为:
Time=Tf-TS
步骤三:服务质量模型
鉴于可用资源的计算能力、内存、网络带宽等诸多方面存在差异,故每个可用资源在执行相同Web服务时的服务质量不同。将可用资源在执行Web服务时的服务质量表示为矩阵T,其中Tij表示可用资源i执行web服务j的服务质量,则协同服务数组X对应的服务质量Quality如下所示:
Figure BDA0001798516920000111
其中Xj=i
步骤四:模型目标确定
协同服务调度目标即是在保证服务质量的前提下,尽可能降低成本并减少协同服务的执行时间。由此,建立目标函数如下:
Fitness=min(a·Cost+b·Time+(1-a-b)·Quality)。
Fitness的参数a,b根据用户对各个因素的侧重程度来制定。
3.种群初始化方法,包括以下三个步骤:
步骤一:初始内点确定。
设置初始种群的数量为population_Size,先根据随机初始点(随机初始点是指初始条件下随机产生的符合约束条件的个体)所占百分比M产生随机初始点,即随机初始点的数目为population_Size*M。对于每一个随机初始点随机产生entity_Size个个体,entity_Size个个体中满足约束条件的个体保留到初始种群population中
步骤二:根据初始内点向内修正。
种群中其余的个体初始化时需要向已产生的个体靠近直到满足约束条件并保留到初始种群population中,以此类推直到产生的个体数为population_Size。其中不满足所有约束条件的个体向满足所有约束条件的个体靠近的方法是取两者的中点作为该个体的新值,若仍不满足所有约束条件则再次取两者中点作为自己的新值直到满足所有的约束条件。通过随机产生部分初始点、其他节点向其靠近的方式进行种群初始化虽然会在一定程度上降低初始种群的多样性,但该初始化种群方式对种群多样性影响可以通过随机初始化点的占比M进行调节,并不会很大程度上降低初始种群的多样性,并且该方式对于种群的初始化时长会有很大提升。
步骤三:取中点操作。
在取两个个体的中点形成新个体时,需要先对两个个体中每个服务提供商所提供的服务数目进行统计,然后对每个服务提供商的服务数目进行取中点操作。例如:初始个体A中编号为1的服务提供商共提供5个服务,而趋近初始个体A的个体B中编号为1的服务提供商共提供3个服务,则新形成的个体B中编号为1的服务提供商共提供4个服务,而这4个服务的编号随机产生。最后对未分配出去的任务采用随机生成服务提供商编号的形式产生服务的提供商。
4.基于种群交流的选择方法,包括以下三个步骤:
步骤一:对种群个体进行四等分,分成A1,A2,B1,B2四个子种群。
a.种群划分过程:种群划分过程要最大化的保证划分的随机性,本文采用的是按顺序对四个子种群进行个体的存放,选择存放个体时采用随机选择的方式产生目标个体。
步骤二:选择A1,B1子种群进行基于轮盘赌的种群间交叉
a.轮盘赌选择个体:根据个体的适应度值确定个体被选择的概率,本次规定适应度越大的个体被选择的概率就越大。按照种群中个体的适应度为个体分配在随机数区间的位置,根据随机数确定要获取的个体。重复该操作,直到种群中全部个体都被取出。
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变。
步骤三:选择A2,B2子种群进行基于锦标赛的种群间交叉
a.基于锦标赛方法选择个体:每次从种群中取出一定数量个体(不放回抽样),然后选择其中最好的一个进入子代种群。重复该操作,直到种群中的个体被全部取出。
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变。
5.保留部分低适应度个体并自适应变异率方法,主要包括以下两个步骤:
步骤一:留部分低适应度个体。
根据实验结果来动态调整定义低适应度的阈值及其保留比例。根据实验所得,低适应度个体的保留比例在0.1时实验结果最佳。由于适应度与问题的解相关,故随着实验条件的不同,低适应度个体的适应度阈值也随之发生变化。
步骤二:自适应突变率。
子代的突变率需要根据上一代的适应度进行判定,具体的突变率确定方法如下表所示:其中S表示正常状态下的突变率,确定个体的适应度高或低的阈值需要根据实验数据来动态确定。
Figure BDA0001798516920000131
Figure BDA0001798516920000141
以上所述仅为本申请的优选实施例而已,并不用于限制本申请,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。
上述虽然结合附图对本发明的具体实施方式进行了描述,但并非对本发明保护范围的限制,所属领域技术人员应该明白,在本发明的技术方案的基础上,本领域技术人员不需要付出创造性劳动即可做出的各种修改或变形仍在本发明的保护范围以内。

Claims (7)

1.一种基于智能遗传算法的web服务协同调度方法,其特征是:包括以下步骤:
确定协同服务中的服务之间的偏序关系、可用资源数、执行时间和花费、表示协同服务调度的各个元素,确定每个协同服务数组的约束限制条件,包括:
每个可用资源执行的Web服务数需要小于等于对应可用资源所能执行的最大服务数;
每个服务都只由一个可用资源执行;
可用资源i执行各服务的服务质量需要高于最低服务质量;
对可用资源和协同服务数组分别进行染色体编码:染色体编码中,首先需要对每个可用资源进行染色体编码,定义N为可用资源的数目,则染色体上每个可用资源所占基因位数C为
Figure FDA0002399893990000011
染色体编码中,对可用资源进行编码后,根据协同服务数组中各个元素的赋值情况对染色体进行编码,定义M为协同服务中web服务的数目,则染色体的长度L为
Figure FDA0002399893990000012
确定协同服务执行成本、整个协同服务执行所需的总时间和协同服务数组的服务质量函数,以协同服务调度目标即是在保证服务质量的前提下,将成本及协同服务的执行时间降为最少为目标,确定目标函数;
利用智能遗传算法对目标函数进行求解,对种群进行初始化,在初始种群选取时采用确定初始内点对内修正的方式,进行种群的迭代和选择,在迭代和选择过程中保留部分低适应度个体并自适应变异率,得到目标结果;
保留部分低适应度个体并自适应变异率方法,包括以下步骤:
保留部分低适应度个体:根据实验结果来动态调整定义低适应度的阈值及其保留比例;
根据上一代的适应度进行判定子代的突变率,具体的突变率确定方法如表所示:
F_Entity适应度高于设定值 F_Entity适应度低于设定值 M_Entity适应度高于设定值 S/2 S M_Entity适应度低于设定值 S 4S
其中S表示正常状态下的突变率,M_Entity表示子代的母亲个体,F_Entity表示子代的父亲个体,俩者进行交叉操作产生子代个体。
2.如权利要求1所述的一种基于智能遗传算法的web服务协同调度方法,其特征是:协同服务执行的成本为执行每一web服务的花费之和,每个web服务在所有可用资源上执行的成本表示为矩阵Quote,其中Quoteij表示web服务j在可用资源i上执行的成本,定义协同服务数组X中web服务j在可用资源i上执行得到最终的执行协同服务的总成本Cost:
Figure FDA0002399893990000021
其中Xj=i,xj用于表示协同服务数组X中第j个web服务的元素。
3.如权利要求1所述的一种基于智能遗传算法的web服务协同调度方法,其特征是:根据协同服务数组X及协同服务中Web服务之间的偏序关系,以及可用资源执行不同web服务所需时长Tij得最后一个web服务的完成时间Tf,则整个协同服务执行所需的总时间为最后一个web服务的完成时间与第一个web服务的开始执行时间的差值。
4.如权利要求1所述的一种基于智能遗传算法的web服务协同调度方法,其特征是:种群初始化过程中,设置初始种群的数量,先根据随机初始点所占百分比,产生随机初始点,对于每一个随机初始点随机产生一定数量的个体,将个体中满足约束条件的个体保留到初始种群;
对初始点的修正过程为:种群中其余的个体初始化时需要向已产生的个体靠近直到满足约束条件并保留到初始种群中,以此类推直到产生的个体数为设置的种群数量,其中不满足所有约束条件的个体向满足所有约束条件的个体靠近的方法是取两者的中点作为该个体的新值,若仍不满足所有约束条件则再次取两者中点作为自己的新值直到满足所有的约束条件;
对修正后的种群取中点操作,对两个个体中每个服务提供商所提供的服务数目进行统计,然后对每个服务提供商的服务数目进行取中点操作,对未分配出去的任务采用随机生成服务提供商编号的形式产生服务的提供商。
5.如权利要求1所述的一种基于智能遗传算法的web服务协同调度方法,其特征是:对种群的选择过程包括以下步骤:
对种群个体进行随机四等分,分成A1,A2,B1,B2四个子种群;
选择A1,B1子种群进行基于轮盘赌的种群间交叉;
选择A2,B2子种群进行基于锦标赛的种群间交叉。
6.如权利要求5所述的一种基于智能遗传算法的web服务协同调度方法,其特征是:基于轮盘赌的种群间交叉的具体过程包括:
a.轮盘赌选择个体:根据个体的适应度值确定个体被选择的概率,适应度越大的个体被选择的概率就越大,按照种群中个体的适应度为个体分配在随机数区间的位置,根据随机数确定要获取的个体,重复该操作,直到种群中全部个体都被取出;
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L位置的元素及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变;
基于锦标赛的种群间交叉的具体过程包括:
a.基于锦标赛方法选择个体:每次从种群中取出一定数量个体且不放回抽样,然后选择其中最好的一个进入子代种群,重复该操作,直到种群中的个体被全部取出;
b.种群间交叉:每取出两个个体a,b后进行一次交叉操作,随机产生交叉的基因位置L,取a的前L个元素作为子代的前L个元素,b的L位置的元素及其之后的元素作为子代的剩余元素,基因编码的顺序保持不变。
7.一种基于智能遗传算法的web服务协同调度系统,其特征是:所述系统包括处理器和存储器,存储器上保存的指令被处理器执行时实现以下步骤:
确定协同服务中的服务之间的偏序关系、可用资源数、执行时间和花费、表示协同服务调度的各个元素,确定每个协同服务数组的约束限制条件,包括:
每个可用资源执行的Web服务数需要小于等于对应可用资源所能执行的最大服务数;
每个服务都只由一个可用资源执行;
可用资源i执行各服务的服务质量需要高于最低服务质量;
对可用资源和协同服务数组分别进行染色体编码:染色体编码中,首先需要对每个可用资源进行染色体编码,定义N为可用资源的数目,则染色体上每个可用资源所占基因位数C为
Figure FDA0002399893990000051
染色体编码中,对可用资源进行编码后,根据协同服务数组中各个元素的赋值情况对染色体进行编码,定义M为协同服务中web服务的数目,则染色体的长度L为
Figure FDA0002399893990000052
确定协同服务执行成本、整个协同服务执行所需的总时间和协同服务数组的服务质量函数,以协同服务调度目标即是在保证服务质量的前提下,将成本及协同服务的执行时间降为最少为目标,确定目标函数;
利用智能遗传算法对目标函数进行求解,对种群进行初始化,在初始种群选取时采用确定初始内点对内修正的方式,进行种群的迭代和选择,在迭代和选择过程中保留部分低适应度个体并自适应变异率,得到目标结果;
保留部分低适应度个体并自适应变异率方法,包括以下步骤:
保留部分低适应度个体:根据实验结果来动态调整定义低适应度的阈值及其保留比例;
根据上一代的适应度进行判定子代的突变率,具体的突变率确定方法如表所示:
F_Entity适应度高于设定值 F_Entity适应度低于设定值 M_Entity适应度高于设定值 S/2 S M_Entity适应度低于设定值 S 4S
其中S表示正常状态下的突变率,M_Entity表示子代的母亲个体,F_Entity表示子代的父亲个体,俩者进行交叉操作产生子代个体。
CN201811066866.7A 2018-09-13 2018-09-13 一种基于智能遗传算法的web服务协同调度方法及系统 Active CN109347913B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811066866.7A CN109347913B (zh) 2018-09-13 2018-09-13 一种基于智能遗传算法的web服务协同调度方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811066866.7A CN109347913B (zh) 2018-09-13 2018-09-13 一种基于智能遗传算法的web服务协同调度方法及系统

Publications (2)

Publication Number Publication Date
CN109347913A CN109347913A (zh) 2019-02-15
CN109347913B true CN109347913B (zh) 2020-05-12

Family

ID=65305500

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811066866.7A Active CN109347913B (zh) 2018-09-13 2018-09-13 一种基于智能遗传算法的web服务协同调度方法及系统

Country Status (1)

Country Link
CN (1) CN109347913B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111768851B (zh) * 2020-06-22 2023-10-03 杭州电子科技大学 一种动态需求下多级别家庭护理调度方法及系统

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103150629A (zh) * 2013-03-11 2013-06-12 上海电力学院 基于相关机会二层规划模型的输电网规划方法
CN103279796A (zh) * 2013-06-08 2013-09-04 苏州大学 一种优化遗传算法进化质量的方法
CN103489042A (zh) * 2013-09-17 2014-01-01 中国科学院深圳先进技术研究院 一种灾害应急决策系统路径优化的方法
CN103870647A (zh) * 2014-03-14 2014-06-18 西安工业大学 一种基于遗传算法的作业车间调度建模的方法
CN106875094A (zh) * 2017-01-11 2017-06-20 陕西科技大学 一种基于多色集合遗传算法的多目标车间调度方法
CN107172166A (zh) * 2017-05-27 2017-09-15 电子科技大学 面向工业智能化服务的云雾计算系统
CN107977740A (zh) * 2017-11-23 2018-05-01 海南电网有限责任公司 一种现场运维智能调度方法
CN108492025A (zh) * 2018-03-20 2018-09-04 合肥工业大学 基于混合差分遗传算法的高端装备制造过程协同调度方法

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104461728B (zh) * 2013-09-18 2019-06-14 Sap欧洲公司 迁移事件调度管理的计算机系统、介质和方法
CN107578119A (zh) * 2017-08-09 2018-01-12 泉州装备制造研究所 一种智能调度系统的资源分配全局优化方法

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103150629A (zh) * 2013-03-11 2013-06-12 上海电力学院 基于相关机会二层规划模型的输电网规划方法
CN103279796A (zh) * 2013-06-08 2013-09-04 苏州大学 一种优化遗传算法进化质量的方法
CN103489042A (zh) * 2013-09-17 2014-01-01 中国科学院深圳先进技术研究院 一种灾害应急决策系统路径优化的方法
CN103870647A (zh) * 2014-03-14 2014-06-18 西安工业大学 一种基于遗传算法的作业车间调度建模的方法
CN106875094A (zh) * 2017-01-11 2017-06-20 陕西科技大学 一种基于多色集合遗传算法的多目标车间调度方法
CN107172166A (zh) * 2017-05-27 2017-09-15 电子科技大学 面向工业智能化服务的云雾计算系统
CN107977740A (zh) * 2017-11-23 2018-05-01 海南电网有限责任公司 一种现场运维智能调度方法
CN108492025A (zh) * 2018-03-20 2018-09-04 合肥工业大学 基于混合差分遗传算法的高端装备制造过程协同调度方法

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
云计算环境中数据放置及复制策略研究;郭伟;《中国博士学位论文全文数据库(电子期刊)》;20160115;全文 *
利用遗传算法求解应急物资调度优化问题;赵明等;《沈阳建筑大学学报(自然科学版)》;20120930;全文 *

Also Published As

Publication number Publication date
CN109347913A (zh) 2019-02-15

Similar Documents

Publication Publication Date Title
CN111182582B (zh) 面向移动边缘计算的多任务分布式卸载方法
CN109474980A (zh) 一种基于深度增强学习的无线网络资源分配方法
CN110389819B (zh) 一种计算密集型批处理任务的调度方法和系统
CN111585816A (zh) 一种基于自适应遗传算法的任务卸载决策方法
CN112380008A (zh) 一种面向移动边缘计算应用的多用户细粒度任务卸载调度方法
CN111325356A (zh) 一种基于演化计算的神经网络搜索分布式训练系统及训练方法
CN112181598B (zh) 基于改进遗传算法的云计算任务调度方法
CN114565239B (zh) 用于产业园区的综合低碳能源调度方法及系统
CN111628855A (zh) 基于深度强化学习的工业5g动态多优先级多接入方法
CN110162390B (zh) 一种雾计算系统的任务分配方法及系统
US20220374722A1 (en) Intelligent ammunition co-evolution task assignment method
CN112202847B (zh) 一种基于移动边缘计算的服务器资源配置方法
CN104684095A (zh) 一种异构网络融合场景中基于遗传运算的资源分配方法
CN112261725A (zh) 一种基于深度强化学习的数据包传输智能决策方法
CN109347913B (zh) 一种基于智能遗传算法的web服务协同调度方法及系统
CN106411469A (zh) 基于多基站异构网络中可伸缩视频的多播资源分配及传输方法
Ghanshala et al. Self-organizing sustainable spectrum management methodology in cognitive radio vehicular adhoc network (CRAVENET) environment: a reinforcement learning approach
CN103347299A (zh) 一种基于遗传算法的集中式资源管理方法
CN110505681B (zh) 基于遗传方法的非正交多址接入场景用户配对方法
CN116800753A (zh) 一种移动模型通信资源分配方法、装置、终端及存储介质
CN114493090A (zh) 工业园区综合能源智能管控方法及装置
CN111290853B (zh) 一种基于自适应改进遗传算法的云数据中心调度方法
CN113326135B (zh) 一种多目标下的云资源调度方法
CN113269324B (zh) 一种基于遗传算法的低轨卫星时间窗规划方法及系统
CN110677913B (zh) 一种eh分布式基站系统的动态功率分配方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
TR01 Transfer of patent right

Effective date of registration: 20220429

Address after: 250101 Room 203, floor 2, building a3-5, Hanyu Golden Valley, No. 2000, jingshidong Road, high tech Zone, Jinan, Shandong Province

Patentee after: Shandong gaoxintong Network Technology Co.,Ltd.

Address before: 250101 no.1500 Shunhua Road, high tech Zone, Jinan City, Shandong Province

Patentee before: SHANDONG University

TR01 Transfer of patent right