One task performed by robots is to pick objects, e.g., from a bin or shelf. Automated bin picking of arbitrary objects is a complex task, especially if those objects are highly diverse (e.g., in size, shape, and color) and are arranged irregularly. Automated bin picking has gained considerable attention from manufacturing, e-commerce order fulfillment, and warehouse automation. In order to handle a diverse range of objects, the robotic cells are often equipped with a tool changer station which allows the robot to select a new end-effector (also referred to herein as a “tool”) from a set of available end-effectors (e.g., vacuum end-effectors varying in size, antipodal end-effectors) and swap it with the current one automatically in real time. In some other cases, an ambidextrous robot is equipped with a different end-effector on each arm (see Mahler et al. [2019] for an example).
The situation above is further illustrated in
Tool changing, however, comes at a cost of cycle time: every time the robot decides to change the tool, it has to physically navigate the end-effector to the tool changing station and swap it with the newly-selected end effector. This swapping process will add to the cycle time, thereby having a negative impact on throughput (defined as the total time required to pick all objects divided by the number of objects picked). What is needed, therefore, and what embodiments of the present invention provide, are efficient algorithms that optimize (or otherwise increase) the throughput, and possibly also while minimizing the tool changing costs.
Optimizing tool selection is challenging due to many factors, such as the combinatorial space of bin configurations (in terms of diversity of the objects randomly packed in a bin), high dimensional visual sensory inputs, and uncertainties that are inherent in sensing and control. The disclosure herein formulates the problem as a stochastic decision making under uncertainty using a Markov Decision Process (MDP), and discloses a planning algorithm that leverages individual pre-trained end-effector grasp prediction models in a model predictive control (MPC) framework.
A computer system automatically selects robot end-effectors for pick-and-place applications using a model-predictive control algorithm. The system may select an end-effector to replace an existing end-effector in order to optimize (or at least increase) throughput. The system uses a predictive model of reward, where reward of each potential grasp for each end tool is parameterized by a deep neural network. The system may also use a variety of metrics to evaluate the performance of the tool-selection algorithm, and thereby improve performance of the system.
Deep learning-based grasp prediction models have become an industry standard for robotic bin-picking systems. To maximize pick success, production environments are often equipped with several end-effector tools that can be swapped on-the-fly, based on the target object. Tool-change, however, takes time. Embodiments of the present invention are directed to computer-implemented systems and methods which can automatically choose the order of grasps to perform (such as that the grasps are in an ordered sequence), and the corresponding tool-change actions, to improve system throughput.
The main challenge in planning tool change is uncertainty; we typically cannot see objects in the bin that are currently occluded. Embodiments of the present invention address this problem by modeling the problem as a Markov Decision Process (MDP), where the goal is to maximize expected throughput. Embodiments of the present invention may further pursue an approximate solution based on model predictive control, where at each time step, planning is performed based only on the currently visible objects. Special to embodiments of the present invention is use of “void zones,” which are geometrical boundaries in which an unknown object will be present, and therefore cannot be accounted for during planning. Embodiments of the present invention may solve the planning problem using integer linear programming (ILP). Some embodiments of the present invention use an approximate solution based on sparse tree search, which yields near-optimal performance at a fraction of the time required to solve the planning problem directly.
Another problem addressed by embodiments of the present invention is how to measure the performance of tool-change planning. Throughput alone can fail to capture delicate and smooth behavior. As a result, embodiments of the present invention provide a principled alternative to using throughput as the sole measure of performance. Finally, the description below demonstrates the operation of embodiments of the present invention on both synthetic and real world bin picking tasks.
Embodiments of the present invention include computer-implemented methods and systems for automatically selecting an end-effector for a robot and automatically swapping out the existing end-effector on the robot for the selected end-effector.
The description herein uses the term “Grasp Tool Selection Problem” (GTSP) to refer to the stochastic decision making problem of picking objects from a bin described above. Embodiments of the present invention formulate the GTSP as a Markov Decision Process (MDP). In practice, solving this MDP is difficult due to its large state space and difficult-to-estimate transition dynamics. To address this, embodiments of the present invention use an approximation of the problem which: (1) replaces the discounted horizon problem with a receding horizon Model Predictive Control (MPC); (2) in the inner planning loop of the MPC component, replaces the stochastic optimization with an approximate deterministic problem that does not require the complete knowledge of the true transition dynamics. This deterministic problem is an instance of integer linear programming (ILP), which can be solved, for example, using off-the-shelf software packages. However, embodiments of the present invention may instead use an approximate solution method based on a sparse tree search to improve the planning speed by orders of magnitude, with a negligible effect on the solution quality, and in a way that is fast enough to run in real time.
Embodiments of the present invention decouple grasp prediction learning from tool selection planning, such as by only requiring access to a set of pre-trained grasp prediction models for each individual end-effector. As a result, embodiments of the present invention may be applied ad hoc in production environments whenever such models are available. Experiments, on both synthetic and real-world environments, have demonstrated that embodiments of the present invention significantly improve system throughput when compared to heuristic selection methods.
Embodiments of the present invention also include a set of metrics for benchmarking tool selection algorithms, based on practical considerations relevant to the bin picking problem.
Having described various aspects of embodiments of the present invention at a high level of generality, certain embodiments of the present invention will now be described in more detail.
Consider a planar workspace , discretized into a grid of W×H points. For example, could be an image of a bin containing a plurality of objects, as in
A grasp prediction model τε: ->{ωi}i=1W×H gives a set of grasp proposals for an input image and end-effector ε. In practice, only a small subset of grasp proposals yield good grasps. Thus, without loss of generality, we denote τεk()={ωi}i=1k, limiting the model only to the k best grasps (in terms of grasp success probability). Given a set of n end-effector grasp proposal models {τi}i=1n, we define the grasp plan space Ω∪i=1n τik(), which denotes the space of all plannable grasps. We will further denote by Ωt the grasp plan space that is available at time t of the task. (For simplifying notations we interchangeably use τi to refer to an end-effectors grasp proposal model τε
Embodiments of the present invention may model the problem as a Markov Decision Process (MDP) ≡, , , defined as follows: is a set of states, where each s=Ω, ε∈ consists of the current grasp plan space and the current end-effector on the robot. (The “current” end-effector refers to the end-effector that is currently attached (also referred to as “connected”) to the robot.) We denote by sΩ and sε the individual elements of state s. The action space =Ω is the set of all plannable grasp proposals. The reward balances pick success and tool change cost. In certain embodiments, the reward is chosen as:
(s,ω)=ωρ+c1(sε≠ωε), (1)
where ωρ is the grasp success score, c<0 reflects a negative reward for tool changing, and 1(·) is the indicator function. The state transition function (st, ωt, st+1)->[0,1] gives the probability of observing the next state st+1 after executing grasp proposal ωt in state st. As a result of performing a grasp, and depending on the grasp outcome, an object is removed from the bin and some other object randomly appears at the position of the executed grasp and new graspable positions will be exposed. In certain embodiments, the optimal policy π*:->Ω is defined as:
Solving GTSP is difficult for at least the following reasons: (1) Prediction: we do not know the true state transitions, as they capture the future grasps that will be made possible after a grasp attempt, which effectively requires a prediction of objects in the bin that are not directly visible (see, e.g.,
Embodiments of the present invention may address (1) by replacing the stochastic optimization with an approximate deterministic problem that does not require the complete knowledge of the true transitions, based on the idea of void zones. Embodiments of the present invention may address (2) by replacing the infinite horizon discounted horizon problem with an online solver, which at each time step chooses the grasp that is optimal for the next several time steps; we term this part the “model predictive control” (MPC) component. Embodiments of the present invention may, for example, use either of two computational methods for solving the short horizon problem in the inner MPC loop, either accurately, based on integer linear programming, or approximately, using a simple tree search method.
Embodiments of the present invention may seek to replace the stochastic (and unknown) transitions in GTSP by deterministic dynamics, such that the solution of the deterministic problem will yield a reasonable approximation of the true optimal controller. Such embodiments are based on the idea of a void zone, which is an area surrounding a location of one or more previous grasps. Embodiments of the present invention may not allow a grasp that is in very close proximity to any previous grasp (as defined by a void zone associated with the previous grasp(s)), as movement of objects in the bin resulting from the previous grasp attempt could render a future grasp in its close vicinity impossible.
Void zones may, for example, be implemented in accordance with the following principle: As long as the objects are sufficiently small, when a grasp is attempted, the set of grasp proposals that are sufficiently distant from the attempted grasp position will remain valid in the next state.
This observation is illustrated in
Certain embodiments of the present invention define the void zone based on the Euclidean distance, as follows:
Definition 1. 1-separation Let di,j=∥ωiu−ωju∥ denote the Euclidean distance on the plane between grasp proposals ωi and ωj. A pair of grasp proposals ωi, ωj is called l-separated if di,j>l. We refer to l as the void radius and use the notation Ψl(ω) to refer to a set of grasp proposals which are l-separated from ω. Note that by definition ω ∉ Ψl(ω). The void radius l may have any value.
Based on the above definition, we can formally define deterministic dynamics in GTSP, which we will henceforth refer to as GTSP-void. At state st=Ωt, εt, taking action ωt results in a next state,
s
t+1=Ωt+1, ωtε,Ωt+1={ω|ω∈Ωt{circumflex over ( )}ω∈Ψl(ωt)}. (2)
That is, the end-effector in the next state is as chosen by ωt, and the grasp plan space is updated to exclude all grasp proposals within the void zone.
As shown in
Replanning at every step allows our method to adapt to the real transitions observed in the bin. The following description explains two methods that may be used by embodiments of the present invention to solve the inner GTSP-void optimization problem within our MPC.
For example, the GTSP-void problem may be formulated as an integer linear program (ILP). To motivate this approach, note that GTSP-void with horizon H seeks to find a trajectory of H l-separated grasp proposals in Ωt with the highest accumulated return. This motivates us to think of the problem as a walk over a directed graph generating an elementary path (in an elementary path on a graph in which all nodes are distinct) of length H of l-separated grasp proposals with the highest return, where the nodes of the graph are the grasp proposals in the current state, stΩ, and the directed edges represent the order at which the grasp proposals are executed. The formulation provided herein is mainly inspired by the ILP formulation of the well known Travelling Salesman Problem (TSP) with the following changes: (1) the main objective is modified to finding an elementary path of length h with maximal return, anywhere on the graph (as opposed to the conventional tour definition in TSP); (2) addition of the l-separation constraints to enforce voiding; and (3) a modification of Miller-Tucker-Zemlin sub-tour elimination technique for ensuring the path does not contain any sub-tour.
Given the current state st=Ωt, εt, we represent the grasp plan space as a graph =V, E where the nodes of the graph are grasp proposals ωi ∈ stΩ plus two auxiliary initial and terminal nodes {s, e}: ={1,|Ωt|} ∪ {s, e}. We index the initial and terminal nodes by 1 and |V|, respectively. For any pair of l-separated grasp proposals ωi and ωj (i, j ∈ V{s,e}), embodiments of the present invention add directed edges {eij, eji}∈ E with a reward ri jρωi+c1(ωiε≠ωjmcE)) (cf. Equation 1). For such pairs of grasp proposals, embodiments of the present invention also add binary variables {ωij, ωji} to ILP. Embodiments of the present invention connect the initial node s to the set of all grasp proposal nodes with reward defined as rsi:=c1(ωsε≠ωiε) and add binary variables ωsi(∀i ∈ V{s, e}) to ILP. Embodiments of the present invention also connect the set of all grasp proposal nodes to the terminal node e with reward rieωiρ, and add corresponding binary variables ωie(∀i ∈\{s, e}) to ILP. The optimization objective is defined as maximization
subject to a set of constraints that enforce an elementary path of length H.
An example of the complete ILP formulation according to one embodiment of the present invention is outlined in Algorithm 1, which is shown in
Some embodiments of the present invention use a simple alternative to ILP for approximately solving GTSP-void based on a sparse tree search (STS). In this approach, at every search step, a node is expanded using a sparse subset of available grasp proposals, which are chosen to be the top k grasp proposals per end-effector according to the grasp proposal scores ωρ (we only choose among grasp proposals that satisfy the l-separation constraint). The parameter k—termed the sparsity factor—therefore determines the sparsity of the grasp proposals subset. Example pseudocode of one embodiment of the STS method is shown in
Having described various embodiments of the present invention, we now describe experiments that we performed in connection with embodiments of the present invention. The following discussion is divided into: (1) an investigation on synthetic problems, aimed at quantifying our algorithmic choices, and (2) a real robot study evaluating the performance of embodiments of the present invention in practice.
We first describe synthetic experiments that we performed. In the first set of experiments we conducted a comparative analysis of the two GTSP-void solvers described above. Our goal is to answer the following question: How do the ILP and STS solvers compare in terms of the optimization quality and speed?
In the first set of experiments, we crafted a synthetic tool selection problem generator as follows. (An example of pseudocode for performing the synthetic experiments in shown in
Next, for each-end effector we generate random Gaussian kernels with randomized scale and standard deviation, centered on each object position. The resulting grasp proposal grid for each pixel gives a higher probability of success to pixels that are closer to an object center.
In our experiments, we report the advantage metric, defined as Adv()=ILP()−STS(), which measures the advantage in optimization quality of ILP over STS, and the planning time, evaluated on our Python implementation of STS, and the commercial Gurobi ILP solver, using MacBook Pro 2.8 GHz Quad-Core Intel Core i7 hardware. We used a fixed void radius l=20 and swap cost c=−0.2, and report results over n=100 random problem instances as defined above.
In terms of quality, we observed STS to perform as well as ILP or just marginally worse. In terms of planning speed, STS is orders of magnitude faster, except for the case of 4 end effectors and a low sparsity k=3. Yet, we observe that even in this setting, reducing k significantly improves speed with a negligible effect on quality.
In the second set of experiments, we conducted experiments to evaluate the performance of various grasp tool selection algorithms, and to validate the adequacy of the proposed tool changing score in capturing efficiency. First, we compare the MPC-STS with a set of heuristic baselines. Next, we compare the performance of MPC-STS and heuristics baselines against experiments where only a single end-effector was used (no tool changing allowed). We also conduct a series of ablations on MPC-STS in terms of its void radius and max horizon (i.e., H). Before we present our results, we first discuss how real-world performance should be best evaluated.
As the synthetic results indicated that STS is much faster than ILP, yet suffers a negligible loss in performance, STS may be an advantageous choice in at least some circumstances. Before we present our results, we first discuss how real-world performance should be best evaluated by providing the following metric definitions.
Our primary goal is to minimize the cost associated with changing tools, yet still maximize pick success. One way to measure performance is by grasp throughput—the average number of successful picks in a unit time. However, grasp throughput does not correctly penalize strategies that execute many failed grasps quickly, which can be inappropriate for scenarios where items may become damaged as a result of repeated, aggressive picking.
To adress this, we propose a combined score based on pick success rate (PSR), and tool consistency rate (TCR), defined as:
where PS is the pick success count, PA is the pick attempt count, and TC is the tool change count (here, we do assume that there is no more than one tool change per pick attempt). Ideally, we would like both scores to be high. Also, the PSR and TCR should be balanced according to the time cost of tool change compared to the time cost of a failed grasp. We posit that the following β, TC-score score captures these desiderata,
where β is analogous to an F-beta score. We recommend that β be set to the opportunity cost of a single tool change—the approximate number of successful picks that could have been completed in the time it takes to execute a tool change. For our setup, we estimated β to be 0.33.
In our experimental setup, we used a Fanuc LRMate 200iD/7L arm, with a tool selection hardware using two vacuum end-effectors: Piab BL30-3P.4L.04AJ (30 mm) and Piab BL50-2.10.05AD (50 mm). We used an assortment of mixed items (various sizes, weights, shapes, colors, etc.). Each end-effector is associated with a grasp proposal model trained using previously collected production data appropriate for that end-effector. Embodiments of the grasp proposal models disclosed herein include encoder-decoder convolutional neural nets including a feature pyramid network on a ResNet-101 backbone and a pixelwise sigmoidal output of volume W× H, where W× H are the dimensions of the grasp success probabilities τε. The network is then trained end-to-end using previously collected grasp success/failure data consisting of 5k grasp data per end-effector using stochastic gradient descent with momentum (LR=0.0003; p=0.8). Following the synthetic experiments conclusion, we only used the STS solver.
The feature extractor is pretrained on the MS-COCO detection task, then the full network (feature extractor with the sigmoidal output head) is trained using stochastic gradient descent with momentum (LR=0.0003; p=0.8). To compensate for the sparsity of the pixelwise success signal, we also conduct random sampling of background pixels and include their negative signals in training. Pixels are proposed from the output volume using Boltzmann sampling (kT=0.01).
Table 1, above, compares the MPC-STS method of embodiments of the present invention with three baselines. The first is a randomized selector, which randomly changes tools with probability p=0.75 at each step, and forces a change if not swapped after 10 steps. The second baseline is naive greedy selector, which chooses the next grasp proposal based on one-step reward function (see Equation 1). The third baseline is greedy selector, which accumulates the top n=5 likelihood scores for each tool, and selects the tool with the highest sum. Our MPC-STS selector was configured with a void radius of l=100 mm (roughly 60 pixels), a maximum of 10 initial grasp proposal samples per end-effector, sparsity factor k=2, and a max horizon of H=2 (since it yielded the best results for MPC-STS in this domain based on the ablation results in Table 4). Observe that MPC-STS significantly outperforms the other baselines in terms of both TC-score and pick success rate per hour (improving over the best baseline by 50%).
Comparisons with a single end-effector will now be described. This set of comparisons is based on a separate set of shorter experimental runs with similar items; results are reported in Table 2. Here, note the divergence between the TC-score and the throughput (PS/hr) in the ordering of the performance of the single 50 mm end-effector and the naive greedy baseline.
While the throughput for the single 50 mm strategy is higher, the TC-score correctly reflects that this strategy is less pick efficient. Indeed, the successful pick percentage for the 50 mm strategy is 66% while the successful pick percentage for the naive greedy strategy is 73%. The throughput in this case is inflated by executing failing picks quickly. changing score correctly does not. As expected, MPC-STS outperforms all the baselines.
Experiments were also performed in relation to void radius and max horizon. These experiments are reported in Tables 3 and 4.
On our item set, increasing the size of the void radius leads to a decrease in tool-changing efficiency and overall throughput at an MPC-STS with H=3. As the tree search progresses, the bin becomes increasingly voided. For large void radii, a large fraction of the bin will be voided, leading to unreliable reward estimates.
Thus, as long as the void radius is large enough to cover areas disturbed by previous picks, the smaller radius the better. We also see that increasing the max horizon H from 1 to 2 leads to an increase in performance, but thereafter there is a decrease in performance metrics even though the overall tool change count remains similar. We conjecture that this is due to the crude approximation of the deterministic dynamics, which are not reliable for a long planning horizon.
In some embodiments, the techniques described herein relate to a method, performed by a computer, for use with a plurality of grasp prediction models having a one-to-one correspondence with a plurality of end-effectors, the method including: (A) identifying an end-effector currently attached to a robot; (B) identifying, based on an input image, a plurality of objects to be grasped by the robot; (C) selecting, using a Markov Decision Process (MDP) based on the plurality of grasp prediction models, a plurality of grasps for grasping the plurality of objects, wherein the plurality of grasps are in an ordered sequence; and (D) selecting, for each of the plurality of grasps, a corresponding end-effector.
The MDP may include a set of reward balances which balances pick success and end-effector change cost.
The method may further include: (E) identifying a first grasp in the ordered sequence; (F) identifying the end-effector corresponding to the first grasp; (G) determining whether the end-effector currently attached to the robot differs from the end-effector corresponding to the first grasp; and (H) in response to determining that the end-effector currently attached to the robot differs from the end-effector corresponding to the first grasp: (H)(1) detaching the end-effector currently attached to the robot from the robot; and (H)(2) automatically attaching, to the robot, the end-effector corresponding to the first grasp.
Operations (H)(1) and/or (H)(2) may be performed automatically. Operations (H)(1) and (H)(2) may be performed automatically using a single tool-changer mechanism.
Each of the plurality of grasp prediction models may provide, based on a given image and the end-effector corresponding to the grasp prediction model, a plurality of grasp proposals, wherein each of the plurality of grasp proposals identifies: the end-effector corresponding to the grasp prediction model, a pixel in the given image, and a probability of a successful grasp when the end-effector corresponding to the grasp prediction model is used to attempt a grasp at a location corresponding to the pixel in the given image.
Operation (C) may include: (C)(1) for each of the plurality of grasp prediction models, evaluating the grasp prediction model at each of a plurality of pixels in the input image to generate a success probability score corresponding to that grasp prediction model and that pixel; and (C)(2) identifying, for each of the plurality of grasp prediction models, k pixel positions in the image having the k highest success probability scores for that grasp prediction model, where k>1.
Operation (C) may include selecting the plurality of grasps by solving an approximation of the Markov Decision Process (MDP).
Solving the approximation of the MDP may include solving the approximation of the MDP based only on objects that are visible in the input image. Solving the approximation of the MDP may include solving the approximation of the MDP using Integer Linear Programming (ILP). Solving the approximation of the MDP may include solving the approximation of the MDP using a sparse tree search.
Operation (C) may include, at each of a plurality of time steps, selecting a grasp that is optimal for at least one next time step.
Operation (C) may include: (C)(1) selecting a first grasp in the ordered sequence of the plurality of grasps; (C)(2) defining a void zone, the void zone including an area surrounding a location of the first grasp; and (C)(3) selecting a second grasp in the ordered sequence of the plurality of grasps, wherein selecting the second grasp includes excluding the void zone from consideration when selecting the second grasp, wherein the second grasp has a location that is not in the void zone.
In some embodiments, the techniques described herein relate to a system for use with a plurality of grasp prediction models having a one-to-one correspondence with a plurality of end-effectors, the system including at least one non-transitory computer-readable medium having computer program instructions stored thereon, the computer program instructions being executable by at least one computer processor to perform a method, the method including: (A) identifying an end-effector currently attached to a robot; (B) identifying, based on an input image, a plurality of objects to be grasped by the robot; (C) selecting, using a Markov Decision Process (MDP) based on the plurality of grasp prediction models, a plurality of grasps for grasping the plurality of objects, wherein the plurality of grasps are in an ordered sequence; and (D) selecting, for each of the plurality of grasps, a corresponding end-effector.
The MDP may include a set of reward balances which balances pick success and end-effector change cost.
The method may further include: (E) identifying a first grasp in the ordered sequence; (F) identifying the end-effector corresponding to the first grasp; (G) determining whether the end-effector currently attached to the robot differs from the end-effector corresponding to the first grasp; and (H) in response to determining that the end-effector currently attached to the robot differs from the end-effector corresponding to the first grasp: (H)(1) detaching the end-effector currently attached to the robot from the robot; and (H)(2) automatically attaching, to the robot, the end-effector corresponding to the first grasp.
Operations (H)(1) and/or (H)(2) may be performed automatically. Operations (H)(1) and (H)(2) may be performed automatically using a single tool-changer mechanism.
Each of the plurality of grasp prediction models may provide, based on a given image and the end-effector corresponding to the grasp prediction model, a plurality of grasp proposals, wherein each of the plurality of grasp proposals identifies: the end-effector corresponding to the grasp prediction model, a pixel in the given image, and a probability of a successful grasp when the end-effector corresponding to the grasp prediction model is used to attempt a grasp at a location corresponding to the pixel in the given image.
Operation (C) may include: (C)(1) for each of the plurality of grasp prediction models, evaluating the grasp prediction model at each of a plurality of pixels in the input image to generate a success probability score corresponding to that grasp prediction model and that pixel; and (C)(2) identifying, for each of the plurality of grasp prediction models, k pixel positions in the image having the k highest success probability scores for that grasp prediction model, where k>1.
Operation (C) may include selecting the plurality of grasps by solving an approximation of the Markov Decision Process (MDP).
Solving the approximation of the MDP may include solving the approximation of the MDP based only on objects that are visible in the input image. Solving the approximation of the MDP may include solving the approximation of the MDP using Integer Linear Programming (ILP). Solving the approximation of the MDP may include solving the approximation of the MDP using a sparse tree search.
Operation (C) may include, at each of a plurality of time steps, selecting a grasp that is optimal for at least one next time step.
Operation (C) may include: (C)(1) selecting a first grasp in the ordered sequence of the plurality of grasps; (C)(2) defining a void zone, the void zone including an area surrounding a location of the first grasp; and (C)(3) selecting a second grasp in the ordered sequence of the plurality of grasps, wherein selecting the second grasp includes excluding the void zone from consideration when selecting the second grasp, wherein the second grasp has a location that is not in the void zone.
It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims. For example, elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions.
Any of the functions disclosed herein may be implemented using means for performing those functions. Such means include, but are not limited to, any of the components disclosed herein, such as the computer-related components described below.
The techniques described above may be implemented, for example, in hardware, one or more computer programs tangibly stored on one or more computer-readable media, firmware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on (or executable by) a programmable computer including any combination of any number of the following: a processor, a storage medium readable and/or writable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), an input device, and an output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output using the output device.
Embodiments of the present invention include features which are only possible and/or feasible to implement with the use of one or more computers, computer processors, and/or other elements of a computer system. Such features are either impossible or impractical to implement mentally and/or manually. For example, the neural networks used by embodiments of the present invention may be applied to datasets containing millions of elements and perform up to millions of calculations per second. It would not be feasible for such algorithms to be executed manually or mentally by a human.
Any claims herein which affirmatively require a computer, a processor, a memory, or similar computer-related elements, are intended to require such elements, and should not be interpreted as if such elements are not present in or required by such claims. Such claims are not intended, and should not be interpreted, to cover methods and/or systems which lack the recited computer-related elements. For example, any method claim herein which recites that the claimed method is performed by a computer, a processor, a memory, and/or similar computer-related element, is intended to, and should only be interpreted to, encompass methods which are performed by the recited computer-related element(s). Such a method claim should not be interpreted, for example, to encompass a method that is performed mentally or by hand (e.g., using pencil and paper). Similarly, any product claim herein which recites that the claimed product includes a computer, a processor, a memory, and/or similar computer-related element, is intended to, and should only be interpreted to, encompass products which include the recited computer-related element(s). Such a product claim should not be interpreted, for example, to encompass a product that does not include the recited computer-related element(s).
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by one or more computer processors executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives (reads) instructions and data from a memory (such as a read-only memory and/or a random access memory) and writes (stores) instructions and data to the memory. Storage devices suitable for tangibly embodying computer program instructions and data include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive (read) programs and data from, and write (store) programs and data to, a non-transitory computer-readable storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
Any data disclosed herein may be implemented, for example, in one or more data structures tangibly stored on a non-transitory computer-readable medium. Embodiments of the invention may store such data in such data structure(s) and read such data from such data structure(s).
Any step or act disclosed herein as being performed, or capable of being performed, by a computer or other machine, may be performed automatically by a computer or other machine, whether or not explicitly disclosed as such herein. A step or act that is performed automatically is performed solely by a computer or other machine, without human intervention. A step or act that is performed automatically may, for example, operate solely on inputs received from a computer or other machine, and not from a human. A step or act that is performed automatically may, for example, be initiated by a signal received from a computer or other machine, and not from a human. A step or act that is performed automatically may, for example, provide output to a computer or other machine, and not to a human.
The terms “A or B,” “at least one of A or/and B,” “at least one of A and B,” “at least one of A or B,” or “one or more of A or/and B” used in the various embodiments of the present disclosure include any and all combinations of words enumerated with it. For example, “A or B,” “at least one of A and B” or “at least one of A or B” may mean: (1) including at least one A, (2) including at least one B, (3) including either A or B, or (4) including both at least one A and at least one B.
Number | Date | Country | |
---|---|---|---|
63243464 | Sep 2021 | US |