The present invention is directed generally toward optimizing multiple objectives, including but not limited to those which occur in integrated circuit design.
Many design problems amount to an exercise in balancing multiple objectives, or what is known as a multi-objective optimization problem. For example, it is often desirable to simultaneously minimize each of a plurality of objectives, while satisfying various constraint functions. Moreover, there are often conflicts between the different objectives such that minimizing one causes another to increase in value, thereby resulting in tradeoffs between objectives. Having a design methodology that can explore tradeoffs would significantly aid fast design convergence at any abstraction level, so as to arrive at a design point that truly is the “sweet spot.”
For example, in the field of VLSI (very large scale integration) integrated circuit design, at the highest abstraction level of implementing a full chip, there is typically a tight and difficult to estimate tradeoff between power and speed. If the speed of an SRAM bitcell is increased, for example, more leakage power is typically consumed as a tradeoff. There are often several constraints on this design problem; e.g., technology capability, market forces, the design methodology, chip area, the system around the chip and design schedule. Many of these constraints could, themselves, be objectives: ideally a designer would also like to analyze the power-performance tradeoffs with chip area, the design schedule and technology costs.
Typically, designers would like to explore the tradeoff between the objectives to pick the solution that best fits their design requirements. One reason for this is that the design goals are not fully determined and an exploration of the tradeoffs is necessary to determine design capability, which in turn may be used to guide the design goals. This is often the case for SRAM bitcell design, since the bitcell is often designed during the early phases of technology development. At this time, the technology, the models and the design specifications coming from the array design are all in flux, and it is very difficult to have all requirements fixed. Knowledge of the full tradeoff between the objectives lets the designer choose a design that meets current requirements and is flexible to adapt at low cost as needs change.
An illustrative embodiment of the present invention includes a method of optimizing a plurality of objectives includes the steps of initializing a set of simplices; selecting a simplex from the set of simplices; computing one or more weights based at least in part on the selected simplex; and generating a point on a tradeoff surface by utilizing the one or more weights in a weighted-sum optimization.
Another illustrative embodiment of the present invention includes a method for designing an integrated circuit. The method includes a step of optimizing a plurality of design objectives. This optimizing step includes the steps of initializing a set of simplices, selecting a simplex from the set of simplices, computing one or more weights based at least in part on the selected simplex, and generating a point on a tradeoff surface by utilizing the one or more weights in a weighted-sum optimization. The method also includes a step of designing the integrated circuit based at least in part on the optimized plurality of design objectives.
These and other objects, features, and advantages of the present invention will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.
A typical multi-objective optimization problem may be expressed as follows:
where X is the domain of search and T denotes a transpose operation. A goal is to simultaneously minimize each of the d objectives, thereby minimizing objective function f(x), while satisfying the vectors of constraint functions g(x) and h(x). Let F be the space of objective values {ƒi}. Then any set of objective values f={ƒ1, ƒ2, . . . , ƒd} is a vector in this space. Let F be the feasible region defined as
F={f(x):g(x)≦0,h(x)=0,xεX}. (2)
ƒ′i≦ƒi,∀iε{1, . . . ,d} and ∃jε{1, . . . ,d}:ƒ′j<ƒj; (3)
that is, there is no other point in F that has a smaller or equal value for all objectives than f Although the illustrative embodiments described herein assume that F is closed and simply connected, F can be of any form.
f
U={ƒ11I, . . . ,ƒddI},
f
N={max(ƒ11I,ƒ21I, . . . ,ƒd1I), . . . ,max(ƒ1dI, . . . ,ƒddI)}, (4)
where ƒijI is the j-th component of fiI.
There are several techniques for solving optimization problems such as (1). For example, various methods, such as the Normal-Boundary Intersection method and the Normal Constraint method, use a sequence of single-objective optimization runs to sample the tradeoff surface, and use some additional constraints to guide each run at a desired location on the surface. However, the additional constraints required by these techniques can make the optimization problem more difficult, resulting in convergence to local minima or longer run times for each optimization run.
As another example, an evolutionary algorithm could be used with solution fitness defined by its non-domination by other solutions. Examples of such techniques include encoding the notion of Pareto optimality into a gene goodness function, the non-denominated sorting genetic algorithm (NSGA) method, or the strength Pareto evolutionary algorithm (SPEA) method. However, these evolutionary algorithms tend to have very high computational costs associated therewith because of the lack of a strong search direction and the need for maintaining large populations. Often, several thousand candidates need to be tried before solutions converge.
Another approach to solving (1) above is to optimize convex-weighted sums of the objectives. To do this, the multi-objective optimization problem is converted into a single objective problem by placing acceptable thresholds on all but one objective, thereby converting these objectives into constraints. The new weighted objective is defined as:
ƒ1α=wTf=α1ƒ1+α2ƒ2+ . . . +(1−Σi=1d−1αi)ƒd (5)
0≦αi≦1 for all i, and Σi=1d−1αi<=1. (6)
w is a strictly non-negative, non-trivial vector, and α={α1, . . . , αd−1} is the vector of weights. The optimization problem can now be written as:
The weights αi allow us to relatively prioritize the objectives for the optimization. For example, if α1=α2=0.5 and all other αi=0, the optimization will only try to minimize the objectives ƒ1 and ƒ2 and ignore the others.
One method of sampling the Pareto surface ∂F uniformly is to sweep the weights uniformly while satisfying (6), and run a single objective optimization for each resulting combination of weights. For a given sweep stepsize, dα, the combinations can be generated as:
α1=0:dα:1
α2=0:dα:(1−α1)
. . . αi=0:dα:(1−Σj=1i−1αj)(for i<d (8)
The question of where a particular choice of weights put us on ∂F can be answered by deriving a direct relationship between the weights α and the partial derivatives of the Pareto front ∂F. In the illustrative embodiments described herein, it is assumed that the origin has been translated to the utopia point fU shown in
Any solution to the problem (7) should satisfy the following theorem:
Let ∂F be continuously differentiable, and let fα* be the global solution to the problem (7). Then
The proof of this theorem is as follows: f is a vector in F and ƒ1α=wTf is the projection of f on the direction vector w defined by the choice of weights α={α1, . . . , αd−1}. Hence, (7) minimizes this projection.
To express this idea in a more convenient way, the axes in this system can be rotated such that the rotated ƒ1 axis is aligned with the vector w, and in the same direction. FIG. 2A shows a system prior to rotation and
Now, any solution fα*, such as that shown in
The feasible region F, and hence the Pareto surface ∂F, lies in the positive orthant of the original coordinate system, and so does w as per (6). Consequently, in the rotated system, ∂F and the feasible region lies in the positive half plane defined by ƒiθ>0. If ƒiθ is minimized while staying feasible, the solution point must then lie on ∂F. This is because for any point fθ={ƒ1θ, . . . , ƒdθ} in F, that is not in ∂F, one can find a neighboring point fθ−{δƒ, 0, . . . , 0} that is feasible and has a smaller value for the ƒiθ coordinate, until we reach ∂F. This proves claim 1 of the theorem.
Given this, for (7) one can equivalently search only on the ∂F manifold and drop all constraints in (7), since the solution for any choice of α as per (6) will lie on it. The resulting formulation is
fα* is a solution of (7) for some α and can be written in the rotated system as fθ*={ƒ1θ*, . . . , ƒdθ*}, which is also a solution of (9) and minimizes ƒ1θ to the value ƒ1θ* Since fθ* lies on ∂F and ∂F is continuously differentiable, ∂F can be written in the neighborhood of fθ* in the following explicit analytical form:
ƒ1θ=h(ƒ2θ, . . . ,ƒdθ). (10)
An example of h( ) is a Taylor expansion of ƒ1θ restricted to ∂F, in terms of {ƒ2θ, . . . , ƒdθ} around ƒ1θ*. In this neighborhood, (9) can be simplified to the following unconstrained form:
From the Karush-Kuhn-Tucker (KKT) necessary condition, the partial derivatives of ƒ1θ at the solution ƒ1θ* must be zero:
∇ƒ1θ(fθ*)=0. (12)
Also, the plane tangent to ∂F at ƒ1θ* is given by
P:[−1∇ƒ1θ(fθ*)T]fθ=[−1∇ƒ1θ(fθ*)T]fθ*. (13)
Using (12) in 3 this plane can be written as
P:ƒ
1
θ=ƒ1θ*, (14)
which is also normal to the ƒ1θ axis, and hence, normal to the w vector in the original coordinate system. This proves part 2 of the theorem.
Now, assume that this tangent plane, which is tangent at the global optimum of (7), intersects ∂F at some other point ƒθ′ where it is not tangent to ∂F. Then, in the neighborhood of ƒθ′ one can assume an explicit form of ∂F similar to (10), and write the optimization problem as (11). The plane P has all partial derivatives equal to zero, as per (14) and if it is not tangent to ∂F at ƒθ′, then
∇ƒ1θ(fθ′)≠0. (15)
This violates the KKT necessary condition at fθ′, and it follows that there is a better solution possible. Since, fθ′ lies on the plane P: ƒ1θ=ƒ1θ*, this better solution will have a smaller value of ƒ1θ. Hence, there is a contradiction with the prior assumption that fθ* is the global optimum. This proves part 3.
This theorem can then be used to derive a relation between the optimization weights {α1, . . . , αd−1} and the derivatives of ∂P. This will indicate exactly where on ∂F the optimization (7) lands.
Corollary Let ∂F be continuously differentiable and let f1α* be a solution to problem (7). Then
This corollary can be proved as follows: the theorem states that the vector w={α1, . . . , αd−1, 1−Σj=1d−1} is normal to ∂F at the solution point fα*. ∂F can be written at any point that lies on it, in the explicit form
ƒd=hd(ƒ1, . . . ,ƒd−1). (17)
Then the inward pointing normal vector to ∂F at that point is
which is parallel to w at fα*. If w is normalized to match its d-th coordinate to the d-th coordinate value of n (i.e., 1), the result is (16).
These observations explain the problem with the standard approach of uniformly sweeping the weights αi in (7). The choice of the vector α relates to the partial derivatives of the Pareto front ∂F and not the position on ∂F. Hence, a uniform spread in the weights will ensure some systematic choice of the partial derivatives that are sampled on ∂F, but the resulting points on ∂F will depend completely on the distribution of these derivatives across it. Consequently, the spread of the points can vary dramatically from one form of ∂F to another and no spatial uniformity is guaranteed.
As can be seen in
An illustrative embodiment of the present invention allows one to sample the weights with the goal of generating uniformly distributed points on ∂F irrespective of the distribution of its partial derivatives and without enforcing additional constraints on the original optimization problem. Rather, the weights are generated adaptively by exploiting the relationship between the objective weights and the partial derivatives of the tradeoff surface. In a sense, this illustrative embodiment performs a Monte Carlo analysis on ∂F following a uniform distribution defined over ∂F.
Such an approximation of a convex surface falls under the general class of polyhedral approximations, as described in R. V. Efremov et al, “Properties of a Method for Polyhedral Approximation of the Feasible Criterion Set in Convex Multiobjective Problems,” Ann. Open. Res., 166, 2009, incorporated by reference herein. Each vertex is a point on ∂F that has been generated using some α in (7), and thus all simplex vertices lie on ∂F. In an illustrative embodiment, this model of ∂F is used to define the next desired sample and the corresponding values of α. New points can then be added incrementally. Because the partial derivatives of a solution point for any given set of weights are known, these known partial derivatives can be used to compute the next set of weights.
In step 710, individual minima {fiI}i=1d are generated by minimizing one objective at a time and ignoring the others. Once {fiI}i=1d are generated, the objective functions are normalized to [0,1] in step 720, such that the utopia point is now the origin and the nadir point is at the far corner of the unit cube. This may involve the use of the transformation:
The single simplex formed by connecting the individual minima together then lies within this unit cube, with the vertices lying on the boundary of the unit cube.
In step 730, one simplex S is selected from Z. Preferably, simplex S is selected from Z in a manner which favors sparsely sampled regions of the Pareto front over densely sampled regions. For example, one could use the volume of each simplex as a measure of the sparsity of its vertices. Then, the distribution of simplex volumes is used to guide the choice of simplex for the next iteration.
In one embodiment, a deterministic method could be utilized in which the largest simplex is picked. Alternatively or additionally, a probabilistic method could be used in which each member of Z is assigned a probability that is proportional to its (d−1)-dimensional volume (surface area of triangle for d=3), S is then picked randomly from the categorical probability distribution assigned to Z. Such a technique would tend to pick larger simplices which correspond to sparsely sampled regions of the Pareto front.
An embodiment may include the computation of the volume of any newly-created simplices that are created, as shown in
Note that yi are (d−1)-dimensional vectors, whereas simplex S is defined using d-dimensional vectors fν, νεV(S). Thus, to use (22) it is necessary to define S in a (d−1)-dimensional coordinate system.
To perform this definition, one must first find a (d−1)-dimensional orthonormal basis for the hyperplane in which S lies with the origin at one vertex of S. Then one can represent all vertices using this (d−1)-dimensional basis. Let {f1, . . . , fd} be the set of vertices V(S) represented in the d-dimensional space F. The simplex is translated such that f1 is at the origin and the vertices are then given by
{0,(f2−f1), . . . ,(fd−f1)} (22)
The following matrix can then be defined
ΔF=[(f2−f1) . . . (fd−f1)] (23)
The columns of this matrix form a basis for the hyperplane containing S. The thin QR decomposition of this d×(d−1) matrix gives us an orthonormal basis for this hyperplane:
ΔF=QR, (24)
where the columns of Q form the orthonormal basis. Q can be computed using Gram-Schmidt orthonormalization. Thin QR decomposition and Gram-Schmidt orthonormalization are both described in G. H. Golub and C. F. Van Loan, “Matrix Computations,” JHU Press, 3 ed., 1996, incorporated by reference herein. Next, the simplex vertices (22) are projected onto this basis set to obtain a (d−1)-dimensional representation of S:
Y=Q
T[0ΔF]=[0QTΔF], (25)
where the i-th column of Y is the i-th vertex of S in the (d−1)-dimensional space defined by ΔF and, equivalently Q. Plugging this into (21), one derives
In step 740, an appropriate set of weights α is selected to run a new optimization. This new set of weights is selected as a function of the corners of the selected simplex. Ideally, α is selected such that the resulting solution is centrally positioned on ∂F with respect to the vertices of the simplex, so as to maximize the uniformity of the points on ∂F. Because we do not have a direct relation between the objective values of any Pareto point and the weights, we use a heuristic by exploiting the relationship between the partial derivatives of ∂F and the weights. For simplicity, any partial derivative
will be notated herein as simply ∂i. Let F− be the (d−1)-dimensional space defined by {ƒ1, . . . , ƒd−1} and let any vector in this space be denoted with a − superscript, as f−.
As shown in
s=[∂
1 . . . ∂d−1]T=Af−+b,
s.t.Af
ν
−
+b=s
ν
,∀νεV(S), (27)
where V(S) is the set of the vertices of S, A and b are the matrix and vector defining the linear functions, fν− is some vertex of S− and sν is the vector s at that vertex. Note that, since vertex ν was generated using some known α in (7), the vector sν can be derived using (16). Equation (27) says that the linear functions are simply interpolations from the vertices of the simplex S. The new desired point on ∂F is the projection of the centroid of S−on to ∂F. This desired point would have the desirable property of being equidistant from all simplex vertices at least in F−.
In one technique, referred to herein as the centroid method, the weights are computed based on the centroid of partial derivatives of the corners. Let fc− denote the centroid of S−. Using the model of (28), the partial derivatives of ∂F at this desired point are estimated as
which is the just the centroid of the simplex defined by V(S) in the s space. From this set of partial derivatives, a set of optimization weights is computed by manipulating (16) and (28):
This set of weights can then be used to drive the next optimization run. Note that if the parial derivative model (27) is accurate, the optimization will land on the desired point on ∂F. In the general case, this model serves as an approximate guide, by trying to exploit currently available information about ∂F
Alternatively or in addition, one could compute the gradients of the plane passing through the simplex corners then compute the weights from these gradients using (16). That is, the linear model can be discarded and instead one could simply use the centroid (mean) of the αν vectors, for all νεV(S). It is important to note that the term
found on the left-hand side of (16), could be equivalent to either the centroid of the partial derivatives of the corners of the simplex or the gradients of the plane passing through the corners of the simplex.
For example, there are certain regions where the linear model does not fit. These are near the edges and corners of ∂F, where one or more partial derivatives rapidly go to −∞. This happens whenever any of the optimization objectives in (7) has a weight very close to 0. To see this mathematically, consider the case where ƒd has a weight of 0; i.e., Σi=1d−1αi=1. This would happen, for instance when one optimizes for the i-th individual minimum fiI by setting αi=1. If the simplex S has a vertex ν with such a choice of α, one will obtain sν={−∞, . . . , −∞}. The partial derivatives across this simplex could not then be interpolated using a linear model. The linear interpolation model (plane method) of αν can be used in terms of f− across such simplices.
Thus, a hybrid method could be utilized in which the plane method is used when simplex plane gradients are all negative, otherwise the centroid method is used. Of course, any combination of the plane method and/or centroid method, or other methods, may be utilized in conjunction with illustrative embodiments of the present invention.
In step 750, a new solution fα* is computed in the manner discussed above with reference to
Z=Z−S+{simplex[(V(S)\ν)∪vertex(fα*)]:∀νεV(S)} (30)
The process then repeats at step 730 with the selection of another simplex S from Z.
SRAM bitcell design offers a potential application for tradeoff exploration methods like those described herein, though one skilled in the art will appreciate that the techniques described herein are applicable to a variety of multi-objective optimization problems. The electrical goodness of a bitcell can be measured in terms of four metrics:
1. Read current, Iread: This is the DC current through the access transistor when its internal node is at 0, the bitline is high and the wordline is active. Iread is a measure of the peripheral-independent read access speed of the cell: as the current sourced by the access transistor is higher, the bitline fall during the read will be faster. Typically, one would want this current to be as large as possible, or at least above a threshold that may be required by the array designers,
2. Leakage current, Ileak: This is the DC current that sinks to ground from an unaccessed cell (i.e., when the wordline is inactive and bitlines are high). It combines all the leakage components from the inverters and the access devices that is wasted during standby. Typically, one would want this current to be as small as possible, or at least below some acceptable threshold, which may be specified by the array designers,
3. Access disturb margin ADM: The ADM is a yield metric that measures the robustness of the cell to disturbance during access, in the presence of device mismatch resulting from manufacturing variations. This mismatch is largely from random dopant fluctuation, and can be modeled by Gaussian distributions on the device threshold voltages Vt).
To measure the ADM, the cell can be placed in a peripheral circuit that represents a relevant application space for the cell. An access (wordline pulse and bitline precharge pulse) is simulated at the expected operating frequency and the device Vts are skewed until the cell flips, to estimate the worst-case failing distance in Vt space.
To compute the ADM, the Vt Gaussians are integrated over the failure region, estimated by assuming a failing boundary that is linear and normal to this worst-case Vt vector. This integral is an estimate of the cell stability failure probability Pf, from which the ADM is computed as the equivalent number of standard deviations (σs) on a standard normal:
ADM=Φ−1(1−Pf) (31)
One typically wants the ADM to satisfy a minimum specified threshold that is set by the array size N, the desired array yield Yarr and the number of redundant bits r in the array:
4. Write access margin WRM: The WRM is similar to the ADM, except that the operation is a write operation and failure occurs when the cell Vts are skewed enough such that a write is not successful given the operating supply voltage and frequency.
One may wish to sample the tradeoff curve between Iread and Ileak under the following constraints on the yield:
ADM>5σ,WRM>5σ (33)
This will ensure that any solution on the Pareto front will satisfy the yield requirement. The design variables here are the nominal Vts of the three device types in the cell: the access nFET (PG), the pull-up pFET (PU) and the pull-down nFET (PD).
This represents a common design scenario for a bitcell where the layout parameter may be fixed early in the technology development because of area and time-to-market constraints. Later in the product development cycle, if the performance and/or leakage requirements from the cell change then it is very expensive to change device dimensions because that will require a redesign of the cell layout and, worse, reordering of several expensive masks. Tuning the Vts is, however, much cheaper since no changes to layout and masks are needed, minimizing any expensive design and technology cascade effects.
Knowledge of the yield-constrained tradeoff curve between power (Ileak) and performance (Iread) is then very useful since it gives complete information regarding the application range of the bitcell layout. To keep the Vts within some practical range, one could further impose:
V
t,xx
εV
t,xx
0+[−200 mV,+200 mV] for xx=PG,PD,PU (34)
where Vt,xx0 is some nominal starting value for each Vt. The weighted optimization problem then is
In order to test the techniques described herein, the inventors simulated a 6-T SRAM cell in an industrial 22 nm technology using a derivative free circuit optimizer based on the DFO method described in A. Conn et al, “A Derivative-Free Optimization Algorithm in Practice,” Symp. Multidisc. Anal. Optim., 1998, incorporated by reference herein. DFO is a trust-region based method that employs quadratic models for the trust region and intelligent region and model maintenance techniques to achieve robust convergence. Each optimization run used 42 circuit simulations on average.
The inventors also tested DP on a synthetic problem in three dimensions, employing MATLAB™, commercially available from Mathworks. Inc., to perform each optimization in this case:
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Such a system may include distinct software modules (for example, a partitioning module executing on a hardware processor). Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Additionally, the techniques as heretofore described can be implemented via a computer program product that can include computer useable program code that is stored in a computer readable storage medium in a data processing system, and wherein the computer useable program code was downloaded over a network from a remote data processing system. Also, in one or more embodiments of the invention, the computer program product can include computer useable program code that is stored in a computer readable storage medium in a server data processing system, and wherein the computer useable program code are downloaded over a network to a remote data processing system for use in a computer readable storage medium with the remote system.
A variety of techniques, utilizing dedicated hardware, general purpose processors, firmware, software, or a combination of the foregoing may be employed to implement the present invention or components thereof. One or more embodiments of the invention, or elements thereof, can be implemented in the form of a computer product including a computer usable medium with computer usable program code for performing the method steps indicated. Furthermore, one or more embodiments of the invention, or elements thereof, can be implemented in the form of an apparatus including a memory and at least one processor that is coupled to the memory and operative to perform exemplary method steps.
One or more embodiments can make use of software running on a general purpose computer or workstation. With reference to
Accordingly, computer software including instructions or code for performing the methodologies of the invention, as described herein, may be stored in one or more of the associated memory devices (for example, ROM, fixed or removable memory) and, when ready to be utilized, loaded in part or in whole (for example, into RAM) and executed by a CPU. Such software could include, but is not limited to, firmware, resident software, microcode, and the like.
Furthermore, the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium (for example, media 1390) providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer usable or computer readable medium can be any apparatus for use by or in connection with the instruction execution system, apparatus, or device. The medium can store program code to execute one or more method steps set forth herein.
A data processing system suitable for storing and/or executing program code can include at least one processor 1310 coupled directly or indirectly to memory elements 1320 through a system bus 1350. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
Input/output or I/O devices (including but not limited to keyboard 1340, display 1330, pointing device, and the like) can be coupled to the system either directly (such as via bus 1350) or through intervening I/O controllers (omitted for clarity).
Network adapters such as network interface 1370 may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
As used herein, including the claims, a “server” includes a physical data processing system (for example, system 1360 as shown in
Embodiments of the invention have been described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a tangible computer-readable storage medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
Furthermore, it should be noted that any of the methods described herein can include an additional step of providing a system comprising distinct software modules embodied on a tangible computer readable storage medium. The method steps can then be carried out using the distinct software modules and/or sub-modules of the system, as described above, executing on a hardware processor. Further, a computer program product can include a tangible computer-readable storage medium with code adapted to be executed to carry out one or more method steps described herein, including the provision of the system with the distinct software modules.
In any case, it should be understood that the components illustrated herein may be implemented in various forms of hardware, software, or combinations thereof; for example, application specific integrated circuit(s) (ASICs), functional circuitry, one or more appropriately programmed general purpose digital computers with associated memory, and the like. Given the teachings of the invention provided herein, one of ordinary skill in the related art will be able to contemplate other implementations of the components of the invention.
It will be appreciated and should be understood that the exemplary embodiments of the invention described above can be implemented in a number of different fashions. Given the teachings of the invention provided herein, one of ordinary skill in the related art will be able to contemplate other implementations of the invention. Indeed, although illustrative embodiments of the present invention have been described herein with reference to the accompanying drawings, it is to be understood that the invention is not limited to those precise embodiments, and that various other changes and modifications may be made by one skilled in the art without departing from the scope or spirit of the invention.