Next Article in Journal
Optimal Design of PV Systems in Electrical Distribution Networks by Minimizing the Annual Equivalent Operative Costs through the Discrete-Continuous Vortex Search Algorithm
Next Article in Special Issue
Network Traffic Prediction Incorporating Prior Knowledge for an Intelligent Network
Previous Article in Journal
Lidar-Based Navigation of Subterranean Environments Using Bio-Inspired Wide-Field Integration of Nearness
Previous Article in Special Issue
Abnormal Detection of Cash-Out Groups in IoT Based Payment
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Greedy Firefly Algorithm for Optimizing Job Scheduling in IoT Grid Computing

1
Department of Computer Science, College of Science and Arts-Sharourah, Najran University, Sharourah 68341, Saudi Arabia
2
Department of Information Systems, College of Computer Science and Information Systems, Najran University, Najran 61441, Saudi Arabia
3
Department of Math, Turubah University College, Taif University, Taif 26571, Saudi Arabia
4
Department of Computer Science, Faculty of Computer Science and Information Technology, Shendi University, Shendi 41601, Sudan
5
National Institute of Information and Communications Technology, Tokyo 184-8795, Japan
6
Department of Computer Science, School of Computer Science and Informatics, University College Dublin, Belfield, D04 V1W8 Dublin, Ireland
7
Lero-the Irish Software Research Centre, Tierney Building, University of Limerick, Sreelane, V94 NYD3 Limerick, Ireland
8
Department of Computer Science, Faculty of Computer Science and Information Technology, University of Science and Technology, Khartoum 14411, Sudan
*
Author to whom correspondence should be addressed.
Submission received: 10 November 2021 / Revised: 15 January 2022 / Accepted: 17 January 2022 / Published: 23 January 2022

Abstract

:
The Internet of Things (IoT) is defined as interconnected digital and mechanical devices with intelligent and interactive data transmission features over a defined network. The ability of the IoT to collect, analyze and mine data into information and knowledge motivates the integration of IoT with grid and cloud computing. New job scheduling techniques are crucial for the effective integration and management of IoT with grid computing as they provide optimal computational solutions. The computational grid is a modern technology that enables distributed computing to take advantage of a organization’s resources in order to handle complex computational problems. However, the scheduling process is considered an NP-hard problem due to the heterogeneity of resources and management systems in the IoT grid. This paper proposed a Greedy Firefly Algorithm (GFA) for jobs scheduling in the grid environment. In the proposed greedy firefly algorithm, a greedy method is utilized as a local search mechanism to enhance the rate of convergence and efficiency of schedules produced by the standard firefly algorithm. Several experiments were conducted using the GridSim toolkit to evaluate the proposed greedy firefly algorithm’s performance. The study measured several sizes of real grid computing workload traces, starting with lightweight traces with only 500 jobs, then typical with 3000 to 7000 jobs, and finally heavy load containing 8000 to 10,000 jobs. The experiment results revealed that the greedy firefly algorithm could insignificantly reduce the makespan makespan and execution times of the IoT grid scheduling process as compared to other evaluated scheduling methods. Furthermore, the proposed greedy firefly algorithm converges on large search spacefaster , making it suitable for large-scale IoT grid environments.

1. Introduction

The computational grid is a distributed technology consisting of multiple distributed heterogeneous resources in different network sites [1,2,3]. The Internet of Things (IoT) is defined as interconnected digital and mechanical devices with intelligent and interactive data transmission features over a defined network [4,5]. Grid computing is a large-scale computational environment consisting of a huge number of heterogeneous resources combined to perform complex processes [6]. From a communication viewpoint, the IoT is identified as a system of interconnected things, each with a unique address to deliver computational services and connect using specified protocols. The IoT comprises things such as sensors, computing devices, embedded systems, objects, and animals with unique identifiers and that have the capacity to transmit data over a specified network [4,5,7,8,9]. The IoT grid was introduced to integrate the grid services with IoT architecture [10,11]. The IoT grid benefits from deploying grid service architecture for IoT technology [10,12]. The grid sites are clusters, super computers, or multiprocessor computing networks [1]. Moreover, global resources and tasks send application jobs through the global grid job scheduler. Given several clients’ jobs and several heterogeneous resources, the grid job scheduling problem is finding a schedule that maps the client’s jobs to site resources to optimize specified scheduling criteria [13,14]. The complexity of the computational grid increased due to the high heterogeneity of grid resources, the complexity of computational problems, and the dynamic nature of resources [15]. These complexities of computational grid environments offer an opportunity and challenge for developing grid job scheduling mechanisms based on metaheuristics and nature-inspired methods to optimize the grid job scheduling process. The job scheduling process aims to find the optimal mapping of clients’ jobs to grid resources that minimize the execution and makespan times [16]. The exponential increase in the size of the solution search space inspired more research to utilize optimization methods to tackle grid job scheduling gaps [17].
Nature-inspired metaheuristics have established a high degree of success in solving optimization problems with large scale search space [18,19]. Several genetic algorithm (GA) methods have been introduced for grid job scheduling problems [20,21,22]. To improve the genetic algorithm further, a hybrid job clustering combining fuzzy C-Mean and a genetic algorithm was developed in [23]. A task scheduler with fault tolerance based on ACO is proposed to guarantee that tasks are performed efficiently, even if resource failure has arisen [24].
The firefly algorithm is a nature-inspired metaheuristic based on the flashing behavior of fireflies [25]. A study in [26] presented job scheduling mechanisms for grid computing based on the standard firefly algorithm. Each firefly algorithm denotes one schedule in the solution search space in the standard firefly algorithm. The job scheduling standard mechanism based on FA starts with an initial random population of schedules or fireflies [26]. In  each stage, greedy algorithms rely on current options to make their decisions and do not consider future possibilities [27,28].
This paper proposed a greedy firefly algorithm (GFA) for IoT grid job scheduling. The greedy firefly algorithm enhances the standard firefly algorithm by combining the firefly method with the greedy mechanism. In the proposed greedy firefly algorithm, the greedy method is utilized as a local search mechanism to enhance the speed of convergence and efficiency of the solution generated by the standard firefly algorithm. The proposed GFA aims to obtain better coverage as the search space increases. This is because the greedy algorithm increases the search exploitation process. The search exploitation implemented by the greedy algorithm increases the probability of finding the optimum solution. Furthermore, the study considers the balance between exploitation achieved by the greedy algorithm and the exploration implemented by the firefly algorithm.
The remainder of this paper is organized as follows. Section 2 reviews the related works. Section 3 discusses the basic idea of the proposed greedy firefly algorithm. Section 4 describes experiments and results. Finally, we conclude in Section 5.

2. Related Works

