回溯法-作业调度

问题定义

输入:

1.       任务数N

2.       机器数M

3.       随机序列长度t[i],其中t[i]=x表示第i个任务完成需要时间单位x

输出:

1.       开销时间besttime,表示最佳调度需要时间单位

2.       最佳调度序列bestx[],其中bestx[i]=x,表示将第i个任务分配给第x个机器执行。

实验思想

解空间的表示:

一个深度为NM叉树。

基本思路:搜索从开始结点(根结点)出发,以DFS搜索整个解空间。

         每搜索完一条路径则记录下besttime bestx[]序列

开始结点就成为一个活结点,同时也成为当前的扩展结点。在当前的扩展结点处向纵深方向移至一个新结点,并成为一个新的活结点,也成为当前扩展结点。

如果在当前的扩展结点处不能再向纵深方向扩展,则当前扩展结点就成为死结点。

此时,应往回移动(回溯)至最近的一个活结点处,并使这个活结点成为当前的扩展结点;直至找到一个解或全部解。

        

测试数据及结果

本测试的硬件以及软件环境如下

         CPUPM 1.5G; 内存:768M;操作系统:windows xp sp2;软件平台:JDK1.5;开发环境:eclipse

         如图1所示:即为求任务数为10机器数为5的最佳调度的算法结果。

《回溯法-作业调度》

1

实验结论以及算法分析

通过测试证明算法正确有效。

性能分析的方法:使用JDK 1.5System.nanoTime(),计算算法消耗的时间,以此来评价算法。(该方法在JDK1.5以下的版本中不支持)

为了不影响算法的准确度,在测试的过程我们注释掉了打印随机字符串的步骤。

由于没有使用限界函数进行优化,算法时间和空间复杂度呈指数级增长。所以该算法不适合较大规模的计算。

  
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
=10// 任务数
《回溯法-作业调度》
         M=7//机器数目
《回溯法-作业调度》
        Random r =new Random();
《回溯法-作业调度》        t
=new int [N]; //每个任务的时间
《回溯法-作业调度》        
//int sum=0;
《回溯法-作业调度》
        for (int i =0;i<N;i++)
《回溯法-作业调度》        
{
《回溯法-作业调度》            t[i]
=r.nextInt(5*N);
《回溯法-作业调度》            
//sum+=t[i];
《回溯法-作业调度》
        }

《回溯法-作业调度》        len 
=new int [M];      //记录每台机器已经安排的时间
《回溯法-作业调度》
    
《回溯法-作业调度》        best 
= Integer.MAX_VALUE;  
《回溯法-作业调度》        bestx
=new int [N];
《回溯法-作业调度》        x 
=new int[N];
《回溯法-作业调度》        
《回溯法-作业调度》        Long startTime 
= System.nanoTime();
《回溯法-作业调度》        backtrack(
0);
《回溯法-作业调度》        Long endTime 
= System.nanoTime();
《回溯法-作业调度》        System.out.println(
Totle time is  + (endTime  startTime) +  ns);
《回溯法-作业调度》        
《回溯法-作业调度》        System.out.println(
best time:);
《回溯法-作业调度》        System.out.println(best);
《回溯法-作业调度》        System.out.println(
each job costs:);
《回溯法-作业调度》        
for (int i=0;i<N;i++)
《回溯法-作业调度》            System.out.print(t[i]
+  );
《回溯法-作业调度》        System.out.println(
 best schedule:);
《回溯法-作业调度》        
for (int i=0;i<N;i++)
《回溯法-作业调度》            System.out.print(bestx[i]
+  );
《回溯法-作业调度》        
《回溯法-作业调度》            
《回溯法-作业调度》        }

《回溯法-作业调度》    
//回溯搜索
《回溯法-作业调度》
    void backtrack (int dep)
《回溯法-作业调度》    
{
《回溯法-作业调度》        
《回溯法-作业调度》        
if (dep==N)
《回溯法-作业调度》        
{
《回溯法-作业调度》            
《回溯法-作业调度》            
int tmp = comp();
《回溯法-作业调度》            
if(tmp<best)
《回溯法-作业调度》            
{
《回溯法-作业调度》                best
=tmp;
《回溯法-作业调度》                
for(int i=0;i<N;i++)
《回溯法-作业调度》                
{
《回溯法-作业调度》                    bestx[i]
=x[i];
《回溯法-作业调度》                }

《回溯法-作业调度》            }

《回溯法-作业调度》            
return;
《回溯法-作业调度》        }

《回溯法-作业调度》    
《回溯法-作业调度》        
for(int i=0;i<M;i++)
《回溯法-作业调度》        
{
《回溯法-作业调度》            len[i]
+=t[dep];
《回溯法-作业调度》            x[dep]
=i+1;
《回溯法-作业调度》            
if(len[i]<best)
《回溯法-作业调度》            
{        
《回溯法-作业调度》                backtrack(dep
+1);    
《回溯法-作业调度》            }

《回溯法-作业调度》            
《回溯法-作业调度》            len[i]
-=t[dep];    
《回溯法-作业调度》        }

《回溯法-作业调度》    }

《回溯法-作业调度》    
《回溯法-作业调度》    
//计算完成任务的时间
《回溯法-作业调度》
    int comp()
《回溯法-作业调度》    
{
《回溯法-作业调度》        
int tmp =0;
《回溯法-作业调度》        
for (int i=0;i<M;i++)
《回溯法-作业调度》        
{
《回溯法-作业调度》            
if(len[i]>tmp)
《回溯法-作业调度》            
{
《回溯法-作业调度》                tmp
=len[i];
《回溯法-作业调度》            }

《回溯法-作业调度》        }

《回溯法-作业调度》        
return tmp;
《回溯法-作业调度》        
《回溯法-作业调度》    }

《回溯法-作业调度》
《回溯法-作业调度》}


《回溯法-作业调度》

    原文作者:回溯法
    原文地址: https://blog.csdn.net/bojue__123/article/details/41051169
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