基于遗传算法的新的异构分布式系统任务调度算法研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

 ⛳️赠与读者

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码、文章


 ⛳️赠与读者

👨‍💻做科研,涉及到一个深在的思想系统,需要科研者逻辑缜密,踏实认真,但是不能只是努力,很多时候借力比努力更重要,然后还要有仰望星空的创新点和启发点。当哲学课上老师问你什么是科学,什么是电的时候,不要觉得这些问题搞笑。哲学是科学之母,哲学就是追究终极问题,寻找那些不言自明只有小孩子会问的但是你却回答不出来的问题。建议读者按目录次序逐一浏览,免得骤然跌入幽暗的迷宫找不到来时的路,它不足为你揭示全部问题的答案,但若能让人胸中升起一朵朵疑云,也未尝不会酿成晚霞斑斓的别一番景致,万一它居然给你带来了一场精神世界的苦雨,那就借机洗刷一下原来存放在那儿的“躺平”上的尘埃吧。

     或许,雨过云收,神驰的天地更清朗.......🔎🔎🔎

💥1 概述

文献来源:

摘要
分布式系统,如网格计算和云计算向全球用户提供 Web 服务。服务提供者最关心的问题之一是如何处理总拥有成本(TCO)。TCO 的大部分与由于资源管理不当导致的能耗有关。任务调度模块作为一个关键组件,对用户响应时间和底层资源利用率都有巨大影响。这种异构分布式系统通过不同速度和架构的不同处理器互连。此外,用户应用通常以有向无环图(DAG)的形式呈现,必须在这种类型的并行处理系统上执行。由于在这种复杂系统中的任务调度属于 NP 难题,现有的启发式方法已不再有效。因此,趋势是应用混合元启发式方法。在本文中,我们扩展了一种基于遗传的元启发式算法,用于最小化用户应用的总执行时间(makespan)的任务调度算法。在这方面,我们利用其他启发式方法,比如异构最早完成时间(HEFT)方法,通过应用一种新的打乱操作符生成智能初始种群,以探索搜索空间中的可行和有前途的个体。我们也正确地进行其他遗传操作符,以生成最终接近最优解的解决方案。为了得出具体结果,我们进行了几个场景的实验。我们提出的算法在平均 makespan 方面优于其他现有方法,如 HEFT 版本和 QGARAR。
关键词:任务调度,云计算,有向无环图(DAG)

文献中已经有许多工作致力于提出分布式系统中任务调度问题的清晰解决方案。一种基于 PSO 的任务调度算法已被提出,用于有效处理科学程序在用户定义的截止期限内对云资源的利用 [7]。这个适应函数是基于执行时间和成本定义在适应函数中的减少 [7]。虽然这种提出的算法很有前景,但它专门设计用于只具有计算密集型的科学问题。另一个基于蚁群优化(ACO)的任务调度算法被用于最小化在云环境中提交的任务的 makespan [8]。这种提出的算法在云计算中运行高效,因为它根据请求的任务启动适当的虚拟机。然而,该算法仅限于独立任务。一种经济实惠的低成本任务调度算法基于两种策略运行;第一种策略基于帕累托支配为任务分配最佳虚拟机。第二种策略通过将下一个阶段中不重要的任务映射来减少总成本[9]。文章中调度算法的主要焦点是经济观点,这可能会牺牲用户响应时间。基于模糊 TOPSIS 的多标准任务调度方法已在第 30 届 IEEE 加拿大电气和计算机工程会议(CCECE)中展示[12]。在这项工作中,作者应用模糊 TOPSIS 方法基于用户和提供者的偏好来排名备选方案。其最初设计用于具有时间限制和独立的实时应用程序。另一个基于启发式的细菌觅食算法已被提出,用于在云计算环境中独立任务调度[14]。尽管效率高,但不适用于具有依赖任务的程序。一种带旋转角度细化的量子遗传算法已被提出在文献中用于对云数据中心等分布式系统的依赖任务进行调度[15]。该提出的算法基本上是一种很好的量子计算方法。它还依赖于随机生成的种群进行初始阶段,以使更多的迭代轮次达到满意的标准。文献综述揭示了混合元启发式方法是有利的,可以从其他方法中获益以达到良好的优化结果,并利用搜索空间中的探索和开发。

📚2 运行结果

部分代码:

%%
global nVM nTask DAG extP0 extP1 extP2 c
nVM=3; % Number of Hetergenous Virtual Machines
c=ones(nVM)-eye(nVM);  % communication time between servers
nTask=11; % Number of Tasks
DAG=[0 12 14 0 0 0 0 0 0 0 0  % Directed Acyclic Graph
     0 0 0 8 15 11 0 0 0 0 0
     0 0 0 0 0 0 13 0 0 0 0
     0 0 0 0 0 0 0 11 0 0 0
     0 0 0 0 0 0 0 8 0 0 0
     0 0 0 0 0 0 0 0 7 12 0
     0 0 0 0 0 0 0 0 0 14 0
     0 0 0 0 0 0 0 0 0 0 15
     0 0 0 0 0 0 0 0 0 0 7
     0 0 0 0 0 0 0 0 0 0 10
     0 0 0 0 0 0 0 0 0 0 0];
extP0=[7 10 5 6 10 11 12 10 8 15 8]; %Execution Time on Processor1
extP1=[9 9 7 8 8 13 15 13 9 11 9];
extP2=[8 14 6 7 6 15 18 7 10 13 10];
Wbar=[8 11 6 7 8 13 15 10 9 13 9]; % Average Computation Cost
npop=20; % population size
maxIter= 100; % maximum number of generation
%% The first generation:
population=INITp(npop);
%% Genetic optimization:
for iter=1:maxIter
    for i=1:npop
        cost(i)=MAPPER(population{i});
        fitness(i)=1/cost(i);

🎉3 参考文献

文章中一些内容引自网络,会注明出处或引用为参考文献,难免有未尽之处,如有不妥,请随时联系删除。

🌈4 Matlab代码、文章

  • 11
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值