The IoT grid was introduced to integrate the grid services with IoT architecture [10]. The IoT grid benefits from deploying grid service architecture to IoT technology [10,12]. Several researchers have presented hybrid high-performance computing systems with IoT technologies [29,30,31]. The research by Deniziak and Bąk in [32] suggests a new scheduling mechanism for IoT distributed jobs in heterogeneous cloud computing. The researchers considered that jobs that demand execution are identified as directed acyclic graphs. According to [33], grid computing is a group of clusters connected over high-speed networks that involve coordinating and sharing computational power, data storage, and network resources operating across dynamic and geographically dispersed locations. In the desktop grid model, the job is submitted for execution only when the system is idle, and there is no guarantee that the job will entirely execute without disruption. In 2017, Shiny and Jetlin described a secure resource allocation method capable of allocating the resources to authenticated grid users by improving the system’s functionality by submitting the jobs on a machine with a higher probability of being available at a given time [33]. Furthermore, they proposed a system where the number of jobs was fewer than the available resources, with checkpointing and replication tools were being used to mitigate the volatility of the resource, hence reducing job processing time. In the same year, an improved ant colony optimization algorithm with fault tolerance for job scheduling in the grid computing system was proposed to ensure that jobs were executed successfully even when resource failure occurred. In addition, the design applied a resource failure and checkpoint-based rollback recovery strategy to reduce the amount of work lost upon system failure by immediately saving the system’s state [24].
An Application-aware Deadline Constraint Job Scheduling Mechanism On A Large-Scale Computational Grid was proposed to overcome earlier models’ challenges due to the heterogeneity, dynamics of resources, and diversity of application requirements [34]. Since the scheduling task had remained a challenging task, a Hybrid Heuristic of Variable Neighborhood Descent and Great Deluge Algorithm for efficient task scheduling in grid computing was proposed. It synergized the Great Deluge algorithm and variable Neighborhood Decent algorithm to schedule independent tasks, effectively minimizing the makespan [35]. Furthermore, a fuzzy priority deadline-based task scheduling algorithm (FPDSA) having a fuzzy deadline limitation to competent job execution was proposed in 2020 to enhance the existing grid’s performance regarding Average Actual execution and the number of non-delayed Jobs [15]. A recent survey showed that most of the algorithms developed a long time ago are in constant development, making them still used today due to their efficiency. These algorithms include the Ant Colony algorithm, Compact Genetic algorithm, Load Balanced Min-Min algorithm, and Divisible Load Scheduling algorithm. They are still widely used for scientific and medical purposes [36]. To guarantee that jobs complete their execution within the estimated completion time, a dynamic job scheduling model (DTSCA) that uses job characteristics to map them to resources with minimum execution time was proposed. The system would make virtual machine choices closer to their expectations [37]. The recent development has been tailored to provide a very low-cost distributed computing platform to group members using their personal computers. The proposed Static Job Scheduling Algorithm Considering CPU Core Utilization for User-PC Computing System has the master PC receiving user tasks and assigning them to available worker PCs [38]. High-Performance Computing (HPC) systems offer massive computation strength to execute large-scale applications, hence consuming a lot of energy and increasing carbon emissions. To overcome these drawbacks and improve searching efficiency, a performance-aware, energy-efficient parallel job schedule in HPC grids using nature-inspired hybrid meta-heuristics was proposed [1].
Nature-inspired optimization methods have been applied to handle the job scheduling problem on the computational grid [39]. Natural metaheuristics are derived and inspired by natural behaviors to address complex real-world issues [40]. The essential methods representing the field are evolutionary optimization techniques and swarm intelligence mechanisms [28,41]. Metaheuristic evolutionary techniques such as Genetic Algorithms (GA) and Differential Evolution (DE) methods have proven their usefulness in solving the problem of spanned design space [41,42]. In recent years, swarm intelligence (SI) mechanisms such as PSO and FA have been considered successful search methods that perform better than evolutionary techniques when applied to various problems [39].
GA starts with a random population of candidate solutions. The initial random population is a set of integer numbers, and each solution in the population denotes a chromosome. To enhance GA further, a hybrid job clustering using a fuzzy C-Mean and a genetic algorithm was developed in [23]. This hybrid genetic algorithm was presented to reduce the GA’s generations’ repetitions. Delavar at el. [43] presented a job scheduling method to attain a shorter execution times and lower communication costs. A rank-based genetic for the computational grid is introduced to increase the genetic algorithm convergence and reduce the search time [44]. A new research work presented two hybrid meta-heuristic job scheduling methods for the computational grid.
A task schedule with fault tolerance based on ACO is proposed to guarantee that tasks are performed efficiently even if resource failure has arisen. The ACO fault tolerance task scheduling mechanism is based on the resource failure rate and the checkpoint-rollback approach. The check-pointing parts of the mechanism aim to decrease the total effort lost during grid failure by instantly saving the status of the grid computing system [24]. A grid architecture for scalable monitoring and enhanced, dependable job scheduling is presented in [45]. The proposed scalable monitor architecture focuses on two critical distributed heterogeneous and multi-domain grid computing features: the scalable distribution of control and administration data and system recovery of when job failures occur [45]. On the other hand, HC is used in grid task scheduling [46,47]. HC optimization has a plateau problem in flat search space. In the plateau problem, HC can not find the next best position. HC will occasionally choose directions that do not have the best schedules [48]. Tabu Search (TS) has an advantage over HC as it has a memory that supports continuous exploration, even if the mechanism does not generate better solutions. In addition, the memory avoids TS searching from local optima trapping.
The basic job scheduling approaches, such as shortest job first, select the best schedule by considering a single criterion. For instance, the goal of MET is to map tasks with their most suitable resources. Still, this can produce a serious load imbalance within resources. Similarly, the FCFS mechanism may produce weak scheduling in a task with high resource requests being submitted to the global scheduler, causing long execution times for several grid resources [15].
The greedy approach Tabu Search (TS) utilizes a one-search path of job scheduling. This constraint generates scheduling solutions appropriate for lightweight scheduling problems. Yet, it is challenging for the single path approaches to obtain the optimal schedules in case of heavy system loads. Furthermore, single path scheduling mechanisms suffer from plateau problems and solution search space diversity issues. As a result of these weaknesses, TS generates long execution times in heavy load system states.
Genetic algorithms and other evolutionary algorithms are sometimes trapped in local optimals. As a result, they are unable to progress any further extent [49]. This happens as the diversity of schedules in the population is decreased, which makes the crossover and mutation processes not capable of producing enhanced chromosomes [50]. Likewise, evolutionary algorithms sometimes suffer in obtaining optimal schedules due to the difficulty in handling the population changes [51]. The limitations of evolutionary algorithms influence the job scheduling process on the computational grid as GA, and DE generate long makespan and flowtime in some scenarios [50,52,53,54,55].
Swarm intelligence job scheduling approaches such as PSO and ACO suffer from several problems. For instance, PSO reduces the convergence speed while close to the optimal schedule. In addition, PSO scheduling solutions need to handle partial optimism issues. Even if scheduling search space convergence is secured in ACO, the time to convergence is still uncertain [56].
The study [57] presented a method using ant-based systems to reproduce and represent grid service information on the computational grid, allowing a specific semantic classification of such facilities. System information is distributed using agents, which navigate the computational grid using P2P interconnections between grid sites.

3. The Proposed GFA for IoT Grid Job Scheduling

