The present invention relates to apparatus for and a method of resource management.
Resource management comprises resource planning and resource scheduling, and is concerned with deployment of resources to jobs or tasks. One of the goals of resource management is to reduce operational costs and improve quality of service associated with the resource deployment. Resource planning is concerned with identifying potential resource utilisation in terms of number of resources corresponding to type of jobs on the basis of forecasted and where appropriate, actual volumes of work (resource planning is said to be coarse-grained). Resource scheduling is concerned with assigning resources to actual jobs and identifying explicit execution times for those jobs (resource scheduling is said to be fine-grained). Resource planning is an essential pre-cursor to successful resource scheduling: resource planning can be used to strategically arrange the right amount and type of resources in preparation for scheduling of actual jobs.
A problem with existing resource management systems is that resource planning, if done at all, is only done at a coarse-grain level and very rarely accounts for the dynamic nature of resource management (e.g. unanticipated events such as resources being unavailable at short notice, change in weather conditions, which makes travelling difficult in the case of mobile resources, and so forth). This often leads to a gap between planning and scheduling.
As stated above, resource scheduling operates at a fine-grain level, meaning that the scheduling part of resource management systems has to identify actual resources that can carry out actual jobs that need scheduling. This can often lead to costly assignment of resources to jobs, as the resource scheduling part makes scheduling decisions on the basis of fixed information about the resources, which at this stage, cannot be changed. Consider the following illustrative scenario: a job J1, which needs skill sk1, and is located at L1, needs to be scheduled today D1. Assume that only two resources have this skill: R1 and R2. Assume that R2, who is located near to L1, is off-line today D1; assume also that R1 is located at L3, which is far from L1. As R1 is off-line, and the job J1 has to be carried out today D1, the resource scheduling part has no choice but to assign resource R2 to job J1. The requisite movement of resource R2 from location L3 to L1 incurs significant travel costs.
If the resource planning part were operable to modify attributes of the resources, as well as numbers of resources, it may have seen that although R1 was off-line, it had flagged up its availability for working overtime on days when it is off-line. Thus it could have activated resource R1 on day D1, meaning that R1 could carry out job J1, involving little or no travel costs. (The assumption here being that it is less costly to bring R1 on overtime than let R2 travel to L1).
Clickplan™ is one of several companies specialising in developing scheduling and planning software. One of their press releases, entitled “ClickSoftware Announces First Intelligent Capacity Planning Tool For The Service Industry”, identifies the need to assess, in advance, how well or badly, resources are likely to meet predicted demand. This press release was published October 2000, and, at August 2002, is available from pttp://www.clicksoftware.com/press.asp?csid=49&archive=1. Usually a URL takes the form of a first part indicating the network delivery mechanism (e.g. http:// or file:// for the hypertext transfer protocol or file transfer protocol respectively) followed by the network address of the server (e.g. www.server 1.com) suffixed with the name of the file that is being requested. Note that, in the examples given, such names are, for typographical reasons, shown with “http” replaced by “pttp”.
In particular, this press release states: “ClickPlan analyzes the forecasted work by timeframe, job type, skill requirements, and geographic territory. It analyzes available and allocated resources while taking into consideration hours worked, overtime policies, work rules, service level commitments, holidays and vacations, and other factors that influence the capacity of the service force. As resources are allocated, ClickPlan highlights potential shortages, surpluses, and imbalances in the workforce.” Thus ClickPlan™ enables a workforce manager to identify potential shortfalls in resources, so that he can rearrange the resources ahead of time. This press release does not, however, describe the actions that can be taken once such shortages, surpluses etc. have been identified.
According to embodiments of the present invention, there is provided a method of planning resource utilisation in respect of job requirements, the job requirements comprising a plurality of jobs to be carried out over a plurality of days, the method comprising the steps of:
A resource record in this context will usually be a set of one or more values for factors, or attributes, which describe status, capacity and capability of a resource. For instance, in relation to workload an available set of attributes might be availability, location, capability for doing different types of work (“skill”) and productivity. The resource record for a resource component based on those attributes might then hold values for at least some of those attributes.
A resource record can alternatively be referred to as a profile, and resource planning can be considered to include an additional process, herein referred to as resource profiling, where resource records are optimised in accordance with the invention. Accordingly resource records are generated in the light of predicted workload, which includes known tasks and predicted tasks based on, for example, historical data and known patterns in workload. The resource records are adapted with a view to matching configuration of skills, availability and locations of the resources to the skills, timing and locations of the tasks making up the workload. This means that when a scheduling part schedules the tasks, it uses data that implicitly satisfies the job requirements.
The workload data used for resource record assignment can be predictive rather than actual data, based at least in part on known workload patterns. Resource record assignment and scheduling of actual workload may be done at different times: scheduling of workload can be carried out at the beginning of every working period, perhaps daily, while the assignment of resource records might be carried out in respect of a week's worth of jobs.
Assignment of a resource record may be done for instance by first determining available attributes for the resource record, selecting from amongst the available attributes, and assigning values for the selected attributes to the resource record.
In preferred embodiments of the present invention, the system further comprises optimisation means for optimising the assignment of values to attributes on the resource record. This might involve reviewing an allocated workload, amending one or more resource records, making a fresh allocation of workload and reviewing the fresh allocation against the earlier allocation in order to choose the better resource record(s). These steps can be repeated until some predetermined criterion, such as the number of repetitions reaches a preset limit, is satisfied, or the optimisation process times out.
In order to optimise the selection of values of attributes of resource records, there needs to be at least one parameter that can be compared between allocated workloads. This can be chosen according to circumstance, but it might be for instance the amount of unallocated workload remaining, or the unallocated workload of a particular type or types. Different workload types may have different priorities, such as urgency or cost, and this can be taken into account.
The manner in which cost is calculated for unallocated workload can be used to prioritise particular types of work and this offers an excellent way to manipulate the resources to meet ongoing requirements. For instance, if work of a particular kind is process-critical, it becomes important that resources are assigned to deal with that kind of work. Usually, a particular kind of work will require particular capabilities to be available. In the method described above, which is preferably recursive, it is possible to weight the resource record selection towards resource records that will allow more of the process-critical work to be allocated. In a first alternative manner this involves weighting the cost of such work so that it becomes more expensive if left unallocated than if it is allocated. The result will be that the recursive process will encourage resource records to be selected which contain the attributes and/or values which support that kind of work in preference to other attributes and/or values.
In a second alternative approach, which can be used alone or in combination with the first alternative, a cost function can be used to weight the selection of attributes and/or values of one or more resource records. In this approach, assignment costs are used at least in part as a measure of resource record selection. If it has been recognised that one or more attributes and/or values are going to be important, for instance over a particular period to meet a known workload content, then the assigned cost of the attribute(s) and/or value(s) can be reduced relative to its unassigned cost.
In a third alternative, an attribute and/or value can be designated as “essential” in the resource record of one or more resources. This is relatively efficient, though potentially less flexible, since it reduces the number of permutations the system has to cost for assigned resource records and/or allocated workload.
Particularly advantageously, a warning system can be implemented, via the above-mentioned cost function, which raises an alert related to overutilisation of resource. This is done by introducing a “dummy” record of a resource which has a relatively high cost associated with it. An alert is raised if workload is allocated to it as this will usually mean resources must be overstretched. The warning system can also be arranged to monitor underutilisation of resources by checking for low or zero allocation to a resource.
As work patterns show repetitive behaviour, for instance in relation to the working week, embodiments of the invention can utilise work pattern data to proactively organise resource deployment. In anticipation of actual job requirements, resources can be brought online, moved or taken out of service at times that have minimal impact on workload.
An advantage of embodiments of the present invention is that they can be used to meet the requirements of particular events or campaigns: data representative of expected demand for the event or campaign can be used as workload data, and resource records then adapted with a view to matching allocation of capabilities and capacities to the event data. Thus when the event occurs, resources are automatically available to meet the demand.
The content of a resource record is clearly important since it is key to the recursive process and it can have a very significant relationship with the parameter or parameters chosen for comparison of effectiveness of the allocated workloads. If the environment in which the workload is to be carried out is static and the location of the component is known, then the resource record may not include a value for the location attribute at all but may include values for each of the other attributes, such as “1” to indicate full availability, “sk1, sk2” to indicate the resource component has two specific skills and “5, 10” to indicate it can perform 5 tasks an hour which use skill “sk1” and 10 tasks an hour which use “sk2”.
Resource records generated in accordance with the invention can be used to schedule tasks to resources in a workforce management system. Although this is of course a resource involving people, it is a close equivalent to a resource involving machines, because attributes of a resource record are equally applicable to machines and to people. As an example, a resource record for a technician might include attributes for skill, productivity, area, state (ie availability) and preferences. In a machine, these, or similar, attributes apply, representing for instance what the machine is designed and equipped to do (skill), what rate it is capable of working at (productivity), geographical or network location (area), availability, taking into account, for example, downtime or prebooking for non-system tasks (state) and preferred behaviour such as being used for particular tasks or in particular positions (preferences). The preferences might arise for instance out of operational facts such as having limited data storage backup available which makes a database capable but unsuitable for storing critical data types, or certain network locations being preferred for information processing because the bulk of the information is generated close to those network locations.
Resource records can also be generated for call centre equipment, as it can be very important to have sufficient capacity available at specific times and in specific places in order to process valuable calls.
Embodiments of the invention will now be described, by way of example only, with reference to the accompanying figures, in which:
a is a flow diagram showing a method of modifying and selecting resource records according to the second embodiment;
b is a schematic block diagram illustrating parts of the method shown in
The output of the resource planning module 100—namely capacity plans and modified resource records—is input to a deployment module 105, which feeds in daily deployment plans 110 to the scheduling part 115.
The second workload data 120 comprises actual jobs that are to be scheduled, and typically fall within a timescales such as a day. The actual workload data 120, together with the deployment plans 110 that are output from the deployment module 105, are used by the scheduling part 115.
Embodiments of the invention are concerned with the resource planning module 100 and the deployment module 105.
As stated above, in known systems, resource components have resource records associated therewith. However, the resource records are input to the system as fixed data, which the system has no ability to amend or select from. This is unsurprising since the data is based on fact: for instance resources are either available or they are not available and they will be equipped with one or more of a range of capabilities. However, it has been recognised in making the present invention that it is possible to change one or more attributes of a resource component, for instance in the light of workload. That is, resource components can for instance be taken in and out of service, moved geographically or in a network, or can have capabilities added or removed. In this approach, workload can at least to some extent drive the resource availability rather than the other way around and it is advantageous if the system then can select and assign the resource records.
In embodiments of the invention resource planning is considered to include a process whereby resource records are modified in order to match available resources to workload. For clarity, this process is hereinafter referred to as “resource profiling”. It will be appreciated by a skilled person that resource profiling can be viewed as an integral part of resource planning.
In the following description, a first embodiment of the invention is described in the context of generating resource records in the form of an engineering team of technicians. As described above, a resource record is a set of data describing the attributes of a resource, for example skills, working areas, availability and so on, and can alternatively be referred to as a profile. The first embodiment is concerned with generating deployment plans 110 for input to the scheduling part 115.
An overview of the mechanism of resource profiling according to embodiments of the invention is shown in
Apparatus embodying the means 203 for making and running the model is, in a first embodiment of the invention, referred to as a dynamic profiler DP and is described in more detail with reference to
The structure of the model 300, created by the dynamic profiler DP, will now be described, with reference to
The DPProblemModel 300 created by the dynamic profiler DP comprises a plurality of modules, some of which represents a concept: Area 301, Skill 303, State 307, Job 309 and Resource 311, and some of which represent conditions and constraints imposed upon the concepts: objective function 313, constraints 315, cost 317. In at least some embodiments, the DPProblemModel can be defined using object-oriented techniques, so that each concept is represented by a class. Table 1 describes object-level descriptions of DPProblemModel, Area, Skill, State, BasicTask (i.e. job), Resource (i.e. technician).
The modules of the problem model 300 are now described in more detail:
Decision variables module 302 include attributes (components of the resource records) which can be assigned or allocated to each technician and comprise:
Constraint Module 315: The constraint module includes functions that are used to validate resource records. In one arrangement the DPProblemModel 300 includes two constraints: the first is the acceptable range of values for each technician of the decision variables (area, skill and state) and the second enforces the matching of the decision variables in a technician's resource record to the attributes of each job allocated to that technician. The constraints module includes a feasibility measure, which is a measure of whether any aspect of the assignment of decision variables to a technician's resource record violates any of the constraints. An example of the form of the constraint module 315 is defined in Appendix B.
Costs Module 317: The cost module includes functions used to evaluate costs. In one arrangement the DPProblemModel 300 comprise assignment and allocation costs: assignment costs are the costs of assigning values to the decision variables in a technician's resource record, taking priorities into account (described below) in support of the first component of the objective function; and allocation costs are the costs of allocating jobs to technicians, taking priorities into account in support of the second component of the objective function. An example of the form of the cost module 317 is defined in Appendix A.
The dynamic profiler DP acts as a resource manager, providing a central repository of concepts (decision variables and constraint specification), transaction management, constraint checking and costing. The dynamic profiler DP is arranged to:
The data used to populate the modules 301 . . . 317 is stored in a database (not shown) and read by the dynamic profiler DP when populating the model 300. This is described in more detail below (step 405a and subsequent steps).
This data includes area, state, skill information for technicians, and area, skill, state, costs (each area, skill and state has an assignment and unallocation cost) and priority for tasks. The technician information defines:
The task information includes area corresponding to the task and skills and date required for the task, together with a prioritisation value corresponding thereto. The priority value, which, for example, ranges from 0 to 100, represents some form of prioritisation in the business. For example, if the business dictates that residential jobs have lower priority than business jobs, lower priority values will be assigned to areas and skills related to residential jobs compared to priority values assigned to business jobs. On the other hand if the business dictates that quality of service (in terms of completing jobs) should be improved for a given month, then states of 1.0 will have the highest priority. Priority values are used in costing solutions.
Referring now to
Although shown schematically as step 400, in general, it is assumed that the DPProblemModel 300 has been created. This has been described in the preceeding sections, and essentially involves creating modules 301-317 corresponding to the concepts and conditions, as described above.
Next the DPProblemModel 300 so created is populated with data. This involves reading 405a data identifying jobs to be carried out (forecast and workstack jobs, falling within a timescale such as a week), assignment and allocation costs associated therewith, technician skills, area and state data, and generating 405b candidate list of jobs for each technician, using job data read at step 405a. This data can be read from a database. A job is a candidate for a technician if there is at least one way of building a resource record for the technician so that
Thus the output of step 405b is a set of lists of candidate jobs to be carried out by the technicians (the candidate jobs will fall at different times within the week.
Next, at step 405c, the decision variables (skills, area, state) are added to the decision variables module 302, using technician data read at step 405a, and the constraints corresponding to the decision variables are added 405d to the constraints module 315. As mentioned above, there are two types of constraint, the first being the acceptable range of values for each technician of the decision variables (area, skill and state, and implicitly included in the technicians data read at step 405a) and the second enforcing the matching of the decision variables in a technician's resource record to the attributes of each job allocated to that technician. These allocation constraints can be preprocessed for the candidate jobs generated at step 405b.
Next, at step 405e, costs associated with assignment and unallocation are added to the cost module 317. The costs are described in more detail in the context of modifying and evaluating resource records, steps 505, 510.
Next, at step 610, solution resource records are generated. This involves connecting the DPProblemModel 300 to the HSF model 305, which generates 500 an initial solution comprising a feasible instantiation of all feasible resource records. Table 2 shows a simple example of resource records for three technicians, and Table 3 shows attributes and values thereof for three jobs that have to be carried out.
Each technician has a default resource record, which is a resource record that incurs least cost for the technician and effectively acts as reference for costing skill, area and state; when evaluating resource records (step 515, described below), the HSF model 305 compares the costs associated with a modified resource record and the default resource record. When generating a resource record for day “n”, a default resource record may be the resource record for day “n−1”.
Given an initial feasible solution, the HSF model 305 generates potential solutions 505 and evaluates the potential solutions 510 until a termination condition (that is algorithm dependent) is reached.
There are essentially two approaches to generating (step 505) and evaluating (step 510) resource records: the first treats assignment and allocation variables the same way, assigning values to attributes of the resource record and allocating resources on the basis of the assignment at the same time and then evaluating costs associated with the resource record and unallocated jobs. The second approach separates assignment and allocation and firstly solves the assignment problem by assigning variables to the resource records and evaluating the resource records, and then solves the allocation problem based on preferred resource records. The latter approach is preferred, because in the former approach infeasible solutions can be generated.
Accordingly, during the modification step 505, the HSF model 305 generates a neighbourhood for the current resource records using a heuristic search method selected by the HSF model 305. This method can be specified by a user, or selected automatically by the HSF model 305 (examples of neighbourhoods are described in Appendix C).
A neighbour represents potential resource records and is evaluated 510 with regard to the success, or otherwise, of allocating jobs to the technicians on the basis of the resource records.
Resource record modification (generating moves on the resource record) involves altering, adding or deleting values for its attributes. Attributes of each resource record that can be altered include: area within the region; skill set; availability. Resource record alterations affect costs: a workload involves different types of jobs, and different types of unallocated jobs incur different costs to the business. For instance, certain types of job may have a higher priority because they are subject to premium service level agreements. A backlog in this type of job represents a higher cost to the business if it remains unallocated, so that resource records which enable successful allocation of high priority jobs can have comparatively low costs associated therewith.
The mechanism for evaluation (step 510) involves a call to the constraint and cost modules 315, 317 in the DPProblemModel 300.
In overview, the costing part of step 510 evaluates costs associated with travel, area, skill-sets and states for the workforce and the set of unallocated jobs. Individual costs are aggregated across the whole workforce or work pool. Weights can be introduced to allow prioritisation of, say, travel, over unallocation of a job.
In detail, the costing part of step 510 involves assignment of cost functions in the cost module 317, comparing a current resource record (i.e. current assignment) with the default resource record and noting the differences between them. The priorities associated with the job for skill, state and area are used to calculate the differences. Unallocation cost functions in the cost module 317 review the priority associated with the job and identify a cost associated therewith: the higher the priority, the higher the cost of leaving a job unallocated, taking into account a date by which the job must be done (read in at step 405e). Additionally the costing step can include evaluating travel costs associated with the resource record by means of travel costing functions (in the costing module 317, not described above). These travel costing functions calculate the distance between the centroid of the jobs allocated to a resource and its preferred working location (PWL). A lower travel cost denotes a lower resource utilisation cost.
The constraint checking part of step 510 involves discarding infeasible solutions, and ranking feasible ones according to the criteria defined by the algorithm in use by the HSF model 305 (be it Simulated Annealing, Tabu Search etc.).
The HSF model 305 then selects 515 the best solution on the basis of minimum cost, taking account of the costs associated with the default profile (described above).
A potential use of embodiments of the invention is in raising an alert in the event of over- or under-utilisation of a resource. Concerning over-utilisation, a further cost type, referred to as a utilisation cost, could be applied to the resources themselves. In general, a resource would have zero utilisation cost but a “dummy” resource, or resource type, might be added which is allocated a relatively high utilisation cost, such as 10,000 units. The domains of the dummy resource might for instance be supersets of all known domains. In essence, a dummy resource can do everything, but, as it has a high utilisation cost associated therewith, it is not normally in the interest of the planning module 100 to use it. If such a resource is selected for resource record assignment after optimisation of resource records, this can be used as an indicator that available resources are very likely to be overstretched after scheduling. When the dummy resource is selected, the planning module 100 can be arranged to generate an alert requesting an additional resource or a decrease in workload.
Conversely, the dynamic profiler DP can be used to predict underutilisation. If, after optimised profiling, there is a pool of unallocated jobs and some resources have no jobs allocated to them, this indicates either that there is simply too much available resource or that the available resources are of the wrong type in at least one respect.
Once a best solution has been selected (step 515), the dynamic profiler DP populates a plurality of resource plans, each corresponding to a single day's worth of jobs (identified from the workload data read in at step 405a). Referring to
A second embodiment analyses resource utilisation based on the number of resources and their level of productivity, but it does not attempt to allocate actual jobs to resources. Thus it is more coarse-grained than the first embodiment.
Referring to
In this second embodiment, the RPProblemModel 700 effectively filters jobs into so-called job buckets. As can be seen in
The total number of job buckets is thus the multiple of the total number of days in a resource plan; the total number of areas in which a job is located; the total number of skills required to carry out all jobs; and the total number of priority ratings. Each job bucket contains zero, one or a plurality of jobs that need to be carried out.
In the representation shown in
The attribute values of individual jobs determine which of the job buckets a job is assigned to; for example, referring again to
The technicians are then similarly filtered into buckets, herein referred to as resource buckets. Each resource bucket represents a resource in terms of: normalised execution date; area resource located in; and number of skills available to resource.
Thus the resource buckets are related to the job buckets in the following manner: for each resource bucket there is a plurality of job buckets, each having a different priority: e.g. for a given day, area and skill, there is an urgent, medium and unimportant job bucket.
A job bucket and a resource bucket can be described as having a “size”, which is essentially the number of jobs and resources respectively that have been assigned to a respective bucket. In the case of the resource buckets, the size thereof is modified by a productivity value and availability. This means that if, for example, technicians T1 and T2 both have skill sk2, but T1 is far more productive than T2, T1's contribution to the resource bucket corresponding to sk2 will be larger than T2's contribution (assuming area and state to be the same).
The RPProblemModel 700 systematically works through each job bucket in accordance with priority, firstly selecting the most urgent job bucket for a first day, first area and first skill. It then reviews the resource bucket corresponding to this selected job bucket (i.e. the resource bucket tagged first day, first area and first skill), and, if there is resource available to complete the job(s), the size of the selected job bucket is reduced by the size of the resource available. The RPProblemModel 700 repeats this for all jobs in the selected job bucket, and, once the size of the selected job bucket has been reduced as much as possible, it moves onto a second job bucket—e.g. the first day, first area and first skill, medium priority bucket. The RPProblemModel 700 repeats the review process described above. This is repeated for all of the job buckets corresponding to the first day. Having reviewed the job buckets in respect of the first day, the RPProblemModel 700 moves onto the second day and repeats the review process in respect of jobs filtered into job buckets corresponding to the second day. This is repeated for all days in the resource plans.
For at least some of the job buckets, it is likely that there will not be sufficient resources to meet the job requirements; for each job bucket, the RPProblemModel 700 evaluates the cost associated with size of job bucket left after the review process.
The HSF model 305 modifies the resource records, by means of a heuristic search method, arranges the new resource availabilities into resource buckets as described above and repeats the attempted job bucket reduction process for the modified resource buckets.
Each time the resource records are modified the HSF model 305 evaluates a cost associated therewith, and records which of the resource records yields a lowest cost.
This second embodiment does not explicitly allocate jobs to individual technicians, but it works out whether or not the collective resource availability can meet the job requirements.
The second embodiment is now described in more detail, with reference to
As for the first embodiment, the RPProblemModel 700 and HSF models 305 are created, shown as step 901 in
The RPProblemModel 700 evaluates jobs to be carried out as a function of day, skill, area and priority, and, using the information in the resource records, evaluates the capacity available for each combination of day, skill and area (each resource is assumed to use one skill each day).
Accordingly, referring also to
It then initialises 913 the capacity available to meet the jobs of all priorities having skill j and area k on that day to this total resource capacity:
capacity lefti,j,k,I=0=Resource capacityi,j,k
(I=1 high priority; I=0≡initial conditions) (E2)
The number of jobs to be done 93 having priority I (demandi,j,k,I) is then calculated 915: this is made up of new jobs assigned to day i that have priority I (new jobsi,j,k,I), and unassigned jobs from the previous day that have priority I (Unsatisfied demandi-1,j,k,I):
demandi,j,k,I=new jobsi,j,k,I+Unsatisfied demandi-1,j,k,I
//unsatisfied demand 95 (i.e. jobs not carried out in bucket (i-1,j,k,I) are carried over to the equivalent bucket (i,j,k,I) in the next day (E3)
where
Unsatisfied demandi,j,k,I=demandi,j,k,I−capacity lefti,j,k,I-1
//unsatisfied demand on bucket I=demand on bucket I−capacity left after satisfying bucket I−1
// i.e. unsatisfied demand [for the highest priority bucket]=
// demand on hi′ priority bucket−total capacity available
// unsatisfied demand [for the medium priority bucket]=
// demand on med′ priority bucket−capacity available after satisfying the hi′ priority bucket (E4)
In other words, the number of unassigned jobs having priority I is given by the difference between the number of jobs to be done having priority I and the capacity available to do those jobs. Clearly as the RPProblemModel 700 moves through the different priorities on day i, the capacity available (capacity lefti,j,k,I) decreases because resources are effectively assigned to jobs. Thus the RPProblemModel 700 calculates 917:
capacity lefti,j,k,I=capacity lefti,j,k,I-1−demandi,j,k,I
//capacity left after satisfying bucket I=capacity left after satisfying bucket I-1−demand on bucket I(E5)
In addition, a cost associated with the unassigned jobs (Unsatisfied demandi,j,k,I) is evaluated 919:
Where weightI is dependent on the priority associated with the job (higher priority jobs incurring higher costs). Calculations (E1- E5) are repeated for all days i (each day in the resource plan), all skills j, all areas k and all priorities I, whereupon the overall cost is calculated (E6).
The HSF model 305 then modifies 505 the resource records, and steps 911-919 are repeated for the modified resource records. In one arrangement of this embodiment, the HSF model 305 modifies the resource records a predetermined number of times, or until an explicit time limit is reached. In another arrangement, the HSF model 305 continues to modify the resource records until the cost evaluated at step 510 satisfies a predetermined cost criterion.
This second embodiment incurs less processing overhead than the first embodiment, because there is no job allocation, meaning that there is no need to explicitly check constraints. In addition the second embodiment can be used to assess resource availability for an arbitrary time period.
Infrastructure Requirements of Resource Management System 101
Referring to
The inputs to the resource planning module 100, on which it bases its resource deployment plans, are based at least in part on actual workload and performance data which is collected during use of the resources. For example, the actual workload data 120 scheduled by the scheduling module 115 is used to maintain historic data 145, which is input to a forecasting module 150 to obtain forecast workload data 130. Also, any jobs that were input to the scheduling part 115, but were not carried out by the resources are stacked and added to workstack data 135. The workstack data 135 can also comprise jobs arising from ongoing or new service level agreements (“SLAs”).
The class for the cost module 317 for the first embodiment is defined as follows:
The global cost function including the weights can then be defined as follows:
(Re First Embodiment)
The ConstraintModel class (constraint module 315) is defined as follows:
Constraint Optimisation Problem (COP) Formalism
A COP representation (see for example “Foundations of Constraint Satisfaction” by Tsang, published by Academic Press, London, 1993) of a combinatorial optimisation problem is a tuple <X,D,C,F>, where X is the set of the variables to assign, D is the scalar product of the variable domains, C the set of constraints and F the objective function to optimise. A solution of a COP is a tuple of values (X1, . . . Xm), where X contains m variables, such that each xi belongs to the domain Dx
Each value of a skill variable is a list of symbols, each one representing a technician's skill. Each value of a state variable is an integer representing the id of the technician's state. Each value of an area variable is an integer representing the id of the technician's area.
D is the domain of all the possible solutions of the problem. A first approximation of D can be defined as
D′=(Dk x . . . x Dhd t)×(Dt x . . . Dt)×(Da x . . . xDa)
In the real problem definition of Dynamic Profiling, each skill, state and area variable has a specific domain. Thus for each i from 1 to n, for each ki in K, the domain Dk
The same for the state variables:
For each i from 1 to n, for each ti in T,
The same for the area variables:
So the real domain of this problem is a restriction of D′:
D=(Dk
The objective function F is a function that gives a real or float value from a tuple of values taken from the variable domains. F is defined by the following mathematical formula:
The travel cost is computed as the Euclidean distance between the area assigned to a technician and the centroid (i.e. area) of the jobs allocated to him.
TravelCost jobi)=f(ai,position(jobi)).
Implementation of the Resource Planning Module 100
Embodiments of the present invention can be used in a range of different applications and environments and it is particularly convenient if one or more of the software modules involved in embodiments of the present invention can be put together in a flexible manner which can be tailored at least to some extent to the application or environment it is intended for.
In the first and second embodiments, this is done by separating the module into a representation of the profiling problem and an optimisation algorithm. Importantly, the optimisation algorithm is not fixed but can be selected and modified easily. The problem and optimisation representations can be implemented using the iOpt™ Toolkit, which is a Java-based optimisation toolkit for modelling and solving combinatorial problems. Details of the Toolkit can be found in “Heuristic Search and One-way Constraints for Combinatorial Optimisation” by Voudouris C. and Dorne R (2001), Proceedings of CP′AI-OR2001, Wye College (Imperial College), Ashford, Kent UK and are subject to copending patent application number GB02/00051 in the name of the present applicant. In one arrangement the problem of resource record assignment can be represented using iOPT™ Problem Modelling Framework (PMF) toolkit referenced above. With PMF a problem model (constraints etc. thereon) is expressed using invariants, which are one-way constraints.
It will be understood by one skilled in the art that other constraints, other than one-way constraints, could be used. As an alternative to implementing the dynamic profiler DP and resource planner RP with the iOPT™ toolkit, embodiments of the present invention could interface with constraint programming packages such as ILOG “Solver”, described in Puget, J-F., Applications of constraint programming, in Montanari, U. & Rossi, F. (ed.), Proceedings, Principles and Practice of Constraint Programming (CP'95), Lecture Notes in Computer Science, Springer Verlag, Berlin, Heidelberg & New York, 647-650,1995. The ILOG Solver utilizes multi-way constraints and consists of a number of built-in relations and constraint types, which a user can use to define its problem.
The optimisation algorithm can conveniently be implemented using Heuristic Search Framework (HSF, referred to several times in the description above) provided as part of the iOP™ toolkit. HSF includes a collection of heuristic search algorithms for solving combinatorial and optimisation problems, which can be used to find solutions to the problems that have been defined using the iOpt Problem Model Framework (or that have been defined using other modelling means).
Using the iOPT™ toolkit, the DPProblemModel 300 can be created as described below:
1. Model business data: Analysing the preconditions, resource records, costs and constraints of the DP problem allows five logical concepts needed for reasoning about the problem to be identified, Area, Skill, State, Technician and Job, and the parameters for these are set out in Table 1 above. The entry point to iOpt Toolkit's invariant facilities is the Problem class. The Problem class acts a resource manager for iOpt Toolkit, providing a central repository of the user-defined concepts (classes in Java parlance), transaction management, and constraint checking services. The DPProblemModel class as defined extends the Problem class. A class for each concept can then be created—Area, Skill, State, Job and Resource. At runtime, (step 405) the DPProblemModel instance is populated with instances of Area, Skill, State, Job and Resource.
2. Model decision variables: Since the resource record for each technician must contain Area, State and Skill values, their corresponding domains can be modelled as an IntegerDomainVar (in iOpt Toolkit parlance). These are then added to the DPProblemModel as decision variables (step 405c).
3. Model constraints: As described above, there are three main constraints in DP, and these involve variables Area, State and Skill. To ensure computational efficiency, constraints involving skill and area can be placed in the Job class and the constraint involving state can be placed in the Resource class. Other optional constraints can be added such as “enabled” to the Resource and Job classes. This is to facilitate enabling/disabling of jobs and technicians during a profiling session. A constraint model is implemented which encompasses functions that DP uses to validate resource records. As described in relation to step 405d, the constraints can be preprocessed by building a list of candidate jobs for each technician.
4. Define cost: The objective of DP is to generate optimal resource records. To this end, three types of cost are modelled: assignment costs; resource utilisation costs; and unallocation costs. Assignment and resource utilisation costs are defined for each Technician, whilst unallocation cost is defined for each Job. These costs are added to the DPProblemModel. For a problem instance, an optimal solution of DP represents the minimum cost for that problem instance. The global cost function is defined above under the heading “Cost Model”.
The goal of the HSF component is to generate an optimised solution. To achieve this, the HSF component generates an initial feasible solution. An initial feasible solution is generated in the context that jobs are not allocated to technicians. The Skill, Area and State value domains of the technicians guarantee an initial feasible solution (i.e. Resource record) when all jobs are unallocated, since any assignment of Skill, Area and State values from their corresponding domains is valid. Once a feasible solution has been generated, HSF improves it by using a Local Search (LS) component. Since there are three decision types of decision variables (i.e. Area, State and Skill), three Neighbourhood Search (NS) components are defined (one for Area, one for Skill and one for State). Each NS component generates potential moves for the current solution, evaluates the moves, and selects the best move (i.e. having the minimum value returned by the objective function), thus producing a new solution.
In the second embodiment, the decision variables include Area, Skill, State and resource (no job decision variable), and are characterised by the parameters set out in Table 1. The Problem class of iOPT™ is used to generate the problem model RPProblemModel 700 (step 901), and a class for each concept is created—Area, Skill, State and Resource. The RPProblemModel instance is populated with instances of Area, Skill, State and Resource. Domains corresponding to the decision variables area, skill, state and area are then created and added to the RPProblemModel as decision variables (step 904). In the second embodiment three types of cost are modelled: assignment costs, resource utilisation and “unallocation” (this refers to jobs left undone) costs, each of which apply in respect of a resource. These costs are added to the RPProblemModel (step 907).
Evaluation of Moves:
Broadly speaking a move is evaluated by first unallocating jobs assigned to the corresponding technician, adding the jobs to the pool of unallocated jobs, reallocating the unallocated jobs to the technicians on the basis of the newly modified resource records, and using the objective function to return a value. In this scenario a move producing a minimum value for the objective function is considered to be the best.
In the first embodiment, different neighbourhoods for skill, state and area are defined; when a move is made (i.e. when the value(s) of one of these attributes is/are changed) and a resource record is modified, the performance of that modified resource record is evaluated by attempting to re-allocate jobs on the basis of the modified resource record. The steps involved in allocating/reallocating jobs to resources, in the context of the first embodiment, include:
1. For each technician whose resource record is being changed, identify the technician corresponding to the “move” being made and then unallocate all the jobs assigned to that technician that will make the performance of the “move” infeasible. Thus if a skill is assigned in a proposed move, only unallocate those jobs that make the assignment infeasible. If a state is assigned, only unallocate those jobs that make the assignment infeasible.
2. For each technician whose resource record is being changed, unallocate all the jobs assigned to that technician. Here the type of move is not considered during the unallocation phase.
3. Allocate jobs to technicians who already have jobs allocated to them until it is infeasible to allocate further jobs to those technicians. Only then are jobs allocated to an additional technician. This means that technicians tend to be either fully utilised or not used at all, and maximises resource utilisation.
4. This is a variation of the third form of heuristic, which works to balance rather than minimise resource utilisation. In this case, jobs are allocated to technicians which have been least utilised. In this case, jobs are spread as evenly as possible over the resources.
In the second embodiment, HSF improves a solution by using a Local Search (LS) component, which generates one of the following moves on the solution (step 505):
As for the first embodiment, once a solution has been “improved” by one of the above-mentioned moves, it is evaluated. In the second embodiment this involves identifying a match between resource attributes and job attributes (and a cost associated therewith), on the basis of correspondence between resource and job buckets.
A sixth neighbourhood integrates modification of a resource's attributes with the evaluation thereof. Specifically, the sixth neighbourhood involves the following steps:
At this point, you do not know which of the resources have actually been assigned to a job, which is undesirable since an essential part of resource planning involves knowing which resources are off-line and can be brought on-line in the event of changes to the workload. Thus in order to identify those resources that have not been assigned to a job, the following steps are performed:
Since dummy resources are more expensive than both overtime and normal resources, their state should be set to “off”, and the effect thereof evaluated, before the state attribute of other resource types is changed; thus unused dummy resources are identified first.
As stated above (in the specific description relating to the second embodiment) in one implementation of the second embodiment, each resource bucket has a size, and a resource only contributes to the size of a resource bucket if the attribute values in its resource record match those of the resource bucket. However, each resource can be linked to each resource bucket; this is an implementation issue, and is specific to integrating the invention into the iOPT™ toolkit, which uses invariants. The size of a resource bucket, available capacity (capacity left), jobs to be assigned (demand), unassigned jobs (Unsatisfied demand), and costs are invariants (reproducing equations E1-E6 above):
As described in international patent application number GB02/00051, invariants automatically handle updating of conditions and constraints as decision variables involved in the conditions and constraints change. In the second embodiment, as the resource records are modified by the HSF model 305 (step 505), the attributes and values of attributes constituting a resource record change, meaning that resources are effectively moved between resource “buckets”. This is reflected by changes in decision variables (location (k) and skill (j)) and, as these are coupled with the available capacity and demand according to invariant expressions E2, E3, E4, E5, means that the effect of modifying the resource records can immediately be seen.
Number | Date | Country | Kind |
---|---|---|---|
01307806.8 | Sep 2001 | EP | regional |
0206249.5 | Mar 2002 | GB | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/GB02/04153 | 9/11/2002 | WO |