System and method for explicit model predictive control
09766601 · 2017-09-19
Assignee
Inventors
Cpc classification
International classification
Abstract
A method for controlling a system using an explicit model predictive control (EMPC) evaluates, with respect to a state of the system, each inequality in a set of inequalities defining a set of regions of a state space of the system to produce a set of Boolean results. At least some of the inequalities are evaluated concurrently, and a size of the set of Boolean results equals a size of the set of inequalities. The method determines a region including the state by applying a Boolean function to elements of the set of Boolean results corresponding to inequalities forming boundaries of the region and determines a control for the system based on the state and a gain associated with the region. At least some Boolean functions are applied to corresponding elements concurrently after all elements in the set of Boolean results are evaluated.
Claims
1. A method for controlling a system using an explicit model predictive control (EMPC), comprising: evaluating, with respect to a state of the system, each inequality in a set of inequalities defining a set of regions of a state space of the system to produce a set of Boolean results, wherein at least some of the inequalities in the set of inequalities are evaluated concurrently, and wherein a size of the set of Boolean results is equal to a size of the set of inequalities; determining a region including the state by applying a Boolean function to elements of the set of Boolean results corresponding to inequalities forming boundaries of the region, wherein at least some Boolean functions are applied to corresponding elements concurrently after all elements in the set of Boolean results are evaluated; and determining a control for controlling the system based on the state and a gain associated with the region, wherein steps of the method are performed by a processor; wherein the set of Boolean results is a binary vector, wherein each element of the binary vector is one when a Boolean result of a corresponding inequality is true, and, otherwise, is zero, and further comprising: determining Boolean functions for all combinations of elements of the binary vector forming boundaries of each region in the set of regions to produce an output vector, wherein the Boolean function is a product of a combination of the elements, so that an element of the output vector corresponding to the region is one, and other elements of the output vector are zero.
2. The method of claim 1, further comprising: transforming at least some inequalities in the set of inequalities to produce a set of unique inequalities.
3. The method of claim 1, further comprising: transforming a first inequality in the set of inequalities into a negation of a Boolean result of a second inequality in the set of inequalities, wherein the first and the second inequalities represent opposite subspaces from a facet in the state space.
4. The method of claim 3, wherein the second inequality is a non-strict inequality, further comprising: transforming the second inequality into a strict inequality.
5. The method of claim 1, wherein all inequalities are evaluated concurrently.
6. The method of claim 1, wherein inequalities are evaluated using a multiply accumulate (MAC) operation.
7. The method of claim 1, further comprising: determining each bit of an address in a memory storing the gain as a Boolean combination of products of subsets of elements of the output vector.
8. A controller for controlling a system using an explicit model predictive control (EMPC), comprising: an inequality processing (IP) unit for evaluating, with respect to a state of the system, each inequality in a set of inequalities defining a set of regions of a state space of the system to produce a set of Boolean results having one element for each inequality in the set, wherein at least some inequalities from the set are evaluated concurrently, wherein a zero in a particular position of the set indicates that a corresponding inequality evaluated to false and a one indicates that the corresponding inequality evaluated to true; a region identification and gain lookup logic (RGL) unit for determining a region including the state by applying a Boolean function to elements of the set of Boolean results corresponding to inequalities forming boundaries of the region, and for determining a gain associated with the region; and an output processing unit for determining a control for controlling the system based on the state and the gain associated with the region; wherein the RGL unit determines Boolean functions for all combinations of elements of the set of Boolean results forming boundaries of each region in the set of regions to produce an output vector, wherein the Boolean function is a product of the combinations of elements, such that an element of the output vector corresponding to the region equals one, and other elements of the output vector equal zero.
9. The controller of claim 8, wherein the IP unit comprises: a plurality of processing elements (PEs) arranged in parallel for concurrent processing of the at least some inequalities; and a control logic unit for controlling an operation of the PEs.
10. The controller of claim 9, wherein a PE comprises: a memory for storing a subset of inequalities allocated to the PE; and a multiply accumulate unit (MAC) for evaluating the subset of inequalities with respect to the state based on multiplication of coefficients of each inequality in the subset with elements of the state.
11. The controller of claim 10, wherein the memory includes a set of unique inequalities, wherein each unique inequality is transformed into a strict inequality.
12. The controller of claim 10, wherein the Boolean function includes a negation result of the strict inequality.
13. The controller of claim 8, wherein the RGL unit determines each bit of an address in a memory storing the gain as a Boolean combination of products of subsets of elements of the output vector.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1)
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
(12)
(13)
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
(14)
(15) The system can be any device that is controlled by manipulating control signals (inputs), possibly associated with physical quantities such as voltages, pressures, forces, and returns system output possibly associated with physical quantities such as currents, flows, velocities, positions. The values of the output signal are related in part to previous system output values, and in part to previous and current input values. The dependency of previous inputs and previous outputs is encoded in the system state. The operation of the system, e.g., a motion of the system, can include a sequence of output values generated by the system following the application of certain input values.
(16) The controller can be implemented in hardware or a software program executed in a processor, e.g., a microprocessor, which at fixed or variable period sampling intervals receives the system outputs and the reference operation of the system motion, and determines, using this information, the inputs for operating the system. The processor is suitably programmed to perform the steps of the methods according to various embodiments.
(17) In various embodiments of the invention, the model predictive controller 105 combines the reference signal r(t) 101 with the true or estimated state x(t) 102 of the system to form the augmented state vector θ 103. The model predictive controller determines the optimum value of the control signal u(t) 104, based on the value of augmented state vector θ 103. The estimator 108 uses the system output y(t) along with the current and past values of the control signal u(t) to estimate the current state of the system.
(18) In some systems the state is completely determined by the plant outputs y(t), in which case the estimator may simply form the state estimate directly as
x(t)=My(t)
where M is an appropriate square matrix of full rank. However, it is more common that some or all of the system state variables are unobservable, in which case the state estimate may be formulated in a number of different ways. For example for a linear system
x(t+1)=Ax(t)+Bu(t)
y(t)=Cx(t)+Du(t)
where A, B, C, D are matrices of appropriate size, an estimator can be made as
z(t+1)=Az(t)+Bu(t)−L(y(t)−Cz(t)−Du(t))
{circumflex over (x)}(t)=C.sub.zz(t)+C.sub.uu(t)+C.sub.yy(t)
where L, C.sub.z, C.sub.u, C.sub.y are appropriately built matrices.
(19) Model Predictive Control (MPC) is a control algorithm that reads the augmented state or state estimate of a dynamical system and solves a finite horizon optimal control problem formulated over a future horizon from the system dynamics, system constraints, and objective cost function. Of the optimal sequence of inputs over the future horizon the first component is applied to the system, and a new optimal control problem is solved over a shifted future horizon when the next augmented state is read.
(20) The solution at every control cycle of the optimal control problem may require a significant amount of computation and hence the MPC algorithm cannot be executed in systems where the controller is required to run very fast (e.g., once every few microseconds) or that have limited computational capabilities. An alternative is to compute the parametric solution of the MPC optimal control problem as a function of the augmented state. For linear systems the explicit solution of the MPC optimal control problem results in a piecewise affine function
(21)
(22)
(23) The state space 200 is divided into a polyhedral partition with five regions P.sub.1 203, P.sub.2 204, P.sub.3 205, P.sub.4 206, and P.sub.5 207. Each controller region P.sub.i has a set of inequalities that define its boundaries. These inequalities can be written in matrix form as
H.sub.iθ−k.sub.i≦0,
T.sub.1≡[H.sub.i−k.sub.1],
wherein i represents the region number, Hand k are coefficients of the inequality, T.sub.i is auxiliary matrix defined for convenience.
(24) In the diagram of
(25)
(26) Furthermore, the entire system of inequalities for region P.sub.1 is
(27)
(28) Each region P.sub.i has a set of gains and offsets (C.sub.i,E.sub.i) associated with it, such that region P.sub.i 203 is associated with (C.sub.1,E.sub.1) 220, region P.sub.2 204 is associated with (C.sub.2,E.sub.2), and so on.
(29)
(30) If at least one inequality is not true, then the index i is incremented 306 by one and checked to make sure it is less than or equal to N 307, the total number of regions in the controller. The controller continues evaluating the inequalities for each region sequentially until a region is found where all of the inequalities evaluate to true or all of the regions have been searched. When i exceeds N all of the regions have been searched without finding an active region. In this case some special error action 308 is taken. The error action could include reprocessing the previous control output, reverting to some default gains C.sub.d and E.sub.d for the controller output computation, or some other action that meets the requirements of the system.
(31) Evaluating the inequalities and determining active regions is known as region searching. Most of the computation performed by EMPC controllers is dedicated to the region searching task. Therefore, to improve the performance of the EMPC controller, it is desirable to improve the performance of the region searching task.
(32) Some embodiments of the invention are based on a realization that the region searching task includes a large number of repeated operations. These operations also exhibit a very high degree of atomicity, meaning that they do not share information, and thus can be performed in parallel to reduce the time of computation.
(33)
(34) For example, each inequality can be evaluated by taking the scalar product of its coefficients and the augmented system state θ. The scalar product of two vectors, also known as the dot “.” product, is calculated by multiplying corresponding elements together and then summing the products, as in the formula
a.Math.b=Σ.sub.i=1.sup.na.sub.ib.sub.i.
(35) Some embodiments are based on another realization that this formula is also the formula for a Multiply Accumulate (MAC) operation, which is one of the fundamental building blocks of many digital signal processors (DSP). Because of its fundamental nature, many high performance circuit implementations of the MAC operation are known. Of particular advantage in some embodiments of the invention is that the hardware accelerated MAC blocks are included in field programmable gate arrays (FPGAs), such as the DSP48 block present in many Xilinx® FPGAs, and MAC libraries available for many ASICs vendors. Therefore, some embodiments of the invention exploit parallelism in the EMPC by evaluating the inequalities 340 on a plurality of MAC units.
(36) The parallel solution to the region search problem is equivalent to taking all of the inequality matrices from each region and forming a new matrix D that contains all of the inequality coefficients as follows
(37)
where N is the total number of controller regions. Instead of evaluating
H.sub.1θ−k.sub.i≦0
for each region sequentially, some embodiments determine system matrix D as
(38)
which evaluates the inequalities in the system in a single step. The highest degree of parallelism is achieved when each MAC unit evaluates a single row of D, corresponding to a single inequality. However, in most cases the system matrix D has more rows that there are MAC units in the controller. In this case, the system matrix D is partitioned into M sub-matrices, where M is the number of MAC units used in the controller circuit. If L is the number of rows in D, then each MAC unit processes a sub-matrix of D with L/M rows. After the inequalities are evaluated, the set of Boolean results is, e.g., a vector o with L elements where each element i indicates whether the corresponding row of D evaluated true, in which case o(i)=1, or false, in which case o(i)=0.
(39) Evaluating the inequalities in parallel can improve performance of the region searching tasks, and, thus, the performance of the EMPC. However, such an evaluation also presents some challenges that are not present in standard serial implementations of the EMPC. In contrast with the sequential evaluation of the regions, some embodiments determine the active region only after all elements in the set of Boolean results are evaluated. In order to determine which region is active from the results in the vector o, the mapping between particular values of o and the corresponding active region is needed.
(40) One embodiment address this problem by recording correspondence between elements of the set of Boolean results, e.g., value of vector o, and regions during the process of creating the D matrix. Then, a lookup table is built that stores which region is active for each possible value of o. However, in some systems, the number of inequalities L is on the order of 10.sup.2-10.sup.4, and require a lookup table with between 2.sup.10.sup.
(41) Accordingly, some embodiments of the invention determine 320 a region 325 that includes the state by applying a Boolean function to elements of the set of Boolean results corresponding to inequalities forming boundaries of the region. Next, a control 335 for controlling the system is determined based on the state 102 and a gain associated with the region 325.
(42) The Boolean functions have the advantage of being efficient and easy to implement in both FPGAs and ASICs. Each function uses Boolean operations, such as AND and NOT, on specific elements of the result vector o, to determine which region is active. The specific elements of the vector o that each function operates on correspond to the inequalities that form the boundaries of that region. The output of each function is a single bit that is set to one when the region is active and, otherwise, is set to zero. By utilizing a set of unrelated Boolean functions, each operating on a small subset of the vector o, the circuit complexity is reduced.
(43) Some embodiments of the invention also consider latency of the circuitry of the controller. The MAC units in FPGAs and the MAC cells in ASIC libraries are optimized for low latency. For example, the DSP48 blocks in the current generation of Xilinx® FPGAs can operate at clock frequencies in excess of 600 MHz. To achieve maximum efficiency, one goal of some embodiments is for the complete circuit to operate as close as possible to the upper frequency limit set by the MAC blocks. The simplicity of the Boolean function representation of controller regions results in low latency implementation, which ultimately improves performance in the overall controller circuit.
(44) For example, the system matrix D for the state space 200 of example of
D=[a b c d e f g h i j k l m n o p q].sup.T.
(45) The result of evaluating each inequality is stored in the vector o sequentially such that o.sub.1 includes the Boolean result of evaluating inequality a 208 and o.sub.L includes the Boolean result of evaluating inequality q 211. In order for a region to be active, all of its inequalities must evaluate to true, which means that all of the corresponding elements of o are one. Therefore, the Boolean function representing any controller region is the logical AND of all of the elements of o that correspond to inequalities forming boundaries of that region. For region P.sub.1 203, those elements are 1, 2, and 3, yielding the following Boolean function
F.sub.1=o.sub.1 AND o.sub.2 AND o.sub.3.
(46) In Boolean logic, the AND function is equivalent to multiplication, and the OR function is equivalent to addition. Thus, F.sub.1 can be written as
(47) F.sub.1=o.sub.1.Math.o.sub.2.Math.o.sub.3 or F.sub.1=o.sub.1o.sub.2o.sub.3. Thus, in one embodiment, the Boolean functions for the state space 200 include
F.sub.1=abc=o.sub.1o.sub.2o.sub.3;
F.sub.2=def=o.sub.4o.sub.5o.sub.6;
F.sub.3=hig=o.sub.7o.sub.8o.sub.9;
F.sub.4=jklm=o.sub.10o.sub.11o.sub.12o.sub.13;
F.sub.5=nopq=o.sub.14o.sub.15o.sub.16o.sub.17.
(48) Accordingly, in some embodiments the set of Boolean results is a binary vector o, wherein each element of the binary vector equals one if a Boolean result of a corresponding inequality is true, and, otherwise, equals zero. The Boolean function is a product of the combinations of elements, such that an element of the output vector corresponding to the region is one, and other elements of the output vector are zero.
(49) Some embodiments store the output of the Boolean functions F.sub.i in an output vector q which has N elements, one for each region, such that
q≡[F.sub.1,F.sub.2, . . . F.sub.N].
(50) Some embodiments of the invention use the output vector q to determine address in a memory of the controller storing control coefficients associated with the region, e.g., set of gains C.sub.i and E.sub.i, to determine the control output u for controlling the system. For example, one embodiment determines each bit of an address in a memory storing the gains as a Boolean combination of products of subsets of elements of the output vector q.
(51) For example, in one embodiment of the invention the gain coefficients are stored in a linearly addressable memory. In general, C is matrix and E is a vector, which means that more than one memory address is required to store the gain coefficients for a single region. For example, in the EMPC for the state space 200 of
(52) In one representation of the EMPC controller the boundaries between regions belong to all regions that share that boundary. This is a natural result of the fact that all inequalities are formulated as non-strict inequalities, i.e., “less than or equal to.” In this embodiment, the output of the system can be the same along that boundary regardless of which of the bordering region's gains are used to calculate the system output.
(53) For example, referring again to
u=C.sub.3θ+E.sub.3=C.sub.4θ+E.sub.4=C.sub.5θ+E.sub.5,
wherein u is a control outputted by the EMPC.
(54) In software implementations of MPC that solve the region search problem by checking each region sequentially, the fact that the state can belong to multiple regions is of little consequence. The first region in which all of the inequalities evaluate to true is selected as the active region and the gains of that region are used in the controller output calculation.
(55) In some embodiments, however, multiple regions can be active simultaneously. Because regions are searched in parallel, the regions that include the current state can be identified as active by their respective Boolean function F.sub.i. For example, if the state falls on the point (2,2) 213, P.sub.3 205, P.sub.4 206, and P.sub.5 207 can all be active regions. It is necessary to select one region from those three regions so that the gain coefficients can be addressed in the linear memory in which they are stored.
(56) To resolve this issue, some embodiments of the invention use a modified priority encoding scheme to select one region from several active ones and then generate an address that is the offset of the active region's gain coefficients in the linear gain memory.
(57)
(58) The x's in the table indicate “don't care” bits used to prioritize the inputs. The input bits q are the elements of the output vector q having the outputs of the Boolean functions representing each region. In this table, q.sub.1 401 has the highest priority and each successive bit has lower priority than the preceding bit. When q.sub.1 is ‘1’ the output s is forced to 0 . . . 000, regardless of the state of the other inputs. When q.sub.2 405 is ‘1’ the output s is forced to 0 . . . 001, regardless of the state of the other inputs except for q.sub.1, which must be ‘0’. This continues through the q bits until q.sub.N, which can be overridden by any of the previous bits. This encoding scheme provides a mechanism for selecting one region from multiple active regions.
(59) The Boolean functions A.sub.1 406 through A.sub.B 407 are the generator functions for each bit of the output address vector s determining each bit of an address in the memory storing the gain as a Boolean combination of products of subsets of elements of the output vector. Each generator function A.sub.i corresponds to a column s.sub.i in the table. Every ‘1’ in an s.sub.i column corresponds to a product term in the generator function. The horizontal bar above some terms indicates Boolean negation. Multiple product terms are combined using the Boolean OR function, indicated by the + sign.
(60)
B=┌log.sub.2(M)┐.
(61) In this example, the number of bits B is four, and thus four bits are needed to address the gain memory.
(62) The offsets of gain coefficients of each region are 0 (0b0000) 410, 3 (0b0011) 411, 6 (0b0110) 412, 9 (0b1001) 413, and 12 (0b1100) 414. This is a difference between the normal priority encoder and the implementation used in this embodiment. A normal priority encoder produces a fully encoded output with the minimum number of output bits s required to enumerate the inputs. In this embodiment of the invention, the inputs are mapped to a non-minimum encoding that is designed to suit the needs of the particular control problem at hand.
(63) In this table, the region P.sub.1 203, corresponding to g.sub.1408 is given the highest priority. The product term corresponding to q.sub.1 is simply q.sub.1 because its highest priority. The region P.sub.2 204, corresponding to q.sub.2 415 has the second highest priority, and is represented by the product term q.sub.2
(64) Returning to the example of
A.sub.4=1
A.sub.3=1
A.sub.2=1
A.sub.1=1
(65) Thus, the vector s, composed of the outputs of the generator functions A1 418 through A.sub.4 419, does indeed produce the value 6 (0b0110) as desired.
(66) Although this technique does resolve the issue of having multiple active regions, it is limited to relatively small EMPC problems. Most of the generator functions A.sub.1 through A.sub.B include a product term that has N elements, such as 417 and 420. As the number of regions grows the number of elements in that term grows too. In general, the latency of the circuit that implements these functions increases as the number of terms grows. It is not uncommon for an EMPC controller to have 1000 or more regions, which would result in several product terms with 1000 or more elements. This, in turn, would yield a physical circuit with high latency, which is undesirable.
(67) Therefore, another embodiment of the present invention alters the formulation of the original EMPC controller specification such that no more than one region may be active simultaneously. By doing so, the need for priority is eliminated and the latency of the address generator circuits is decoupled from the number of regions in the controller. Furthermore, the number of operations required to complete the region search task is greatly reduced and overall controller performance is improved.
(68)
(69) Accordingly, the embodiment transforms 510 at least some inequalities in the set of inequalities 340 to produce a set of unique inequalities 515. For example, the embodiment can transform a first inequality in the set inequalities into a negation of a Boolean result of a second inequality in the set inequalities, wherein the first and the second inequalities represent opposite subspaces from a facet in the state space.
(70)
(71) The transformed system matrix D* is now D*=[a b c e h i j m].sup.T. The Boolean functions for each region shown in terms of both the inequalities and the elements of the result vector o are
F.sub.1abc=o.sub.1o.sub.2o.sub.3
F.sub.2
F.sub.3
F.sub.4jīhm=o.sub.7
F.sub.5a
(72) The negation of the result of evaluating an inequality is a taking of the logical opposite of that result. The logical opposite of the ≦ operation is the > operation. Therefore, by introducing negation, the two or more regions cannot be active simultaneously. As an example, the point (2,2) 507 in
(73) In the standard EMPC controller formulation, all of the inequalities are non-strict inequalities that use the ≦ operator. Two operations are required to perform this comparison. First, the right side of the equation is subtracted from the left side of the equation. If the result of the subtraction is negative then the less than part of the comparison is true. This condition can be detected quite easily by inspecting the sign bit of the result. In order to determine if the left side of the inequality is equal to the right side, an OR operator is applied to all of the bits of the subtraction result. If the result of the OR operation is zero, then the left and right hand sides of the inequality are equal. Depending on the circuit architecture of the MAC unit, implementing the equal part of the comparison can result in a circuit with higher latency, which in turn limits performance of the overall controller circuit.
(74) Accordingly, some embodiments of the invention transform 520 at least some non-strict inequalities into strict inequalities. For example, if the second inequality, in the above-example, is a non-strict inequality, some embodiments transform the second inequality into a strict inequality.
(75) In one embodiment of the invention, the standard representation of the EMPC controller is reformulated such that all of the inequalities in the system take the form
H.sub.iθ<k.sub.i.
(76) This embodiment is based on the realization that because the boundaries belong to all neighboring regions, the state can be assigned to any one of those regions. In this way, points in the state space that fall on the line
H.sub.iθ=k.sub.i,
are always assigned to the region using the negated version of the inequality.
(77) For example, suppose r≡H.sub.iθ≦k.sub.i. This embodiment solves a modified version of r,
r′≡H.sub.iθ<k.sub.i.
(78) Regions that include the term r′ in their Boolean function F.sub.i are not active for points in the state space that fall on the line H.sub.iθ=k.sub.1. However, regions that include the term r′ are active when the state is on that line. Thus, this embodiment eliminates the equality check, which enables a simpler and more efficient circuit implementation, while still preventing multiple regions from being active simultaneously.
(79) Digital Circuit Architecture
(80) It is a further object of some embodiments of the invention to design a general digital circuit that can be applied to a wide range of EMPC problem sizes and target devices. To this end, the number of MAC units used in any particular implementation of a controller can be selected such that the resulting circuit meets some design goal. Often the design goal is that the resulting circuit does not use more MAC units than are available in a particular FPGA or can fit on a particular ASIC. However, other design goals, such as power consumption or cost, can also be considered.
(81) In order to satisfy the goals of performance and scalability, some embodiments start with a general description of a digital circuit in a Hardware Description Language (HDL) and automatically transform the HDL into a description of an MPC controller for a specific problem using software tools. HDLs are programming languages for designing circuits. These descriptions can then be used to design a specific FPGA or ASIC. The synthesis process is performed using a commercial synthesis tool such as Xilinx® Integrated Software Environment (ISE) or a Synopsys Design Compiler®.
(82)
(83)
(84) A region identification and gain lookup logic (RGL) unit 705 processes the set of Boolean results to determine the operating region of the controller. Based on the active region, the RGL unit generates a gain address signal s 706. The output processing (OP) unit 707 uses the gain address signal to select the correct gain coefficients for use in calculating the controller output u 0708. Intermediate start signals 709 and 710 control the flow of data between the IP, RGL, and OP units. The done signal 711 indicates that the controller has finished the output calculation and the controller output can be sent to the system.
(85)
(86) The IP also contains control logic unit 807 that generates an address signal 808 and a set of control signals 809 to control the operation of the PEs in the IP. The control logic unit can also allocate subsets of inequalities among different PEs. For example, for a controller that includes L inequalities, the inequalities are allocated among the PEs such that each PE processes
(87)
inequalities. Each PE generates one output for each inequality that the PE processes. For example, a PE.sub.1 generates output signals o.sub.1 810 through o.sub.L/M 811, intermediate Pes, PE.sub.i, generate output signals o.sub.(M−1)L/M+1) 812 through o.sub.iL/M 813, and the last PE, PE.sub.M, generates output signals o.sub.(M−1)L/M+1 814 through o.sub.L815. Each individual output signal is then aggregated into the output vector o 816 which has L elements. When the processing operation is complete the control logic asserts the done signal 817.
(88)
(89)
(90)
(91) The above-described embodiments of the present invention can be implemented in any of numerous ways. For example, the embodiments may be implemented using hardware, software or a combination thereof. When implemented in software, the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers. Such processors may be implemented as integrated circuits, with one or more processors in an integrated circuit component. Though, a processor may be implemented using circuitry in any suitable format.
(92) Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, minicomputer, or a tablet computer. Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
(93) Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools.
(94) Also, the embodiments of the invention may be embodied as a method, of which an example has been provided. The steps performed as part of the method may be ordered in any suitable way. Accordingly, embodiments may be constructed in which acts are performed in an order different than illustrated, which may include performing some acts simultaneously, even though shown as sequential acts in illustrative embodiments.
(95) Although the invention has been described by way of examples of preferred embodiments, it is to be understood that various other adaptations and modifications can be made within the spirit and scope of the invention. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the invention.