ISSN ONLINE(2278-8875) PRINT (2320-3765)
K.N.Vitekar1, S.A.Dhanawe2, D.B.Hanchate3
|
Related article at Pubmed, Scholar Google |
Visit for more related articles at International Journal of Advanced Research in Electrical, Electronics and Instrumentation Engineering
SPSP is a problem of scheduling the task and employee. SPSP is a NP-hard (Non Polynomial) problem. SPSP is a problem which is related to RCPSP problem. For solving such problem number of model has been developed. Number of Meta heuristic algorithm is also applied to solve such problem (e.g. GA). This paper presents the survey of methods and models that are put into the historical context. SPSP split the task and distribute dedication of employee to task nodes. Author proposes an ACO Meta heuristics approach to solve the SPSP problem. Author use ACO for solving such problem hence he called it as an ACS: SPSP. Result of this paper is compared with GA to solve SPSP. The proposed algorithm is very efficient and promising and obtains more accuracy.
Keywords |
Software Project Scheduling Problem(SPSP), Resource Constraint Project Scheduling Problem (RCPSP), Genetic Algorithm(GA), Ant Colony Optimization (ACO), Meta heuristic methods |
INTRODUCTION |
Developing effective and efficient tools for project management is a challenging and critical task. Project management is an application of knowledge, skills, tools and technique to solve project scheduling problem. Project scheduling is very critical task in project development. SPSP is a NP-hard problem [4]. This problem consist of number of resources, the important resource is human i.e. Software engineer. To allocate this engineer to a particular task with minimum salary and minimum duration and complete a project is basic requirement in project scheduling. SPSP is related to RCPSP which find an optimal schedule that meets the precedence requirement and minimize the project duration and cost [1]. The SPSP is different than RCPSP is that in SPSP employee is considered with multiple skill and in RCPSP number of resources are considered. Classical Meta heuristic approach is applied to solve SPSP problem such as Genetic Algorithm. |
The GA were quite flexible and efficient for software project scheduling [1]. So many works has been done to solve the SPSP using genetic algorithm. In [4] the author describe the time line based model for SPSP with 3-d GA’s. The success ratio of GA for SPSP is not satisfactory. To take the advantage of ACO Meta heuristic to propose an effective and efficient algorithm to solve the SPSP. |
ACO are used to solve many NP-hard combinatorial problem effectively such as ACS: TSP (Travelling Salesman Problem) [8]. ACO for job shop Scheduling [9], Train Scheduling using ACO technique[7]. The 1st application of ACO was RCPSP [2]. The author use two technique to solve the SPSP problem. 1st is solve SPSP using ACO and 2nd is domain knowledge has been found to be helpful for improving the performance of the scheduling algorithm. |
This paper is organized as follows: Software project scheduling problem is covered in section 2. Section 3 presents Ant Colony Optimization, Section 4 describe ACO for SPSP, ACS:SPSP is compared with GA in section 5. We conclude the paper in the section 6. |
THE SOFTWARE PROJECT SCHEDULING PROBLEM(SPSP) |
Problem Description |
SPSP is a problem of finding an optimal schedule for software project so that all the constraint such as precedence constraint and satisfied and this schedule minimize the salary and duration. SPSP model takes input as a task and the details of task such as task id, task effort, required skill to complete that task, maxhead count of that task. SPSP also take employee as an input and details of employee such as employee id, employee salaryand maximum dedication of employee to each task, skill list of each employee. SPSP take TPG(Task Precedence graph) as input where TPG= {V, A} where V=set of task and A=edge between task i and task j.Basic Symbols and notations that are used in ACS: SPSP paper is, |
The effort and staff is calculate by using any COCOMO model[8]. For scheduling task and employee following constraint must be satisfied. |
1) Every task must involve at least one employee. |
Where, |
Mij- is the degree of dedication of employee ei to the task tj. |
2) Employee involved into task should be able to supply all skill required by this task. |
3) Feasible solution should not make employee to work overtime. |
4) Each task satisfies the precedence constraint. |
In SPSP to evaluate the quality of software project schedule, cost of the project and duration of the project is calculated. |
For calculating duration, start and finish time of each task is calculate using this equation. |
Start time and finish time of each task is calculate: |
Calculate the total duration of software project: |
Total duration of project is calculated using Gantt chart of the project. |
This equation is used to calculate the duration of task. |
This will calculate the total duration of a software project. |
Calculate the total cost of the project: |
1st calculate the cost of each task using following formula. |
Once the cost of all task is calculate then sum of all cost of task is the cost of project. |
The overwork of employee is calculated using ramp function. |
ANT COLONY OPTIMIZATION (ACO) |
ACO was designed by Italian author Dorigo and this Meta heuristic approach is used to solve many NP-hard Problems. ACO [10] is an algorithm based on the behavior of the real ants in finding a shortest path from a source to the food. This algorithm utilizes the behavior of the real ants while searching for the food. It has been observed that the ants deposit a certain amount of pheromone in its path while traveling from its nest to the food. Again while returning, the ants subjected to follow the same path marked by the pheromone deposit and again deposit the pheromone in its path. In this way the ants following the shorter path are expected to return earlier and hence increase the amount of pheromone deposit in its path at a faster rate than the ants following a longer path. ACO takes the inspiration from the foraging behavior of the ants. These ants deposit pheromone on the ground in order to mark some favorable path that should be followed by other members of the colony. However, the pheromone is subjected to evaporation by a certain amount at a constant rate after a certain interval and therefore the paths visited by the ants frequently, are only kept as marked by the pheromone deposit, whereas the paths rarely visited by the ants are lost because of the lack of pheromone deposit on that path and as a result the new ants are intended to follow the frequently used paths only. Thus, all the ants starting their journey can learn from the information left by the previously visitor ants and are guided to follow the shorter path directed by the pheromone deposit. In ACO, a number of artificial ants build solutions to the considered optimization problem at hand and exchange information on the quality of these solutions via a communication scheme that is pheromone deposit on the path of the journey performed by it. At the present time, many algorithms have been suggested based on the improvement of ACS algorithm and used for solving various problems such as TSP, Train scheduling, nurse scheduling, job shop scheduling etc. |
ACO FOR SPSP |
The problem of SPSP is solved using ACO includes the important algorithm is ACS:SPSP algorithm and construction graph for selecting the dedication of each employee to the task and heuristic information is calculated by using one of the six strategies and designing the pheromone to solve the communication problem. |
Construction Graph |
ACO is widely used to solve the combinatorial problem. The 1st step of applying ACO to SPSP is to construct graph that will assign the dedication of each employee to the task. Each employee gives some dedication to the task, so this can be assigned to the task by using construction graph. Construction graph is designed by splitting the task into number of nodes and this nodes depends upon the number of employee and the value if minimum dedication. First we calculate the density of nodes i.e. |
Where, minded is minimum dedication of employee to task j. |
The value of dedication is start from 0 and it is increased in multiple of minded. The value of density is 5 when the value of minded is 0.25. the split operation of a task in TPG is described as follows: |
1) Select starting node and put into column 0 |
2) According to the number of employee , create E number of column and give names as column1 to ColumnE , each column include Density number of nodes. |
3) Identify end node and add to the ColumnE+1 |
4) Construct all possible edges from columnito columni+1 . |
After splitting the task ant select one by one edge and reaches to the next task. This path is straight forward. There is no any returning backward path. Ant select edge according to the dedication of employee to the task. Ant select only one edge from each column and go to next column. At the end when ant reaches to the end of node i.e. end task that time the total task is assigned to employee and one tour is complete. After that according to the dedication of employee the quality of solution is evaluated. |
Implementation of ACS-SPSP |
We have constructed the graph that will help to assign the dedication of employee to the task. Once the tour is completed the quality of solution is checked by using fitness function ACS is employed to obtain the best solution which has the maximum fitness values. The fitness function is defined as the inverse weighted sum of project cost and project duration. We consider the importance of project cost and duration is equal in the fitness function and the weights are used to adjust the project cost and duration to the same order of magnitude. The fitness function is presented as following: |
The details of ACS-SPSP are as follows: |
1) Initialize all parameter that are used in ACO. Such as α,β,Ãâ°Ãâ¹0 ,ρ , Ngen, Nant . α and β are used to evaluate the importance of history information and heuristic information. Ρ which adjust the pheromone updating, Ãâ°Ãâ¹0 balance the exploration and exploitation behaviour, Ngenis the number of generation of ACO, Nant is the number of ant. |
2) Initialize pheromone values. All values are 0. |
3) Ant select path to get solution. Each ant select next node in construction graph using selection scheme. Each ant maintains its own solution matrix and store the result dedication values into that matrix. |
4) Evaluate the quality of a matrix using fitness function. Calculate the cost and duration of project as well as over time load of the employee. |
5) Select the best solution and update the pheromone values using pheromone update formula. |
6) Step 3-5 repeat till the termination condition is not satisfied. Termination condition is either the number of generation or the quality of solution. |
7) Select the best solution whose cost and duration is less according to the fitness function. |
Pheromone management- |
Ant select path in construction graph using selection scheme and when tour is finished that means all task are successfully assigned to the employee, by using fitness function we check the quality of solution and if solution is best then the pheromone values are updated. Pheromone value are updated in two times. The update of pheromone τij on the edge ended with Nij is implemented by the following equation: |
AD strategy means that the heuristic information is related to the dedication of employee ei has already been contribute to other task. |
COMPARISON |
The SPSP is a NP-hard problem, so the time complexity of such problem is very high. Such problem is solved by using many techniques. Manual calculation of such problem is not a solution. This problem is solved by using Meta heuristic approach. In Meta heuristic approach SPSP is solved by using GA and ACO. By comparing the result of ACO to the GA, ACO is better than the GA. The average hit rate and project duration of ACO solution is always better than GA. But ACS-SPSP or GA cannot be obtain the feasible solution for the instances with 30 tasks. |
CONCLUSION |
SPSP is NP-hard problem. For scheduling task and employee is not a simple task. Its time complexity is very high. Due to its complexity there are very few algorithm is implemented to solve such problem. There are also few algorithm of Meta heuristic approach is presented such as Genetic Algorithm. GA is also very good method to solve NP-hard problem. GA is also applied to solve SPSP problem but its success rate is not satisfactory. Compared with GA approach the proposed approach such as ACS: SPSP is effective and promising in the following aspects. |
1) Graph based searching method is used i.e. splitting the task by distributing the dedication of employee to a task and construction graph is generated. |
2) Six heuristic mechanism are used to use the domain knowledge including total dedication in task and allocated dedication of employees. |
This aspects are considered and in six heuristic mechanism allocated dedication of employees to other task heuristic achieves the best result. So the ACS:SPSP is outperform the GA approach for the SPSP. |
References |
|