This paper proposed an enhanced greedy firefly algorithm for job scheduling on the IoT grid. The proposed greedy algorithm is based on a discrete firefly algorithm. The study applied the smallest position value (SMV) mechanism [58]. The idea behind the proposed greedy firefly algorithm is to combine the benefits of the firefly algorithm and greedy algorithms by using the greedy choice to help enhance the firefly algorithm schedule. Furthermore, the greedy choice allows the firefly solution to search for schedules’ near-optimal solutions. The IoT grid environment is presented in Figure 1. The IoT grid environments consist of four layers: a sensing layer, a grid network layer, an open grid service architecture layer, and the client interface layer. The sensing layer contains the sensors’ RFID readers and other IoT devices. The grid network layer represents the grid computing network core. The third layer is an open grid service architecture in which service integration is provided between grid resources and IoT devices. The last layer is the IoT grid user interface. The process starts when grid clients build an IoT application that needs computational grid power. Next, the client application is submitted to grid resources, and clients can require additional resource specifications. When the execution process starts, the information requested by the sensors is collected using the embedded system’s devices. The next step includes submitting the execution request to the grid IoT scheduler. The grid IoT scheduler schedules all the submitted jobs based on the proposed scheduling mechanism. Finally, the execution results are sent back to the IoT system.
Figure 2 depicts the elements and components of IoT grid scheduling architecture. The IoT grid applications send their tasks to the global grid scheduler. The proposed greedy firefly algorithm-based global scheduler distributes IoT application tasks to the appropriate resources in the available sites. Each grid site has its local tasks and receives tasks from other sites using the global scheduler. The IoT grid applications started submitting jobs to the global scheduler. Then, the global scheduler submits jobs to suitable IoT grid resources using the specific scheduling method using the network connections. Each grid site consists of several resources, a local scheduler, and a global access component. The local scheduler is responsible for the local scheduling policy. The global access components allow the global scheduler to access the local resource information. Finally, the proposed GFA is performed within the global scheduler component.

3.1. Mathematical Modeling

In this study, the following assumptions are considered:
  • All clients’ jobs are independent.
  • The submitted jobs have different executions times.
  • The model assumes that the IoT grid resources deliver only one type of service.
  • Pre-emption is not allowed, i.e., each job cannot be interrupted before its completion on the assigned resource.
  • At any given time, a resource can run only one job.
To formulate the IoT grid job problem, this study consider n clients jobs J n = [ j 1 , j 2 , j 3 , , j n ] and m grid resources R m = [ r 1 , r 2 , r 3 , , r m ] with an objective of minimizing job execution and makespan times. The speed of resources is measured in million instructions per second (MIPS). The job length is defined as the number of instructions in millions (MI). Figure 3 describes the IoT grid job scheduler model. Jobs allocated to each resource are handled on a first-come, first-serve basis. If a resource is busy, jobs are queued in the resource queue.
This study considers the execution and makespan times to be minimized. First, the study defined C j as the time that the last job, j k completed execution. Consider C m a x = m a x { C j , j = 1 , , n } as representing makespan time and j = n j = 1 c j represents the execution time. The proposed scheduling method improves the standard firefly algorithm presented in [25]. In the proposed method, the study combines the standard firefly algorithm with the greedy algorithm to enhance the scheduling and minimize the makespan time. In the greedy firefly algorithm, the greedy method is employed as a local search mechanism to improve the rate of convergence and quality of the solution generated by the standard firefly algorithm, as shown in Figure 4.
The proposed GFA starts when grid clients submit jobs to the global scheduler. After that, the global scheduler gathers information of resources in each grid site. After obtaining jobs’ and resources’ information, the proposed GFA generates a random population of solutions from the solution search space. In each population, the solution represents a firefly. The makespan time and execution times are considered as firefly attractiveness. Starting with the random initial solutions, the firefly algorithm is executed. If the new population achieves the required fitness value, the algorithm finishes. However, suppose the new population does not produce the required fitness. A greedy algorithm is then implemented to exploit the solution search space by searching for better solutions near the current solution. This is achieved by searching and moving to solutions near the existing solutions. The algorithm then returns to the firefly algorithm execution. This process is repeated until the required fitness value is achieved.
The continuous firefly algorithm needs to be modified to solve discrete problems such as job scheduling problems. Discrete optimization problems apply modified nature-inspired metaheuristics optimization methods [59]. The study used the smallest position value rule (SPV) [58]. Several studies utilized the SPV rule to adjust the continuous optimization with a discrete computational problem [58,60,61,62].

3.2. Greedy Algorithm

The greedy method is integrated with the standard firefly algorithm as a local search mechanism to enhance the speed of convergence and efficiency of the solution generated by the standard firefly algorithm. The idea of greedy scheduling is that there is a group of jobs to be scheduled on some resources, and each job j has a given length l j . The greedy scheduling method aims to schedule as many jobs as possible on the cloud provider’s resources. Starting from the empty schedule, provided at least one cloud job exists, the jobs that lead to minimum makespan time are continuously added. A The greedy algorithm can choose any option that may seem to be the best in a particular step, and then it resolves partial problems that will appear later. In each phase, the greedy algorithm selects a solution, and this selection process is based only on the current phase and not the future phases. The greedy algorithm repeats the generations of a greedy solutions to transform a given problem into a smaller one. Sometimes, greedy algorithms fail to obtain the best solution. Furthermore, the greedy algorithm can generate the worst solution from the search space. The details of the proposed Greedy Algorithm for the IoT grid job scheduling steps are stated in Algorithm 1.
Algorithm 1 Greedy Algorithm for Job Scheduling.
Require: 
G r e e d y S c h e d u l e ( s , f )
1:
J s u b m i t t e d J o b s
2:
R a v a i l a b l e _ R e s o u r c e s
3:
S e m p t y
4:
0 f m a k s p a n
5:
Sort jobs J by increasing order of length
6:
while ( i t e r a t i o n _ b e s t i t e r a t i o n < n m a x ) do
7:
     i t e r a t i o n = i t e r a t i o n + 1
8:
    for ( j o b = 1 ) to n do
9:
        for ( r e s o u r c e = 1 ) to m do
10:
           assign j o b i = r e s o u r c e j
11:
            C i , j f i n i s h _ t i m e
12:
           if  C i , j p r e v _ f i n i s h  then
13:
                C i , j > p r e v _ f i n i s h
14:
                C i , j p r e v _ f i n i s h
15:
                j = 1 n C i , j T i
16:
           end if
17:
        end for
18:
         m a x ( T i ) f m a k s p a n ( c )
19:
         S ( j ) S
20:
    end for
21:
    return S
22:
end while

3.3. Firefly Algorithm

Firefly algorithm is a nature-inspired optimization. Each firefly attracts mating partners and preys on other fireflies using flashing lights [39,63,64]. The details of the proposed firefly algorithms for IoT grid job scheduling steps are stated in Algorithm 2.
Algorithm 2 Firefly Algorithm for Job Scheduling.
Require: 
Form each firefly to represent a schedule
1:
m a x m a x I t e r a t i o n
2:
generate initial random population of fireflies
3:
Sort jobs J by increasing order of length
4:
while ( i t e r a t i o n < m a x ) do
5:
    for each firefly do
6:
        calculate the light intensity as makespan time
7:
        estimate the firefly’s distances
8:
        estimate the firefly’s attractiveness
9:
        if the firefly has the highest brightness value then
10:
           the firefly has the highest brightness value
11:
        else
12:
           if the firefly has the highest brightness value then
13:
               execute the greedy algorithm
14:
               move the firefly to the firefly with highest brightness value
15:
           end if
16:
        end if
17:
    end for
18:
    Return the best firefly
