- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
最佳调度的回溯算法.
实验目的:
理解回溯法的原理,掌握调度问题的处理方法,实现最佳调度问题的回溯解决。
?
问题定义
输入:
1.?????? 任务数N
2.?????? 机器数M
3.?????? 随机序列长度t[i],其中t[i]=x表示第i个任务完成需要时间单位x,
输出:
1.?????? 开销时间besttime,表示最佳调度需要时间单位
2.?????? 最佳调度序列bestx[],其中bestx[i]=x,表示将第i个任务分配给第x个机器执行。
实验思想
解空间的表示:
一个深度为N的M叉树。
基本思路:搜索从开始结点(根结点)出发,以DFS搜索整个解空间。
每搜索完一条路径则记录下besttime 和bestx[]序列
开始结点就成为一个活结点,同时也成为当前的扩展结点。在当前的扩展结点处向纵深方向移至一个新结点,并成为一个新的活结点,也成为当前扩展结点。
如果在当前的扩展结点处不能再向纵深方向扩展,则当前扩展结点就成为死结点。
此时,应往回移动(回溯)至最近的一个活结点处,并使这个活结点成为当前的扩展结点;直至找到一个解或全部解。
测试数据及结果
本测试的硬件以及软件环境如下
CPU:PM 1.5G; 内存:768M;操作系统:windows xp sp2;软件平台:JDK1.5;开发环境:eclipse
如图1所示:即为求任务数为10机器数为5的最佳调度的算法结果。
图1
实验结论以及算法分析
通过测试证明算法正确有效。
性能分析的方法:使用JDK 1.5的System.nanoTime(),计算算法消耗的时间,以此来评价算法。(该方法在JDK1.5以下的版本中不支持)
为了不影响算法的准确度,在测试的过程我们注释掉了打印随机字符串的步骤。
由于没有使用限界函数进行优化,算法时间和空间复杂度呈指数级增长。所以该算法不适合较大规模的计算。
图2
图2 蓝线表示机器数一定M=3时,n增大时求解最佳调度对所消耗的时间,该趋势随着指数增加。
图3
图3表示任务数N一定时随着M的增大的增长曲线。
图2和图3表明该程序的时间复杂度与理论分析相符合。
源代码
最佳调度的回溯算法(java描述)
BestSchedule.Java
package?bestSchedule;import?java.util.Random;public?class?BestSchedule?...{????/**?*//**?????*?@author?icyfire?????*?本程序是采用回溯法解决最佳调度问题?????*??????*/
????int?N;????????//任务数????int?M;????????//机器数????int?best;?????//最优值????int[]?t;??????//每个任务所需的时间序列????int[]?len;????//每台机器所需时间序列????int[]?x;??????//当前路径????int[]?bestx;??//最优调度:其中bestx[i]=m表示把第i项任务分配给第m台机器???????????? public?static?void?main(String[]?args)?...{?????BestSchedule?bs?=new?BestSchedule(); //进入主方法,那就先创建一个对象;?????bs.showTest(); //然后,就开始调用自己的方法,开始求解吧!????}????????void?showTest()???...{?????????N=3 //为了简单点就先小点吧。。。N=10;?//?任务数?????????M=2 //同上,M=7;?//机器数目????????Random?r?=new?Random(); //java果真比较狠,连个随机数都是一个类的对象!????????t=new?int?[N];?//每个任务的时间????????//int?sum=0;????????for?(int?i?=0;iN;i++)????????...{????????????t[i]=r.nextInt(5*N); //这个会是什么东西呢,噢,是随机的给每个任务分配 //时间。天,不带这么玩的吧!????????????//sum+=t[i];???????? }????????len?=new?int?[M];??????//记录每台机器已经安排的时间????
????????best?=?Integer.MAX_VALUE;?? //这又是
您可能关注的文档
- 最优化及最优控制计算研究精确罚函数途径《上海大学》2014年博士论文..doc
- 最优化复习材料..doc
- 最优化实验的两个案例..doc
- 最优化方法(线性规划)用Lingo对线性规划进行灵敏度分析..doc
- 最优化方法教学大纲12版..doc
- 最优化方法用Lingo对线性规划进行灵敏度分析..doc
- 最优化方法讲稿..doc
- 最优化方法论文..doc
- 最优化方法课程设计..doc
- 最优化理论与方法..doc
- 《农村土地流转政策实施对农业规模化经营区域农业现代化进程的影响》教学研究课题报告.docx
- 《金融开放与金融监管变革:中国金融监管体系改革趋势与前瞻》教学研究课题报告.docx
- 基于大数据的初中学校教学质量均衡化决策模型构建与应用教学研究课题报告.docx
- 初中英语写作应用数字教育资源设计与开发中的版权问题与合规性分析教学研究课题报告.docx
- 小学政治课程中法治观念与公民权利意识培养研究教学研究课题报告[001].docx
- 《心血管内科药物治疗监护中临床药师对新型药物的临床应用研究》教学研究课题报告.docx
- 《区块链技术在电子政务招投标领域的应用与风险防范》教学研究课题报告.docx
- 4 《商业银行财富管理业务在金融市场中风险控制与合规监管研究》教学研究课题报告.docx
- 高中历史《中国近代史》单元复习课近代史事件分析教学策略探讨教学研究课题报告.docx
- 基于人工智能的初中化学学习困难学生精准帮扶与效果评估教学研究课题报告.docx
文档评论(0)