19:
end while
Figure 5 describes an example of a valid firefly algorithm schedule. As shown in Figure 5, job number 1 is scheduled to the resource with ID 4, and job number 2 is scheduled to resource with ID 8, and so on.

3.4. The Proposed GFA in Details

This section explains the proposed job scheduling mechanisms using the greedy firefly algorithm. To illustrate the proposed greedy firefly algorithm clearly, an example instance with nine jobs and four resources are defined in Table 1 and Table 2, respectively.
The greedy firefly algorithm starts with a random initial schedule, as shown in Figure 5. Figure 6 describes the corresponding schedule.
The greedy firefly algorithm generates a fitness value for each schedule in the second step. The fitness value represents the makespan time in the proposed greedy firefly algorithm. The makespan time is calculated using Equation (1).
m a k e s p a n t i m e = m a x T 1 , T 2 , T 3 , , T m
and
T k = n i = 1 L i S k ,
where L i represents the length of job i , and S k represents the speed of resource k.
T k = n i = 1 L i S k = S 1 S 2 S 3 S 4 R 1 36.37 47.00 28.18 26.91 R 2 19.13 28.38 22.88 18.50 R 3 31.00 33.20 30.40 29.20 R 4 13.11 10.57 10.57 17.43
T h e i n i t a i l m a k e s p a n t i m e s ( β 0 ) = S 1 = 47.00 , S 2 = 28.38 , T 3 = 33.20 , T 4 = 17.43
To calculate the brightness of each schedule, first we need to find the distances between each schedules using Equation (2) and (3):
d i s t a n c e i , j = x i x j = k = 1 n ( x i , k x j , k ) 2
d i s t a n c i , j = S 1 S 2 S 3 S 4 S 1 0 2.00 3.46 5.10 S 2 2.00 0 4.47 4.90 S 3 3.46 4.47 0 5.10 S 4 5.10 4.90 5.10 0
The brightness of the schedule is calculated using Equation (4):
β ( r ) = T k e γ d i s t a n c e i , j 2
The movements towards the brightest firefly is calculated using Equation (5):
f i r e f l y i ( t + 1 ) = f i r e f l y i ( t ) + T k e γ d i s t a n c e i , j 2 + α ϵ i
The remaining steps of the proposed greedy firefly algorithm focus on the greedy choice by selected the schedule that handles as many jobs as possible on the cloud provider resources. Starting from the empty schedule, provided that at least one cloud job exists, continuously add in the job that leads to the minimum makespan time. The idea behind the proposed greedy firefly algorithm is to combine the benefits of firefly algorithm and greedy algorithms by using the greedy choice to help in enhancing the firefly algorithm schedule. The greedy choice allows the firefly solution to search for schedules near optimal solutions.

4. Performance Evaluation

Generally, the simple mathematical models of job scheduling metaheuristics fail when dynamic changes occur in the IoT grid configurations or the scheduling configuration. For this reason, the empirical evaluation of the greedy firefly algorithm is considered a good choice to assess the effectiveness of the proposed mechanism in the IoT grid. However, the empirical evaluation of the greedy firefly algorithm requires specifications of a wide range of parameters for the environment [65]. Therefore, simulation experiments have been conducted to assess the efficiency of the greedy firefly algorithm for IoT grid job scheduling. The simulation results focus on representing the performance advantages of the greedy firefly algorithm over the standard firefly algorithm and other states of arts scheduling mechanism.
GridSim simulator, a discrete event simulator, developed to simulate the distributed heterogeneous systems such as cloud systems and computational IoT grid environments, is used as a tool [66]. The workload traces to employed in our evaluation are obtained from the Grid Workload Achieve (GWA). Grid Workload Achieve is built based on a real grid workload trace as a public dataset to conduct real data experiments [67].

4.1. The Experiments

To evaluate the greedy firefly algorithm, the study considered different sizes of workload traces. As a result, the number of jobs range from lightweight loads with less than 1000 jobs to the heavy workload with 10,000 jobs. The parameter values for the proposed greedy firefly algorithm are described in Table 3 [43,64,68]. The experimental parameters in the study are based on the relevant literature [69,70,71,72].
Here, β 0 represents the attractiveness of each firefly at r = 0 , while γ represents the media light absorption coefficient, and α is a random number.
Table 4 and Figure 7 describes the makespan times of the greedy firefly algorithms compared to different IoT grid job scheduling methods for different workloads traces with sizes ranging from 500 jobs to 10,000 jobs.
Each scheduling method’s makespan and execution times were calculated to evaluate the proposed greedy firefly algorithm. The simulation results for the makespan and execution times are as stated in Table 4 and depicted in Figure 7. The results in Table 4 state that the proposed greedy firefly algorithm mostly has shorter makespan and execution times than other evaluated scheduling methods, such as TS, GA, and standard firefly algorithms. This means that the proposed greedy firefly algorithm needs a shorter time to finish the submitted jobs and has better performance than all other IoT grid job scheduling methods in different workload traces. Furthermore, the results show that the standard firefly algorithm is the second best. Therefore, these results prove that makespan times using the proposed greedy firefly algorithm have better performance than other evaluated IoT grid job scheduling algorithms.
The reasons for the improvements in the results demonstrate that the proposed GFA has better coverage as the search space increases. This is because the greedy algorithm increases the search exploitation process. The search exploitation implemented by the greedy algorithm increases the probability of finding the optimum solution. Furthermore, the study considers the balance between exploitation achieved by the greedy algorithm and the exploration implemented by the firefly algorithm.
As reported in Table 5 and revealed in Figure 8 , the GFA has the shortest execution time compared to other evaluated scheduling methods. The obtained results indicate that proposed GFA improves the IoT grid job scheduling process when considering execution time as a performance metric.

4.2. Test Case 1: Typical Workload of 5000 Jobs

To evaluate the efficiency of the GFA under different workloads, the study compared the makespan time and execution times of the proposed method with several scheduling algorithms using different workloads. The experiments evaluated the proposed GFA with a typical workload involving 5000 jobs in the first scenario. The makespan and execution times of varying scheduling methods are described in Table 6 and depicted in Figure 9.
Considering typical workload, the proposed GFA makespan time is 2654, the shortest makespan time compared with other evaluated scheduling algorithms in Table 6. Furthermore, the obtained results revealed that the GFA has the best execution time: 21,005 compared to 101,424, 115,148, and 4295 for TS, GA, and the standard firefly algorithm, respectively.

4.3. Test Case 2: The Heavy Load of 10,000 Jobs

The study evaluated the GFA under a heavy workload environment containing 10,000 jobs. The makespan times and execution times of the TS, GA, and standard firefly algorithm and the GFA are reported in Table 7 and depicted in Figure 10.
Figure 10 and Table 7 compare the makespan time between the TS, GA, and standard firefly algorithm and the proposed GFA. These results show that the makespan time in the GFA is less than the other evaluated algorithms. In heavy workload, the proposed GFA produced a makespan time of 3945, which is shorter than the makespan time of 4742 for the standard firefly algorithm. As shown in Figure 11 and Table 8, the results obtained from this experiment show that the proposed GFA shows a shorter execution time compared to other evaluated scheduling methods. Moreover, GA is ranked far below the standard firefly algorithm in almost all test cases, and TS falls behind GA.

4.4. Test Case 3: Lightweight Load of 1000 Jobs

The study evaluated the GFA in a lightweight workload environment containing 1000 jobs. The makespan times and execution times of GFA and other evaluated scheduling methods are reported in Table 8 and depicted in Figure 11.
The makespan time for TS was 20 and for GA was 46, while the makespan time for the standard firefly algorithm was 28. The proposed GFA makespan time for this experiment was 20. As noted, the TS and GFA require shorter makespan times compared to other scheduling methods. The TS, GA, and standard firefly algorithms’ execution times were 559, 1040, and 557, respectively. Meanwhile, the execution time of the GFA was 518. These results prove that the proposed GFA is an effective method in optimizing the search performance for IoT grid scheduling problems since it minimizes the execution time required to obtain the optimal schedule. We also find that the standard firefly algorithm performs a little better than TS in lightweight workload cases; both fall behind the GFA. To conclude, the obtained results show that the GFA job scheduling mechanism can achieve better performance than the other scheduling mechanism. The GFA achieves better results in minimizing the makespan execution times of the IoT grid job scheduling process. Better GFA makespan and execution times may entice consumers to request GFA inorder to save money and complete their job on a reasonable time.

5. Conclusions

The performance of IoT grid environments depends mainly on the job scheduling method applied to manage resources. This paper presented an IoT grid job scheduling method based on a GFA. The proposed GFA depends on enhancing the efficiency of the standard firefly algorithm using the greedy approach. Furthermore, the proposed GFA aims to minimize the makespan and execution simultaneously. The study conducted various experiments to study the efficiency of the proposed GFA compared to those reported in recent work that used TS, GA, and standard firefly algorithms by conducting extensive simulation experiments using different workloads. The obtained simulation results revealed that the GFA has the shortest execution time, 21,005, compared to 101,424, 115,148, and 42,958 for the TS, GA, and standard firefly algorithm, respectively. Using the GFA for task scheduling, where the solution search space is huge, the GFA search takes a shorter time to find an optimal solution. This is because the greedy algorithm increases the search exploitation process. The search exploitation implemented by the greedy algorithm increases the probability of finding the optimum solution. Furthermore, the study considered the balance between exploitation achieved by the greedy algorithm and the exploration implemented by the firefly algorithm. Future research work for the GFA will include optimizing the process by integrating a clustering mechanism for clients’ tasks. Furthermore, the evaluation of the GFA will be extended based on other key parameters and considering a comparison with an additional scheduling strategy.

Author Contributions

Conceptualization, A.Y.; Investigation, A.Y., M.B.B. and A.H.; Methodology, A.Y.; Software, A.A.; Validation, A.H.; Writing—review & editing, S.M.A., R.H. and T.M.T. All authors have read and agreed to the published version of the manuscript.

Funding

This work was funded by the deputyship for research and innovation, Ministry of Education in Saudi Arabia through the project number(NU/IFC/ENT/01/013) under the institutional funding committee at Najran University, Kingdom of Saudi Arabia.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not applicable.

Acknowledgments

The authors extend their appreciation to the deputyship for research and innovation, Ministry of Education in Saudi Arabia for funding this research work through the project number(NU/IFC/ENT/01/013) under the institutional funding committee at Najran University, Kingdom of Saudi Arabia.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Chhabra, A.; Singh, G.; Kahlon, K.S. Performance-aware energy-efficient parallel job scheduling in HPC grid using nature-inspired hybrid meta-heuristics. J. Ambient. Intell. Humaniz. Comput. 2021, 12, 1801–1835. [Google Scholar] [CrossRef]
  2. Foster, I.; Kesselman, C.; Tuecke, S. The anatomy of the grid: Enabling scalable virtual organizations. Int. J. High Perform. Comput. Appl. 2001, 15, 200–222. [Google Scholar] [CrossRef]
  3. Hernández, H.G. Vector and Parallel Processing-VECPAR 2000: 4th International Conference, Porto, Portugal, 21–23 June 2000, Selected Papers and Invited Talks; Springer Science & Business Media: Berlin/Heidelberg, Germany, 2001; Volume 1981. [Google Scholar]
  4. Singh, R.P.; Javaid, M.; Haleem, A.; Suman, R. Internet of things (IoT) applications to fight against COVID-19 pandemic. Diabetes Metab. Syndr. Clin. Res. Rev. 2020, 14, 521–524. [Google Scholar] [CrossRef] [PubMed]
  5. Xia, F.; Yang, L.T.; Wang, L.; Vinel, A. Internet of things. Int. J. Commun. Syst. 2012, 25, 1101. [Google Scholar] [CrossRef]
  6. Arafah, M.A.; Al-Harbi, H.S.; Bakry, S.H. Grid computing: A STOPE view. Int. J. Netw. Manag. 2007, 17, 295–305. [Google Scholar] [CrossRef]
  7. Holler, J.; Tsiatsis, V.; Mulligan, C.; Karnouskos, S.; Avesand, S.; Boyle, D. Internet of Things; Academic Press: Cambridge, MA, USA, 2014. [Google Scholar]
  8. Li, S.; Da Xu, L.; Zhao, S. The Internet of Things: A Survey. Information Systems Frontiers; Springer: Berlin/Heidelberg, Germany, 2015. [Google Scholar]
  9. Nord, J.H.; Koohang, A.; Paliszkiewicz, J. The Internet of Things: Review and theoretical framework. Expert Syst. Appl. 2019, 133, 97–108. [Google Scholar] [CrossRef]
  10. Zou, Y.; Quan, L. A new service-oriented grid-based method for AIoT application and implementation. Mod. Phys. Lett. B 2017, 31, 1740064. [Google Scholar] [CrossRef]
  11. Veenstra, K.; Obraczka, K. Grid Partition: An Efficient Greedy Approach for Outdoor Camera IoT Deployments in 2.5 D Terrain. In Proceedings of the 2020 29th International Conference on Computer Communications and Networks (ICCCN), Honolulu, HI, USA, 3–6 August 2020; pp. 1–9. [Google Scholar]
  12. Alzaabi, A.; Aldoobi, A.; Alnuaimi, D.; Alserkal, L.; Alsuwaidi, M.; Ababneh, N. Grid-Based Source Location Privacy Protection Schemes in IoT Wireless Sensor Networks. In Proceedings of the 2021 4th International Conference on Data Storage and Data Engineering, Barcelona, Spain, 18–20 February 2021; pp. 31–36. [Google Scholar]
  13. Mohanty, S.; Moharana, S.C.; Das, H.; Satpathy, S.C. QoS aware group-based workload scheduling in cloud environment. In Data Engineering and Communication Technology; Springer: Berlin/Heidelberg, Germany, 2020; pp. 953–960. [Google Scholar]
  14. Goswami, S.; Mukherjee, K. High Performance Fault Tolerant Resource Scheduling in Computational Grid Environment. Int. J. Web-Based Learn. Teach. Technol. (IJWLTT) 2020, 15, 73–87. [Google Scholar] [CrossRef]
  15. Rajan, C.D.S. Design and implementation of fuzzy priority deadline job scheduling algorithm in heterogeneous grid computing. J. Ambient. Intell. Humaniz. Comput. 2020, 12, 6073–6080. [Google Scholar]
  16. Kianfar, K.; Barafkandeh, S. A mathematical model and NSGA-II algorithm for bi-objective grid scheduling problem with quality of service satisfaction. Int. J. Serv. Oper. Manag. 2020, 36, 531–557. [Google Scholar]
  17. Miao, Y. Resource scheduling simulation design of firefly algorithm based on chaos optimization in cloud computing. Int. J. Grid Distrib. Comput. 2014, 7, 221–228. [Google Scholar] [CrossRef]
  18. Zang, H.; Zhang, S.; Hapeshi, K. A review of nature-inspired algorithms. J. Bionic Eng. 2010, 7, S232–S237. [Google Scholar] [CrossRef]
  19. Abraham, A.; Buyya, R.; Nath, B. Nature’s heuristics for scheduling jobs on computational grids. In Proceedings of the 8th IEEE international conference on advanced computing and communications (ADCOM 2000), Cochin, India, 14–16 December 2000; Volume 5, pp. 45–52. [Google Scholar]
  20. Ghosh, T.K.; Das, S.; Barman, S.; Goswami, R. A comparison between genetic algorithm and cuckoo search algorithm to minimize the makespan for grid job scheduling. In Advances in Computational Intelligence; Springer: Berlin/Heidelberg, Germany, 2017; pp. 141–147. [Google Scholar]
  21. Younis, M.T.; Yang, S. Genetic algorithm for independent job scheduling in grid computing. Mendel 2017, 23, 65–72. [Google Scholar] [CrossRef] [Green Version]
  22. Ghosh, T.K.; Das, S.; Ghoshal, N. Job scheduling in computational grid using a hybrid algorithm based on genetic algorithm and particle swarm optimization. In Proceedings of the International Conference on Information Technology and Applied Mathematics, Haldia, India, 7–9 March 2019; Springer: Berlin/Heidelberg, Germany, 2019; pp. 873–885. [Google Scholar]
  23. Lorpunmanee, S.; Sap, M.; Noor, M.; Abdullah, A.H. Fuzzy c-mean and genetic algorithms based scheduling for Independent jobs in computational grid. J. Teknol. Mklm. 2006, 18, 1–13. [Google Scholar]
  24. Idris, H.; Ezugwu, A.E.; Junaidu, S.B.; Adewumi, A.O. An improved ant colony optimization algorithm with fault tolerance for job scheduling in grid computing systems. PLoS ONE 2017, 12, e0177567. [Google Scholar] [CrossRef]
  25. Yang, X.S. Firefly algorithm, Levy flights and global optimization. In Research and Development in Intelligent Systems XXVI; Springer: Berlin/Heidelberg, Germany, 2010; pp. 209–218. [Google Scholar]
  26. Yousif, A.; Nor, S.M.; Abdullah, A.H.; Bashir, M.B. A discrete firefly algorithm for scheduling jobs on computational grid. In Cuckoo Search and Firefly Algorithm; Springer: Berlin/Heidelberg, Germany, 2014; pp. 271–290. [Google Scholar]
  27. Shao, W.; Shao, Z.; Pi, D. Modeling and multi-neighborhood iterated greedy algorithm for distributed hybrid flow shop scheduling problem. Knowl.-Based Syst. 2020, 194, 105527. [Google Scholar] [CrossRef]
  28. Zhou, J.; Zhao, X.; Zhang, X.; Zhao, D.; Li, H. Task allocation for multi-agent systems based on distributed many-objective evolutionary algorithm and greedy algorithm. IEEE Access 2020, 8, 19306–19318. [Google Scholar] [CrossRef]
  29. El Baz, D. IoT and the need for high performance computing. In Proceedings of the 2014 International Conference on Identification, Information and Knowledge in the Internet of Things, Beijing, China, 17–18 October 2014; pp. 1–6. [Google Scholar]
  30. De Souza Cimino, L.; de Resende, J.E.E.; Silva, L.H.M.; Rocha, S.Q.S.; de Oliveira Correia, M.; Monteiro, G.S.; de Souza Fernandes, G.N.; Almeida, S.G.M.; Almeida, A.L.B.; de Aquino, A.L.L.; et al. IoT and HPC integration: Revision and perspectives. In Proceedings of the 2017 VII Brazilian Symposium on Computing Systems Engineering (SBESC), Curitiba, Brazil, 6–10 November 2017; pp. 132–139. [Google Scholar]
  31. De Souza Cimino, L.; de Resende, J.E.E.; Silva, L.H.M.; Rocha, S.Q.S.; de Oliveira Correia, M.; Monteiro, G.S.; de Souza Fernandes, G.N.; da Silva Moreira, R.; de Silva, J.G.; Santos, M.I.B.; et al. A middleware solution for integrating and exploring IoT and HPC capabilities. Softw. Pract. Exp. 2019, 49, 584–616. [Google Scholar] [CrossRef]
  32. Deniziak, S.; Bąk, S. Scheduling of Distributed Applications in HHPCaaS Clouds for Internet of Things. In Proceedings of the 2020 23rd International Symposium on Design and Diagnostics of Electronic Circuits & Systems (DDECS), Novi Sad, Serbia, 22–24 April 2020; pp. 1–4. [Google Scholar]
  33. Shiny, R.; Jetlin, C. A Reliable Resource Allocation Approach for Grid. Int. Res. J. Glob. Eng. Sci. 2017, 2, 221–226. [Google Scholar]
  34. Tang, X.; Liao, X. Application-aware deadline constraint job scheduling mechanism on large-scale computational grid. PLoS ONE 2018, 13, e0207596. [Google Scholar] [CrossRef]
  35. Eng, K.; Muhammed, A.; Mohamed, M.A.; Hasan, S. A hybrid heuristic of Variable Neighbourhood Descent and Great Deluge algorithm for efficient task scheduling in Grid computing. Eur. J. Oper. Res. 2020, 284, 75–86. [Google Scholar] [CrossRef]
  36. Gabri, L.R.; Agrawal, Y.; Srinivas, B. A Survey on Grid Computing Scheduling Algorithms. Int. J. Res. Appl. Sci. Eng. Technol. (IJRASET) 2020, 8, 731–736. [Google Scholar] [CrossRef]
  37. Alsaih, M.A.; Latip, R.; Abdullah, A.; Subramaniam, S.K.; Ali Alezabi, K. Dynamic job scheduling strategy using jobs characteristics in cloud computing. Symmetry 2020, 12, 1638. [Google Scholar] [CrossRef]
  38. Kamoyedji, A.; Funabiki, N.; Htet, H.; Kuribayashi, M. A Proposal of Static Job Scheduling Algorithm Considering CPU Core Utilization for User-PC Computing System. In Proceedings of the 2021 9th International Conference on Information and Education Technology (ICIET), Okayama, Japan, 27–29 March 2021; pp. 374–379. [Google Scholar]
  39. Yang, X.S. Nature-Inspired Metaheuristic Algorithms; Luniver Press: Bristol, UK, 2010. [Google Scholar]
  40. Yang, X.S. Nature-inspired mateheuristic algorithms: Success and new challenges. arXiv 2012, arXiv:1211.6658. [Google Scholar] [CrossRef]
  41. Selvi, S.; Manimegalai, D.; Suruliandi, A. Efficient job scheduling on computational grid with differential evolution algorithm. Int. J. Comput. Theory Eng. 2011, 3, 277–281. [Google Scholar] [CrossRef]
  42. Rajagopalan, A.; Modale, D.R.; Senthilkumar, R. Optimal scheduling of tasks in cloud computing using hybrid firefly-genetic algorithm. In Advances in Decision Sciences, Image Processing, Security and Computer Vision; Springer: Berlin/Heidelberg, Germany, 2020; pp. 678–687. [Google Scholar]
  43. Delavar, A.G.; Nejadkheirallah, M.; Motalleb, M. A new scheduling algorithm for dynamic task and fault tolerant in heterogeneous grid systems using genetic algorithm. In Proceedings of the 2010 3rd International Conference on Computer Science and Information Technology, Chengdu, China, 9–11 July 2010; Volume 9, pp. 408–412. [Google Scholar]
  44. Abdulal, W.; Jabas, A.; Ramachandram, S.; Al Jadaan, O. Rank based genetic scheduler for grid computing systems. In Proceedings of the 2010 International Conference on Computational Intelligence and Communication Networks, Bhopal, India, 26–28 November 2010; pp. 644–649. [Google Scholar]
  45. Bellavista, P.; Cinque, M.; Corradi, A.; Foschini, L.; Frattini, F.; Povedano-Molina, J. GAMESH: A grid architecture for scalable monitoring and enhanced dependable job scheduling. Future Gener. Comput. Syst. 2017, 71, 192–201. [Google Scholar] [CrossRef]
  46. Wang, Q.; Gao, Y.; Liu, P. Hill climbing-based decentralized job scheduling on computational grids. In Proceedings of the First International Multi-Symposiums on Computer and Computational Sciences (IMSCCS’06), Hangzhou, China, 20–24 June 2006; Volume 1, pp. 705–708. [Google Scholar]
  47. Zhong, L.; Long, Z.; Zhang, J.; Song, H. An efficient memetic algorithm for job scheduling in computing grid. In Proceedings of the International Symposium on Information and Automation, Guangzhou, China, 10–11 November 2010; Springer: Berlin/Heidelberg, Germany, 2010; pp. 650–656. [Google Scholar]
  48. Talbi, E.G.; Muntean, T. Hill-climbing, simulated annealing and genetic algorithms: A comparative study and application to the mapping problem. In Proceedings of the Twenty-sixth Hawaii International Conference on System Sciences, Wailea, HI, USA, 8 January 1993; Volume 2, pp. 565–573. [Google Scholar]
  49. Santhosh, J.; Aruna, R.; Balamurugan, P.; Arulkumaran, G. An Efficient Job Scheduling and Load Balancing Methods Using Enhanced Genetic Algorithm. Eur. J. Mol. Clin. Med. 2021, 7, 2020. [Google Scholar]
  50. Kang, Q.; He, H.; Wang, H.; Jiang, C. A novel discrete particle swarm optimization algorithm for job scheduling in grids. In Proceedings of the 2008 Fourth International Conference on Natural Computation, Jinan, China, 18–20 October 2008; Volume 1, pp. 401–405. [Google Scholar]
  51. Ghosh, T.K.; Das, S. A novel hybrid algorithm based on firefly algorithm and differential evolution for job scheduling in computational grid. Int. J. Distrib. Syst. Technol. (IJDST) 2018, 9, 1–15. [Google Scholar] [CrossRef]
  52. Abraham, A.; Liu, H.; Zhang, W.; Chang, T.G. Scheduling jobs on computational grids using fuzzy particle swarm algorithm. In Proceedings of the International Conference on Knowledge-Based and Intelligent Information and Engineering Systems, Bournemouth, UK, 9–11 October 2006; pp. 500–507. [Google Scholar]
  53. Chen, T.; Zhang, B.; Hao, X.; Dai, Y. Task scheduling in grid based on particle swarm optimization. In Proceedings of the 2006 Fifth International Symposium on Parallel and Distributed Computing, Timisoara, Romania, 6–9 July 2006; pp. 238–245. [Google Scholar]
  54. Liu, H.; Abraham, A.; Hassanien, A.E. Scheduling jobs on computational grids using a fuzzy particle swarm optimization algorithm. Future Gener. Comput. Syst. 2010, 26, 1336–1343. [Google Scholar] [CrossRef]
  55. Zhang, L.; Chen, Y.; Yang, B. Task scheduling based on PSO algorithm in computational grid. In Proceedings of the Sixth International Conference on Intelligent Systems Design and Applications, Jinan, China, 16–18 October 2006; Volume 2, pp. 696–704. [Google Scholar]
  56. Ankita, S.; Sahana, S.K. Ba-PSO: A Balanced PSO to solve multi-objective grid scheduling problem. Appl. Intell. 2021, 1–13. [Google Scholar] [CrossRef]
  57. Forestiero, A.; Mastroianni, C.; Spezzano, G. A Multi-Agent Approach for the. Self-Organ. Auton. Inform. (I) 2005, 135, 220. [Google Scholar]
  58. Tasgetiren, M.F.; Sevkli, M.; Liang, Y.C.; Gençyilmaz, G. Particle swarm optimization algorithm for single machine total weighted tardiness problem. In Proceedings of the Proceedings of the 2004 Congress on Evolutionary Computation (IEEE Cat. No. 04TH8753), Portland, OR, USA, 19–23 June 2004; Volume 2, pp. 1412–1419. [Google Scholar]
  59. Onwubolu, G.C.; Davendra, D. Differential Evolution: A Handbook for Global Permutation-Based Combinatorial Optimization; Springer Science & Business Media: Berlin/Heidelberg, Germany, 2009; Volume 175. [Google Scholar]
  60. Chandrasekaran, S.; Ponnambalam, S.; Suresh, R.; Vijayakumar, N. A hybrid discrete particle swarm optimization algorithm to solve flow shop scheduling problems. In Proceedings of the 2006 IEEE Conference on Cybernetics and Intelligent Systems, Bangkok, Thailand, 7–9 June 2006; pp. 1–6. [Google Scholar]
  61. Tasgetiren, M.F.; Liang, Y.C.; Sevkli, M.; Gencyilmaz, G. A particle swarm optimization algorithm for makespan and total flowtime minimization in the permutation flowshop sequencing problem. Eur. J. Oper. Res. 2007, 177, 1930–1947. [Google Scholar] [CrossRef]
  62. Sadasivam, G.S.; Rajendran, V.V. An efficient approach to task scheduling in computational grids. Int. J. Comput. Sci. Appl. 2009, 6, 53–69. [Google Scholar]
  63. Yang, X.S. Firefly algorithms for multimodal optimization. In International Symposium on Stochastic Algorithms; Springer: Berlin/Heidelberg, Germany, 2009; pp. 169–178. [Google Scholar]
  64. Senthilnath, J.; Omkar, S.; Mani, V. Clustering using firefly algorithm: Performance study. Swarm Evol. Comput. 2011, 1, 164–171. [Google Scholar] [CrossRef]
  65. Kołodziej, J.; Khan, S.U. Multi-level hierarchic genetic-based scheduling of independent jobs in dynamic heterogeneous grid environment. Inf. Sci. 2012, 214, 1–19. [Google Scholar] [CrossRef]
  66. Buyya, R.; Murshed, M. Gridsim: A toolkit for the modeling and simulation of distributed resource management and scheduling for grid computing. Concurr. Comput. Pract. Exp. 2002, 14, 1175–1220. [Google Scholar] [CrossRef] [Green Version]
  67. Iosup, A.; Li, H.; Jan, M.; Anoep, S.; Dumitrescu, C.; Wolters, L.; Epema, D.H. The grid workloads archive. Future Gener. Comput. Syst. 2008, 24, 672–686. [Google Scholar] [CrossRef]
  68. Thesen, A. Design and evaluation of tabu search algorithms for multiprocessor scheduling. J. Heuristics 1998, 4, 141–160. [Google Scholar] [CrossRef]
  69. Shao, S.; Xu, S.X.; Huang, G.Q. Variable neighborhood search and tabu search for auction-based waste collection synchronization. Transp. Res. Part Methodol. 2020, 133, 1–20. [Google Scholar] [CrossRef]
  70. Alrubaie, A.J.K.; Tajuddin, M.F.N.; Zidane, T.E.K.; Azmi, A. Improved hill climbing algorithm with fast scanning technique under dynamic irradiance conditions in photovoltaic system. In Journal of Physics: Conference Series, Volume 1432, First International Conference on Emerging Electrical Energy, Electronics and Computing Technologies 2019, Melaka, Malaysia, 30–31 October 2019; IOP Publishing: Bristol, UK, 2020; Volume 1432, p. 012061. [Google Scholar]
  71. Sin, I.H.; Do Chung, B. Bi-objective optimization approach for energy aware scheduling considering electricity cost and preventive maintenance using genetic algorithm. J. Clean. Prod. 2020, 244, 118869. [Google Scholar] [CrossRef]
  72. Langari, R.K.; Sardar, S.; Mousavi, S.A.A.; Radfar, R. Combined fuzzy clustering and firefly algorithm for privacy preserving in social networks. Expert Syst. Appl. 2020, 141, 112968. [Google Scholar] [CrossRef]
Figure 1. IoT Grid Environment.
Figure 1. IoT Grid Environment.
Sensors 22 00850 g001
Figure 2. GFA IoT Grid Task Scheduling Architecture.
Figure 2. GFA IoT Grid Task Scheduling Architecture.
Sensors 22 00850 g002
Figure 3. Model of IoT Grid Job Scheduler.
Figure 3. Model of IoT Grid Job Scheduler.
Sensors 22 00850 g003
Figure 4. The Flowchart of the Proposed GFA.
Figure 4. The Flowchart of the Proposed GFA.
Sensors 22 00850 g004
Figure 5. The Firefly Permutation Representation of a Valid Schedule.
Figure 5. The Firefly Permutation Representation of a Valid Schedule.
Sensors 22 00850 g005
Figure 6. Corresponding Gantt chart of S 1 and S 2 .
Figure 6. Corresponding Gantt chart of S 1 and S 2 .
Sensors 22 00850 g006
Figure 7. Makespan times of GFA Compared to Different Scheduling Methods for Different Workloads.
Figure 7. Makespan times of GFA Compared to Different Scheduling Methods for Different Workloads.
Sensors 22 00850 g007
Figure 8. Execution times of the GFA Compared to Different Scheduling Methods for Different Workloads.
Figure 8. Execution times of the GFA Compared to Different Scheduling Methods for Different Workloads.
Sensors 22 00850 g008
Figure 9. Makespan and Execution times for Typical Workloads.
Figure 9. Makespan and Execution times for Typical Workloads.
Sensors 22 00850 g009
Figure 10. Makespan and Execution times for Heavy Workloads.
Figure 10. Makespan and Execution times for Heavy Workloads.
Sensors 22 00850 g010
Figure 11. Makespan and Execution times for Lightweight Workloads.
Figure 11. Makespan and Execution times for Lightweight Workloads.
Sensors 22 00850 g011
Table 1. Data for the Example Instance Jobs.
Table 1. Data for the Example Instance Jobs.
Jobs J 1 J 2 J 3 J 4 J 5 J 6 J 7 J 8 J 9
Length859244786368743030
Table 2. Data for the Example Instance Resources.
Table 2. Data for the Example Instance Resources.
Resource R 1 R 2 R 3 R 4
Speed 5.5 857
Table 3. Parameter values of Greedy Firefly Algorithm.
Table 3. Parameter values of Greedy Firefly Algorithm.
ParametersSize of Population α γ β Number of iterations
Values1090.021.0300
Table 4. Makespan times of The GFA Compared to Different Scheduling Methods for Different Workloads.
Table 4. Makespan times of The GFA Compared to Different Scheduling Methods for Different Workloads.
No. of Jobs500100015002000300040005000600070008000900010,000
TS25203027372743436848656330877610,02210,11812,184
GA46467013827394185425357196452648865129600
Firefly18284612932513284325641024196430742934742
GFA12203211424312627265429583193321135023945
Table 5. Execution times of the GFA Compared to Different Scheduling Methods for Different Workloads.
Table 5. Execution times of the GFA Compared to Different Scheduling Methods for Different Workloads.
No. of Jobs500100015002000300040005000600070008000900010,000
TS25203027372743436848656330877610,02210,11812,184
GA46467013827394185425357196452648865129600
Firefly18284612932513284325641024196430742934742
GFA12203211424312627265429583193321135023945
Table 6. Makespan and Execution times for Typical Workloads.
Table 6. Makespan and Execution times for Typical Workloads.
No. of 5000 JobsTSGAStandard FireflyGFA
GFA4865425332562654
Execution time101,424115,14842,95821,005
Table 7. Makespan and Execution times for Heavy Workloads.
Table 7. Makespan and Execution times for Heavy Workloads.
No. of 5000 JobsTSGAStandard FireflyGFA
Makespan Time12,184960047423945
Execution time168,322158,12193,39465,049
Table 8. Makespan and Execution times for Lightweight Workloads.
Table 8. Makespan and Execution times for Lightweight Workloads.
No. of 5000 JobsTSGAStandard FireflyGFA
Makespan Time20462820
Execution time5591040557518
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Yousif, A.; Alqhtani, S.M.; Bashir, M.B.; Ali, A.; Hamza, R.; Hassan, A.; Tawfeeg, T.M. Greedy Firefly Algorithm for Optimizing Job Scheduling in IoT Grid Computing. Sensors 2022, 22, 850. https://0-doi-org.brum.beds.ac.uk/10.3390/s22030850

AMA Style

Yousif A, Alqhtani SM, Bashir MB, Ali A, Hamza R, Hassan A, Tawfeeg TM. Greedy Firefly Algorithm for Optimizing Job Scheduling in IoT Grid Computing. Sensors. 2022; 22(3):850. https://0-doi-org.brum.beds.ac.uk/10.3390/s22030850

Chicago/Turabian Style

Yousif, Adil, Samar M. Alqhtani, Mohammed Bakri Bashir, Awad Ali, Rafik Hamza, Alzubair Hassan, and Tawfeeg Mohmmed Tawfeeg. 2022. "Greedy Firefly Algorithm for Optimizing Job Scheduling in IoT Grid Computing" Sensors 22, no. 3: 850. https://0-doi-org.brum.beds.ac.uk/10.3390/s22030850

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop