Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
SYSTEMS, METHODS, AND MEDIA FOR MANUFACTURING PROCESSES
Document Type and Number:
WIPO Patent Application WO/2021/092329
Kind Code:
A1
Abstract:
A manufacturing system is disclosed herein. The manufacturing system includes one or more stations, a monitoring platform, and a control module. Each station of the one or more stations is configured to perform at least one step in a multi-step manufacturing process for a component. The monitoring platform is configured to monitor progression of the component throughout the multi-step manufacturing process. The control module is configured to dynamically adjust processing parameters of each step of the multi-step manufacturing process to achieve a desired final quality metric for the component.

Inventors:
SUNDSTROM ANDREW (US)
LIMOGE DAMAS (US)
KIM EUN-SOL (US)
PINSKIY VADIM (US)
PUTMAN MATTHEW (US)
Application Number:
PCT/US2020/059339
Publication Date:
May 14, 2021
Filing Date:
November 06, 2020
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
NANOTRONICS IMAGING INC (US)
International Classes:
G05B19/418; G05B19/19; G05B19/406; G06N20/20; G06Q10/06
Foreign References:
US20040030431A12004-02-12
US20190180153A12019-06-13
US20180144248A12018-05-24
US20060013505A12006-01-19
US20180005083A12018-01-04
US20160259318A12016-09-08
Other References:
See also references of EP 4055454A4
Attorney, Agent or Firm:
WOLFE, Joseph et al. (US)
Download PDF:
Claims:
CLAIMS

1. A manufacturing system, comprising: one or more stations, each station configured to perform at least one step in a multi-step manufacturing process for a component; a monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process; and a control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations, comprising: receiving image data of tooling of a first station of the one or more stations; identifying a set of keypoints from the image data, the set of keypoints corresponding to position information of the tooling during processing at the first station; determining, by a machine learning model, a final quality metric for the component, based on the set of keypoints; determining that the final quality metric is not within a threshold tolerance from the final quality metric; and based on the determining, updating processing parameters of subsequent stations in the multi-step manufacturing process.

2. The manufacturing system of claim 1, wherein the final quality metric cannot be measured until processing of the component is complete.

3. The manufacturing system of claim 1, wherein the image data comprises a plurality of images, each image corresponding to a respective camera.

4. The manufacturing system of claim 1, wherein the operations further comprise: extracting, from the image data, a subset of images, wherein each image of the subset of images includes the tooling of the first station.

5. The manufacturing system of claim 1, wherein identifying the set of keypoints from the image data comprises: applying blob detection to the image data to identify a location of the tooling in the image data.

6. The manufacturing system of claim 5, further comprises: generating a number of points corresponding to the tooling in the image data.

7. The manufacturing system of claim 1, wherein the machine learning model is a long short-term memory model.

8. A manufacturing system, comprising: one or more processing stations, each processing station configured to perform at least one step in a multi-step manufacturing process for a component; a monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process; and a control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations, comprising: identifying positional information corresponding to the component at a first processing station of the one or more processing stations; determining, based on the positional information corresponding to the component, that an irreversible error is present; based on the determining, generating an updated instruction set to correct the irreversible error, the updated instruction set to be performed by a downstream processing station; predicting, by a machine learning model, a final quality metric for the component based on the updated instruction set; and based on the predicted final quality metric, providing the updated instruction set to the downstream processing station.

9. The manufacturing system of claim 8, wherein the final quality metric cannot be measured until processing of the component is complete.

10. The manufacturing system of claim 8, wherein identifying positional information corresponding to the component, comprises: receiving a set of points corresponding to coordinates of the component.

11. The manufacturing system of claim 10, wherein determining, based on the positional information corresponding to the component, that the irreversible error is present comprises: comparing the set of points corresponding to coordinates of the component to a canonical set of points corresponding to a canonical component.

12. The manufacturing system of claim 11, wherein comparing the set of points corresponding to the coordinates of the component to the canonical set of points corresponding to the canonical component comprises: generating a Hausdorff distance between the set of points and the canonical set of points.

13. The manufacturing system of claim 8, wherein generating the updated instruction set to correct the irreversible error comprises: applying a stochastic gradient descent to a set of actions that occurred prior to the irreversible error.

14. The manufacturing system of claim 13, wherein the set of actions that occurred prior to the irreversible error comprises a respective set of actions for each upstream system.

15. The manufacturing system of claim 8, wherein providing the updated instruction set to the downstream station comprises: adjusting control parameters of each downstream system.

16. A manufacturing system, comprising: one or more stations, each station configured to perform at least one step in a multi-step manufacturing process for a component; a monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process; and a control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations, comprising: receiving image data of tooling of a first station of the one or more stations; identifying a set of keypoints from the image data, the set of keypoints corresponding to position information of the tooling during processing at the first station; determining, by a machine learning model, a final quality metric for the component, based on the set of keypoints; determining that the final quality metric is not within a threshold tolerance from the final quality metric; based on the determining, inferring positional information corresponding to the component at the first station; based on the determining, generating an updated instruction set to be performed by a downstream station; predicting, by a machine learning model, a final quality metric for the component based on the updated instruction set; and based on the predicted final quality metric, providing the updated instruction set to the downstream station.

17. The manufacturing system of claim 16, wherein the final quality metric cannot be measured until processing of the component is complete.

18. The manufacturing system of claim 17, further comprising: determining, based on the positional information corresponding to the component, that an irreversible error is present.

19. The manufacturing system of claim 18, further comprising: comparing the set of points corresponding to the coordinates of the component to a canonical set of points corresponding to a canonical component.

20. The manufacturing system of claim 16, wherein generating the updated instruction set to correct the irreversible error comprises: applying a stochastic gradient descent to a set of actions that occurred prior to the irreversible error.

Description:
Systems, Methods, and Media for Manufacturing Processes

Cross-Reference to Related Applications

[0001] This application claims priority to U.S. Provisional Application Serial No. 62/931,448, filed November 6, 2019, U.S. Provisional Application Serial No. 62/932,063, filed November 7, 2019, and U.S. Provisional Application Serial No. 62/931,453, filed November 6, 2019, which are hereby incorporated by reference in their entireties.

Field of Disclosure

[0002] The present disclosure generally relates to a system, method, and media for manufacturing processes.

Background

[0003] Since the dawn of the industrial revolution in the 18 th century, automation has governed the production of goods. Although today’s factories have fully embraced automation as a core principle - with robots performing many repeatable tasks in high-production environments - many assembly tasks continue to be performed by humans. These tasks are difficult to automate due to cost, risk of critical failure, or logistics of deploying a robotic system for a low-quantity production run. These production lines are overseen by standard process control and people management, such that an assembler is taught to perform a certain quality metric over time, or they are replaced by another operator. This process has remained largely unchanged since the advent of the assembly.

Summary

[0004] In some embodiments, a manufacturing system is disclosed herein. The manufacturing system includes one or more stations, a monitoring platform, and a control module. Each station is configured to perform at least one step in a multi-step manufacturing process for a component. The monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process. T control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations. The operations include receiving image data of tooling of a first station of the one or more stations. The operations further include identifying a set of keypoints from the image data. The keypoints correspond to position information of the tooling during processing at the first station. The operations further include determining, by a machine learning model, a final quality metric for the component, based on the keypoints. The operations further include determining that the final quality metric is not within a threshold tolerance from the final quality metric. The operations further include, based on the determining, updating processing parameters of subsequent stations in the multi-step manufacturing process.

[0005] In some embodiments, a manufacturing system is disclosed herein. The manufacturing system includes one or more stations, a monitoring platform, and a control module. Each station is configured to perform at least one step in a multi-step manufacturing process for a component. The monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process. T control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations. The operations include identifying positional information corresponding to the component at a first processing station of the one or more processing stations. The operations further include determining, based on the positional information corresponding to the component, that an irreversible error is present. The operations further include, based on the determining, generating an updated instruction set to correct the irreversible error, the updated instruction set to be performed by a downstream station. The operations further include predicting, by a machine learning model, a final quality metric for the component based on the updated instruction set. The operations further include, based on the predicted final quality metric, providing the updated instruction set to the downstream station.

[0006] In some embodiments, a manufacturing system is disclosed herein. The manufacturing system includes one or more stations, a monitoring platform, and a control module. Each station is configured to perform at least one step in a multi-step manufacturing process for a component. The monitoring platform configured to monitor progression of the component throughout the multi-step manufacturing process. T control module configured to dynamically adjust processing parameters of a step of the multi-step manufacturing process to achieve a desired final quality metric for the component, the control module configured to perform operations. The operations include receiving image data of tooling of a first station of the one or more stations. The operations further include identifying a set of keypoints from the image data. The keypoints correspond to position information of the tooling during processing at the first station. The operations further include determining, by a machine learning model, a final quality metric for the component, based on the keypoints. The operations further include determining that the final quality metric is not within a threshold tolerance from the final quality metric. The operations further include based on the determining, inferring positional information corresponding to the component at the first processing station. The operations further include based on the determining, generating an updated instruction set to be performed by a downstream station. The operations further include predicting, by a machine learning model, a final quality metric for the component based on the updated instruction set. The operations further include, based on the predicted final quality metric, providing the updated instruction set to the downstream station.

Brief Description of the Drawings

[0007] So that the manner in which the above recited features of the present disclosure can be understood in detail, a more particular description of the disclosure, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this disclosure and are therefore not to be considered limiting of its scope, for the disclosure may admit to other equally effective embodiments.

[0008] Figure 1 is a block diagram illustrating a manufacturing environment, according to example embodiments.

[0009] Figure 2 is a block diagram illustrating control module, according to exemplary embodiments.

[0010] Figure 3 is a block diagram illustrating an exemplary architecture of LSTM model, according to example embodiments.

[0011] Figure 4 is a block diagram visually illustrating the overall process flow of a feedback segment for tooling module, according to example embodiments.

[0012] Figure 5 is a block diagram illustrating architecture of GRU model, according to example embodiments.

[0013] Figure 6 is a flow diagram illustrating a method of correcting a multi-step manufacturing process, according to example embodiments

[0014] Figure 7 is a flow diagram illustrating a method of correcting a multi-step manufacturing process, according to example embodiments

[0015] Figure 8A illustrates a system bus computing system architecture, according to example embodiments.

[0016] Figure 8B illustrates a computer system having a chipset architecture, according to example embodiments. [0017] To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures. It is contemplated that elements disclosed in one embodiment may be beneficially utilized on other embodiments without specific recitation.

Detailed Description

[0018] Manufacturing processes may be complex and include raw materials being processed by different process stations (or “stations”) until a final component is produced. In some embodiments, each process station receives an input for processing and may output an intermediate output that may be passed along to a subsequent (downstream) process station for additional processing. In some embodiments, a final process station may receive an input for processing and may output the final component or, more generally, the final output.

[0019] In some embodiments, each station may include one or more tools/equipment that may perform a set of process steps. Exemplary process stations may include, but are not limited to, conveyor belts, injection molding presses, cutting machines, die stamping machines, extruders, computer numerical control (CNC) mills, grinders, assembly stations, three-dimensional printers, quality control stations, validation stations, and the like.

[0020] In some embodiments, operations of each process station may be governed by one or more process controllers. In some embodiments, each process station may include one or more process controllers that may be programmed to control the operation of the process station. In some embodiments, an operator, or control algorithms, may provide the station controller with station controller setpoints that may represent the desired value, or range of values, for each control value. In some embodiments, values used for feedback or feed forward in a manufacturing process may be referred to as control values. Exemplary control values may include, but are not limited to: speed, temperature, pressure, vacuum, rotation, current, voltage, power, viscosity, materials/resources used at the station, throughput rate, outage time, noxious fumes, and the like.

[0021] One or more techniques provided herein improves upon conventional processes by providing a system through which image and/or video data may be used to predict or forecast a final quality metric of a component. In some embodiments, the system may include a monitoring system configured to capture or record video and/or image data of the tooling of each processing node or station of manufacturing system. Based on the positioning of the tooling during a process step, the present system may be configured to predict or forecast a final quality metric of a component. If the predicted final quality metric falls outside of a range of acceptable values, the present system may generate and provide updated processing instructions to downstream processing nodes and/or stations, in an attempt to correct for any errors in processing, such that a desired final quality metric may be achieved.

[0022] In some embodiments, the system may include a monitoring system configured to capture or record video and/or image data of a component at each processing node or station of the manufacturing system. Based on visual information about the component at an end of a processing node, the present system may be configured to predict or forecast a final quality metric of a component. If the predicted final quality metric falls outside of a range of acceptable values, the present system may generate and provide updated processing instructions to downstream processing nodes and/or stations, in an attempt to correct for any errors in processing, such that a desired final quality metric may be achieved.

[0023] In this manner, the present system is able to predict or forecast a final quality metric of a component, at any stage of the manufacturing process, without having to actually test the component. Such system is particularly useful for final quality metrics that would otherwise require destructive testing, or for which the final quality metric cannot be evaluated until processing is complete.

[0024] Figure 1 is a block diagram illustrating a manufacturing environment 100, according to example embodiments. Manufacturing environment 100 may include a manufacturing system 102, a monitoring platform 104, and a control module 106. Manufacturing system 102 may be broadly representative of a multi-step manufacturing system. In some embodiments, manufacturing system 102 may be representative of an assembly line system, where each processing station may be representative of a human worker. In some embodiments, manufacturing system 102 may be representative of a manufacturing system for use in additive manufacturing (e.g., 3D printing system). In some embodiments, manufacturing system 102 may be representative of a manufacturing system for use in subtractive manufacturing (e.g., CNC machining. In some embodiments, manufacturing system 102 may be representative of a manufacturing system for use in a combination of additive manufacturing and subtractive manufacturing. More generally, in some embodiments, manufacturing system 102 may be representative of a manufacturing system for use in a general manufacturing process.

[0025] Manufacturing system 102 may include one or more stations 108i-108 n (generally, “station 108”). Each station 108 may be representative of a step and/or station in a multi-step manufacturing process. For example, each station 108 may be representative of a layer deposition operation in a 3D printing process (e.g., station 108i may correspond to layer 1, station IO8 2 may correspond to layer 2, etc.)· In another example, each station 108 may correspond to a specific processing station. In another example, each station 108 may correspond to a specific human operator performing a specific task in an assembly line manufacturing process.

[0026] Each station 108 may include a process controller 114 and control logic 116. Each process controller 114i-114 n may be programmed to control the operation of each respective station 108. In some embodiments, control module 106 may provide each process controller 114 with station controller setpoints that may represent the desired value, or range of values, for each control value. Control logic 116 may refer to the attributes/parameters associated with a station’s 108 process steps. In operation, control logic 116 for each station 108 may be dynamically updated throughout the manufacturing process by control module 106, depending on a current trajectory of a final quality metric.

[0027] Monitoring platform 104 may be configured to monitor each station 108 of manufacturing system 102. In some embodiments, monitoring platform 104 may be a component of manufacturing system 102. For example, monitoring platform 104 may be a component of a 3D printing system. In some embodiments, monitoring platform 104 may be independent of manufacturing system 102. For example, monitoring platform 104 may be retrofit onto an existing manufacturing system 102. In some embodiments, monitoring platform 104 may be representative of an imaging device configured to capture an image of a component or tooling (e.g., a worker or a process tool) at each step of a multi-step process. For example, monitoring platform 104 may be configured to capture an image of the component at each station 108 and/or an image of a component developing the component at each station 108 (e.g., tooling, human, etc.). Generally, monitoring platform 104 may be configured to capture information associated with production of a component (e.g., an image, a voltage reading, a speed reading, etc.) and/or tool (e.g., hand position, tooling position, etc.), and provide that information, as input, to control module 106 for evaluation.

[0028] Control module 106 may be in communication with manufacturing system 102 and monitoring platform 104 via one or more communication channels. In some embodiments, the one or more communication channels may be representative of individual connections via the Internet, such as cellular or Wi-Fi networks. In some embodiments, the one or more communication channels may connect terminals, services, and mobile devices using direct connections, such as radio frequency identification (RFID), near-field communication (NFC), Bluetooth™, low-energy Bluetooth™ (BLE), Wi-Fi™, ZigBee™, ambient backscatter communication (ABC) protocols, USB, WAN, or LAN.

[0029] Control module 106 may be configured to control each process controller of manufacturing system 102. For example, based on information captured by monitoring platform 104, control module 106 may be configured to adjust process controls associated with a specific station 108. In some embodiments, control module 106 may be configured to adjust process controls of a specific station 108 based on a projected final quality metric.

[0030] Figure 2 is a block diagram illustrating control module 106, according to exemplary embodiments. Control module 106 may include a tooling module 202 and a component module 204.

[0031] Tooling module 202 may be configured to project a final quality metric of a specimen at a given stage of production based on image data obtained by monitoring platform 104. In operation, control module 106 may receive input from monitoring platform 104. In some embodiments, such input may take the form of an image or video of the tooling performing a subprocess at a given step of the multi-step manufacturing process. For example, the image or video data may include image or video data of a human’s hands while performing a specific subprocess of the multi-step manufacturing process. In another example, the image or video data may include image or video data of a three-dimensional printer performing depositing a specific layer of a multi-layer manufacturing process. Based on the input, control module 106 may project a final quality metric of the component. Depending on the projected final quality metric of the component, control module 106 may determine one or more actions to take in subsequent manufacturing steps in order to reach a desired or threshold final quality metric. For example, if the projected final quality metric falls outside of a range of acceptable values, control module 106 may take one or more actions to rectify the manufacturing process. In some embodiments, control module 106 may interface with station controllers in subsequent stations 108 to adjust their respective control and/or station parameters. In some embodiments, control module 106 may provide human manufacturers with updated instructions to be performed at each downstream processing station of a production line. These adjustments may aid in correcting the manufacturing process, such that the final quality metric may be within the range of acceptable quality metrics.

[0032] Component module 204 may be configured to project a final quality metric of a specimen at a given stage of production based on image data obtained by monitoring platform 104. In some embodiments, component module 204 may receive input from monitoring platform 104. In some embodiments, such input may take the form of an image or video of the component at a given step of the multi-step manufacturing process. In some embodiments, component module 204 may receive inferred component data at a given step of the multi-step manufacturing process from tooling module 202. For example, tooling module 202 may infer information about the component at a given step of the multi-step manufacturing process based on the tooling image or video data and provide that inferred information to component module 204 as input. Based on the input, component module 204 may project a final quality metric of the component. Depending on the projected final quality metric of the component, component module 204 may determine one or more actions to take in subsequent manufacturing steps in order to reach a desired or threshold final quality metric. For example, if the projected final quality metric falls outside of a range of acceptable values, component module 204 may identify one or more actions to rectify the manufacturing process. In some embodiments, control module 106 may interface with station controllers in subsequent stations 108 to adjust their respective control and/or station parameters. In some embodiments, control module 106 may provide human manufacturers with updated instructions to be performed at each downstream processing station of a production line. These adjustments may aid in correcting the manufacturing process, such that the final quality metric may be within the range of acceptable quality metrics.

[0033] Each of tooling module 202 and component module 204 may include one or more software modules. The one or more software modules may be collections of code or instructions stored on a media (e.g., memory of computing systems associated with control module 106) that represent a series of machine instructions (e.g., program code) that implements one or more algorithmic steps. Such machine instructions may be the actual computer code the processor interprets to implement the instructions or, alternatively, may be a higher level of coding of the instructions that is interpreted to obtain the actual computer code. The one or more software modules may also include one or more hardware components. One or more aspects of an example algorithm may be performed by the hardware components (e.g., circuitry) itself, rather as a result of the instructions. Further, in some embodiments, each of tooling module 202 and component module 204 may be configured to transmit one or more signals among the components. In such embodiments, such signals may not be limited to machine instructions executed by a computing device.

[0034] In some embodiments, tooling module 202 and component module 204 may communicate via one or more local networks. Network may be of any suitable type, including individual connections via the Internet, such as cellular or Wi-Fi networks. In some embodiments, network may connect terminals, services, and mobile devices using direct connections, such as radio frequency identification (RFID), near-field communication (NFC), Bluetooth™, low-energy Bluetooth™ (BLE), Wi-Fi™, ZigBee™, ambient backscatter communication (ABC) protocols, USB, WAN, or LAN. Because the information transmitted may be personal or confidential, security concerns may dictate one or more of these types of connection be encrypted or otherwise secured. In some embodiments, however, the information being transmitted may be less personal, and therefore, the network connections may be selected for convenience over security.

[0035] Tooling module 202 may include acquisition system 206, extractor module 208, and prediction module 210. Generally, a multi -node or multi-station assembly environment, such as manufacturing system 102, may be represented, broadly as G(s , a[). where s may represent the states of the component at all i nodes and where a[ may represent that set of actions to be performed on the component by the tooling at all i nodes. Given a norm or canonical quality measurement, V c , tooling module 202 may be configured to optimize the error in the assembly process with an estimated quality metric, V c , such that may be within a threshold distance of V c . In some embodiments, tooling module 202 may estimate the state, which may be a numerical representation of a state of the component at all N nodes, and the actions, which may represent the instructions or control values at each node.

[0036] Acquisition system 206 may be configured to receive image data of the assembly process at each node, N. In some embodiments, acquisition system 206 may receive the image data of the assembly process of monitoring platform 104. In some embodiments, for each node N, acquisition system 206 may receive V number of images, where V may represent the number of cameras of monitoring platform 104 that may record the assembly procedure at each node. Accordingly, each image of the V number of images may capture a different perspective of the component during processing. Following receipt of the image data, acquisition system 206 may be configured to extract a subset of images of frames. For example, acquisition system 206 may be configured to extract L number of images from the received image data. The extracted images may be referred to as landmark frames. Landmark frames may be those image frames that are in high motion. The extracted images may include those images or frames that include certain landmarks, /, of the component, where / = [i 0 , i 1 , . . . , i L- 1], and may represent the entire manufacturing process for the component. [0037] Both minimal-motion (e.g., “landmark”) frames and maximal-motion (e.g., “high motion”) frames for a given operator may contain useful information for a classifier that is trying to correlate fmger-hand-arm data and flight performance data in a robust way across a number of operators. In some embodiments, an optical flow algorithm may be used to measure an amount of motion in any given frame. Acquisition system 206 may select those frames that contain the most motion.

[0038] Extractor module 208 may be configured to extract keypoints from the L number of images. For example, extractor module 208 may be configured to extract K number of keypoints, i.e., (x, y) pairs, per landlark /;. In other words, extractor module 208 may be configured to output K number of keypoints for a given input, As output, extractor module 208 may generate a single vector This vector may include landmark representations of K number of (x,y) pairs which may be represented by

[0039] In some embodiments, to generate the , extractor module 208 may implement two separate algorithms: (1) a bounding box estimation; and (2) keypoint detection.

[0040] With respect to the bounding box estimation, given each landmark frame may be processed with a threshold image segmentation to generate a mask image for each tooling component. For example, in an embodiment in which the tooling is a human, extractor module 208 may generate a mask image for each of the user’s hands. In some embodiments, extractor module 208 may implement blob detection to locate components of the tooling. Using a human as an example, extractor module 208 may assume that the image always contains both the left and right hands of the user. When a frame fails to include both hands, extractor module 208 may assign the value with an arbitrary constant value, c.

[0041] With respect to keypoint detection, extractor module 208 may identify keypoints of the tooling based on the estimated bounding boxes. For example, with given input, extractor module 208 may estimate K number of points, along with its confidence value, In some embodiments, extractor module 208 may estimate, not only the points that are visible on the frame, but also points that may be occluded from the frame due to one or more of articulation, viewpoints, objects, or tool interactions. Because the objective may be to predict the quality measurement using the tracked keypoints, the non-estimated occluded points may be unique and important features representing the assembly process. Therefore, an occlusion threshold value, t 0 , may be derived from observation of c L value on occluded points in small randomly chosen subset of the landmark frames. Using t 0 , extractor module 208 may filter out the estimation that are For those filtered points, extractor module 208 may assign them an arbitrary constant value, c. Regardless of the visibility of the tooling or keypoints on the frame, the output of extractor module 208 may include pairs for each component. [0042] In other words, extractor module 208 may be configured to assign a default basal level of confidence for occluded components and, therefore, estimate those keypoints so that a full set of keypoints may be available to measure discrepancies between observed trial tooling component positions and the canonical tooling component positions. In some embodiments, tooling module 202 may draw inferences about the state of the component at a given point in time (e.g., station i) and then output recommended modified-from-canonical subsequent actions to take to correct for the measured discrepancies.

[0043] Prediction module 210 may be configured to predict a final quality metric, For example, prediction module 210 may be configured to predict a final quality metric where given tooling tracking information for the L number of points-in-time, may be gathered from each processing station 108. In some embodiments, prediction module 210 may implement a long short-term memory (LSTM) model to output the final quality metric. The LSTM model may allow prediction module 210 to overcome a vanishing gradient problem that is common in conventional recurrent neural networks. The vanishing gradient problem is the case where a model fails to relate the early input to later input for the long sequence input. LSTM model eliminates this issue.

[0044] Figure 3 is a block diagram illustrating an exemplary architecture of LSTM model, according to example embodiments. As shown, LSTM model 300 may include three layers 302I-3023 (generally layer 302). As shown, each layer 302 may include one or more cells 304. In some embodiment, each cell’s 304 input may be p where Each cell in the LSTM may be defined as: where equation 1 decides whether to keep information from the previous cell or not; equation (2) decides which values to update; equation (3) updates the cell; and equation (4) decides which part to output. Equation (5) may filter the output parts so that LSTM model 300 only outputs what it is programmed to output.

[0045] In some embodiments, LSTM model 300 may include three layers 302 with 30 hidden sizes. In some embodiments, LSTM model 300 may be a sequence-to-one LSTM model. For training, the LI, mean absolute error (MAE), loss function: may be minimized using an Adam optimizer. In some embodiments, MAE may be used because the goal may be to minimize or reduce the magnitude of errors, regardless of the direction of the error.

[0046] Referring back to Figure 2, prediction module 210 may be trained using a canonical set of instructions, a, and multiple components, M. For example, using 10 node videos of M number of data, the input for prediction module 210 may be structured by first being pre- processed through acquisition system 206 and extractor module 208. In some embodiments, each component involved in training may be validated through a validation algorithm that checks their composition (e.g., shape). In some embodiments, the validation algorithm may compute a similarity index on the composition at the end of each node by comparing the composition with canonical compositions. As a result, the components for training are roughly similar to the canonical composition.

[0047] In some embodiments, for output, the corresponding physical components may be tested in a controlled environment to measure their quality metric. Using the prepared input data with corresponding output data, prediction module 210 may be trained, for example, with a portion of M being training data and another portion of M being validation data. Once trained, prediction module 210 may be able to predict a quality measurement of a component at a given processing step, based on image data of the tooling.

[0048] Now referring to component module 204, component module 204 may include stochastic gradient descent (SGD) module 212, gated recurrent unit (GRU) model 214, and simulation module 216. For purposes of this discussion, a partial construct of a component may be defined as where step k introduces an irreversible error in the manufacturing process, and steps k + 1, . . . , N are not yet defined. Component module 204 may be configured to identify an optimal corrective sequence of remaining actions where r and t may correspond to specific operations to be performed on the component, at each subsequent processing station (k + 1 to N) of manufacturing system 102. More generally, any component a may be defined as a sequence of all operations performed at each processing station 1 ... N of manufacturing system. Mathematically, . At each manufacturing step i = 1, . .., 10, the virtual representation system may represent the component in Euclidean space as a set of connected surface and a set of connected points uniformly distributed along the outer contour of each surface. In some embodiments, the virtual representation functions generating these representations may be referred to as and , respectively. In some embodiments, component module 204 may be configured to correct toward a particular, canonical component,

[0049] Simulation module 216 may be configured to simulate or generate a surface model for a given component For example, simulation module 216 may receive tooling information from tooling module 202. Based on the keypoints generated by tooling module 202, simulation module 216 may be configured to generate a surface model representing a state of the component at a specific process step i. In some embodiments, the surface model may be represented as . In some embodiments, simulation module 216 may further be configured to generate or estimate a quality metric of the component From the surface model, simulation module 216 may be configured to generate a points model, , representing specific coordinates of the component, For example, from surface model , simulation module 216 may create points model, by placing a number of points uniformly spaced around a bounding contour of each surface in . In some embodiments, may be used to simulate performance of the artifact d .

[0050] SGD module 212 may receive the points model, P , from simulation module 216. SGD module 212 may determine whether an irreversible error, k, has occurred by comparing the points model, , at step i to a canonical points model, P of a canonical component, An irreversible error may be defined to be a measurably significant structural deviation from a canonical component at step k. SGD module 212 may be configured to detect an irreversible error by taking a Hausdorff distance. For example, SGD module 212 may match a processing step of current component to canonical component based on respective Euclidean point sets. Mathematically, SGD module 212 may be configured to compute the Hausdorff distance between For example, where d(x,y) may be the Euclidean distance between x and y, and the undirected Hausdorff distance may be: H(X, Y) = max {h(X, Y), h(Y, X)

[0051] An irreversible error may be present when the Hausdorff distance between the current component and the canonical component a * exceeds some threshold tolerance. For example, SGD module 212 may determine that an error occurs at step k when: where Τ H is some suitably defined tolerance threshold.

[0052] Assuming an error is present, SGD module 212 may be configured to construct a set of updated actions [{r k+1 , t k+1 ], . . {r N , t N }] given a set of actions up to a point of error an irreversible error k. In some embodiments, this set of updated actions may be referred to as X tail · The sequences of steps or actions that preceded and included the error step k may be referred to as x head . Together, x tail and x head may define a component Based on x head , SGD module 212 may solve for x tail using a stochastic gradient descent method.

[0053] GRU model 214 may be configured to predict a final quality metric for the component, fi j , based on where may represent a vector concatenation operator. The final quality metric generated by GRU model 214 may be compared against a canonical final quality metric to determine if x tail is proper. For example, assuming that the combination of x tail and x head yields a final quality metric that falls outside of a range of acceptable values, GRU model 214 may instruct SGD module 212 to generate an updated sequence of updated actions for further evaluation.

[0054] Figure 5 is a block diagram illustrating architecture of GRU model 214, according to example embodiments. As shown, GRU model 214 may include N GRU cells 502 1 -502 N (generally, GRU cell 502), with each GRU cell 502 corresponding to a respective processing station 108. Each GRU cell 502 may include an (r i - t i ) input pair and a hidden state output of a predetermined size. Together, these input pairs ( r u t L ) may define a given component In some embodiments, each GRU cell 502 may be defined by: where may be the hidden state at time t, x t may be the input at time t, and , and may represent the reset, update, and new gates at time t, respectively.

[0055] GRU model 214 may be trained to generate weights corresponding thereto. For example, GRU model 214 may be trained iteratively to bias GRU model 214 toward solving a specific subproblem. In some embodiments, during a first iteration, GRU model 214 may generate a plurality (e.g., several hundred to several thousand) best predictions (one for each possible error at step k ) to complete a given component at steps k + I, . ., N, along with the corresponding predicted quality metrics corresponding to each prediction.

[0056] In some embodiments, all of the predicted airplane completions may be rendered in a virtual representation system, their stepwise Hausdorff distances computed, and their rendered surfaces simulated, to obtain distance measures between the generated predictions and the canonical. In some embodiments, the loss values between the canonical and predicted quality metric measures may be computed and fed back into the GRU model 214, whose weights may be adjusted via backpropagation, producing a second iteration. This process may continue until a desired error threshold is obtained.

[0057] Figure 4 is a block diagram visually illustrating the overall process flow of a feedback segment 400 for tooling module 202, according to example embodiments.

[0058] As shown, feedback segment 400 may include a first portion 402, a second portion 404, and a third portion 406. During first portion 402, tooling module 202 may perform an acquisition process, such as that carried out, at least partially, by acquisition system 206. [0059] As shown, at block 408, manufacturing system 102 may receive processing instructions for processing a component. In some embodiments, manufacturing system 102 may receive processing instructions on a per station 108 basis. For example, each station 108 of manufacturing system 102 may receive independent processing instructions. In some embodiments, processing instructions may include control values that define attributes (e.g., temperature, pressure, etc.) of a station 108 for manufacturing. In some embodiments, processing instructions may include videos or images that visually illustrate to a human operator how to perform a specific processing step at a processing node of the manufacturing process.

[0060] At block 410, acquisition system 206 may receive image data from monitoring platform 104. In some embodiments, for each node N, acquisition system 206 may receive V number of images, where V may represent the number of cameras of monitoring platform 104 that may record the assembly procedure at each node. Following receipt of the image data, at block 412, acquisition system 206 may be configured to extract a subset of images of frames. For example, acquisition system 206 may be configured to extract L number of images from the received image data. The extracted images may be referred to as landmark frames. The extracted images may include those images or frames that include certain landmarks and may represent the entire manufacturing process for the component.

[0061] Second portion 404 may correspond to operations performed by extractor module 208. As shown, extractor module 208 may receive at least the extracted images from acquisition system 206. Extractor module 208 may be configured to extract keypoints from the L number of images. For example, extractor module 208 may be configured to extract K number of keypoints, i.e., (x,y) pairs, per landlark /;.

[0062] At block 414, extractor module 208 may perform bounding box estimation. For example, given /, each landmark frame may be processed with a threshold image segmentation to generate a mask image for each tooling component. For example, as shown, in an embodiment in which the tooling is a human, extractor module 208 may generate a mask image for each of the user’s hands.

[0063] At block 416, extractor module 208 may perform keypoint detection, given the bounding box estimation. For example, with given input, extractor module 208 may estimate K number of points, ;, along with its confidence value, c L . In some embodiments, extractor module 208 may estimate, not only the points that are visible on the frame, but also points that may be occluded from the frame due to one or more of articulation, viewpoints, objects, or tool interactions.

[0064] Third portion 406 may correspond to operations performed by prediction module 210. As shown, at block 418, prediction module 210 may receive keypoint information from extractor module 208 and may be configured to predict a final quality metric, V c . In some embodiments, prediction module 210 may implement a long short-term memory (LSTM) model to output the final quality metric.

[0065] Figure 6 is a flow diagram illustrating a method 600 of correcting a multi-step manufacturing process, according to example embodiments. Method 600 may begin at step 602.

[0066] At step 602, an instruction set may be provided to manufacturing system 102. The instruction set may be representative of a set of instructions for a manufacturing process to be carried out by manufacturing system 102. In some embodiments, the instruction set may be provided to each station 108. For example, each canonical instruction set provided to each respective station 108 may define the processing parameters for a specific manufacturing step. In another example, each canonical instruction set may be a video of discrete steps to be performed by a human actor at a specific processing node or station 108.

[0067] At step 604, control module 106 may receive image data of the tooling (e.g., station 108) from monitoring platform 104. For example, acquisition system 206 may receive image data of the assembly process at a respective processing node. In some embodiments, acquisition system 206 may receive V number of images, where V may represent the number of cameras of monitoring platform 104 that may record the assembly procedure at a specific procession station 108. Accordingly, each image of the V number of images may capture a different perspective of the tooling during processing.

[0068] At step 606, control module 106 may extract a subset of images from the obtained image data. For example, following receipt of the image data, acquisition system 206 may be configured to extract a subset of images of frames. For example, acquisition system 206 may be configured to extract L number of images, i.e., landmark frames, from the received image data. The extracted images may be referred to as landmark frames. Landmark frames may be those image frames that are in high motion. The extracted images may include those images or frames that include certain landmarks, /, of the component, where , and may represent the entire manufacturing process for the component.

[0069] At step 608, control module 106 may extract one or more keypoints of the tooling from the landmark frames. For example, extractor module 208 may extract keypoints from the L number of images. Extractor module 208 may identify or extract K number of keypoints for a given input, As output, extractor module 208 may generate a single vector This vector may include landmark representations of K number of (x, y) pairs which may be represented by , where

[0070] At step 610, control module 106 may predict a final quality metric for the component based on at least the identified keypoints. In some embodiments, prediction module 210 may implement a long short-term memory (LSTM) model to output the final quality metric.

[0071] At step 612, control module 106 may compare the final quality metric to a desired quality metric. If, at step 610, control module 106 determines that the final quality metric is a threshold tolerance of the desired quality metric, the manufacturing process may proceed to the next processing station or node (e.g., step 616), in accordance with the original instruction set. If, however, at step 612, control module 106 determines that the final quality metric is not within a threshold tolerance of the desired quality metric, then, at step 614 control module 106 may adjust the processing parameters of downstream processing stations. In some embodiments, control module 106 may interface with station controllers in subsequent stations 108 to adjust their respective control and/or station parameters. In some embodiments, control module 106 may provide human manufacturers with updated instructions to be performed at each downstream processing station of a production line. These adjustments may aid in correcting the manufacturing process, such that the final quality metric may be within the range of acceptable quality metrics.

[0072] Figure 7 is a flow diagram illustrating a method 700 of correcting a multi-step manufacturing process, according to example embodiments. Method 700 may begin at step 702.

[0073] At step 702, an instruction set may be provided to manufacturing system 102. The instruction set may be representative of a set of instructions for a manufacturing process to be carried out by manufacturing system 102. In some embodiments, the instruction set may be provided to each station 108. For example, each canonical instruction set provided to each respective station 108 may define the processing parameters for a specific manufacturing step. In another example, each canonical instruction set may be a video of discrete steps to be performed by a human actor at a specific processing node or station 108.

[0074] At step 704, control module 106 may identify information corresponding to a component at a respective processing node. In some embodiments, simulation module 216 may receive tooling information from tooling module 202. Based on the keypoints generated by tooling module 202, simulation module 216 may be configured to generate a surface model representing a state of the component at a specific process step i. In some embodiments, the surface model may be represented as In some embodiments, simulation module 216 may further be configured to generate or estimate a quality metric of the component a L . From the surface model, simulation module 216 may be configured to generate a points model, representing specific coordinates of the component

[0075] At step 706, control module 106 may determine whether an irreversible error has occurred. For example, SGD module 212 may receive points model, , from simulation module 216. SGD module 212 may determine whether an irreversible error, k, has occurred by comparing the points model, at step i to a canonical points model, of a canonical component, SGD module 212 may be configured to detect an irreversible error by taking a Hausdorff distance between the points model and the corresponding canonical points model. An irreversible error may be present when the Hausdorff distance between the current component a; and the canonical component , at the respective processing station or node, exceeds some threshold tolerance.

[0076] If at step 706, control module 106 determines that an irreversible error has not occurred, then the manufacturing process may proceed to the next processing station or node (step 705), in accordance with the original instruction set. If, however, at step 706, control module 106 determines that an irreversible error has occurred, then method 700 proceed to step 708.

[0077] At step 708, control module 106 may generate an updated set of actions to correct the irreversible error. SGD module 212 may construct a set of updated actions given a set of actions up to a point of error an irreversible error k. In some embodiments, this set of updated actions may be referred to as x tail · The sequences of steps or actions that preceded and included the error step k may be referred to as x head . Together, x tail and ead may define a component a έ . Based on x head , SGD module 212 may solve for x tail using a stochastic gradient descent method. The sequences of steps or actions that preceded and included the error step k may be referred to as x head . Together, x tail and X head may define a component a L . Based on x head · SGD module 212 may solve for x taii using a stochastic gradient descent method.

[0078] At step 710, control module 106 may generate a predicted final quality metric for the component, based on the set of actions generated by SGD module 212. For example, GRU model 214 may be configured to predict a final quality metric for the component, based on may represent a vector concatenation operator.

[0079] At step 712, control module 106 may determine if the predicted final quality metric is within a threshold tolerance of the canonical final quality metric. For example, the final quality metric generated by GRU model 214 may be compared against a canonical final quality metric to determine if x taii is proper. If, at step 712, control module 106 determines that the predicted quality metric is within the threshold tolerance, at step 714, control module 106 may adjust the processing parameters of downstream processing stations. In some embodiments, control module 106 may interface with station controllers in subsequent stations 108 to adjust their respective control and/or station parameters. In some embodiments, control module 106 may provide human manufacturers with updated instructions to be performed at each downstream processing station of a production line. These adjustments may aid in correcting the manufacturing process, such that the final quality metric may be within the range of acceptable quality metrics. [0080] If, however, at step 712, control module 106 determines that the predicted quality metric is not within the threshold tolerance, GRU model 214 may prompt SGD module 212 to generate a new x tail · For example, method 700 may revert to step 708 for SGD module 212 to construct a new set of updated actions.

[0081] Figure 8A illustrates a system bus computing system architecture 800, according to example embodiments. One or more components of system 800 may be in electrical communication with each other using a bus 805. System 800 may include a processor (e.g., one or more CPUs, GPUs or other types of processors) 810 and a system bus 805 that couples various system components including the system memory 815, such as read only memory (ROM) 820 and random access memory (RAM) 825, to processor 810. System 800 can include a cache of high-speed memory connected directly with, in close proximity to, or integrated as part of processor 810. System 800 can copy data from memory 815 and/or storage device 830 to cache 812 for quick access by processor 810. In this way, cache 812 may provide a performance boost that avoids processor 810 delays while waiting for data. These and other modules can control or be configured to control processor 810 to perform various actions. Other system memory 815 may be available for use as well. Memory 815 may include multiple different types of memory with different performance characteristics. Processor 810 may be representative of a single processor or multiple processors. Processor 810 can include one or more of a general purpose processor or a hardware module or software module, such as service 1 832, service 2 834, and service 3 836 stored in storage device 830, configured to control processor 810, as well as a special-purpose processor where software instructions are incorporated into the actual processor design. Processor 810 may essentially be a completely self-contained computing system, containing multiple cores or processors, a bus, memory controller, cache, etc. A multi-core processor may be symmetric or asymmetric.

[0082] To enable user interaction with the computing device 800, an input device 845 which can be any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 835 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems can enable a user to provide multiple types of input to communicate with computing device 800. Communications interface 840 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed. [0083] Storage device 830 may be a non-volatile memory and can be a hard disk or other types of computer readable media that can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 825, read only memory (ROM) 820, and hybrids thereof.

[0084] Storage device 830 can include services 832, 834, and 836 for controlling the processor 810. Other hardware or software modules are contemplated. Storage device 830 can be connected to system bus 805. In one aspect, a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as processor 810, bus 805, display 835, and so forth, to carry out the function.

[0085] Figure 8B illustrates a computer system 850 having a chipset architecture, according to example embodiments. Computer system 850 may be an example of computer hardware, software, and firmware that can be used to implement the disclosed technology. System 850 can include one or more processors 855, representative of any number of physically and/or logically distinct resources capable of executing software, firmware, and hardware configured to perform identified computations. One or more processors 855 can communicate with a chipset 860 that can control input to and output from one or more processors 855. In this example, chipset 860 outputs information to output 865, such as a display, and can read and write information to storage device 870, which can include magnetic media, and solid state media, for example. Chipset 860 can also read data from and write data to RAM 875. A bridge 880 for interfacing with a variety of user interface components 885 can be provided for interfacing with chipset 860. Such user interface components 885 can include a keyboard, a microphone, touch detection and processing circuitry, a pointing device, such as a mouse, and so on. In general, inputs to system 850 can come from any of a variety of sources, machine generated and/or human generated.

[0086] Chipset 860 can also interface with one or more communication interfaces 890 that can have different physical interfaces. Such communication interfaces can include interfaces for wired and wireless local area networks, for broadband wireless networks, as well as personal area networks. Some applications of the methods for generating, displaying, and using the GUI disclosed herein can include receiving ordered datasets over the physical interface or be generated by the machine itself by one or more processors 855 analyzing data stored in storage 870 or 875. Further, the machine can receive inputs from a user through user interface components 885 and execute appropriate functions, such as browsing functions by interpreting these inputs using one or more processors 855.

[0087] It can be appreciated that example systems 800 and 850 can have more than one processor 810 or be part of a group or cluster of computing devices networked together to provide greater processing capability.

[0088] While the foregoing is directed to embodiments described herein, other and further embodiments may be devised without departing from the basic scope thereof. For example, aspects of the present disclosure may be implemented in hardware or software or a combination of hardware and software. One embodiment described herein may be implemented as a program product for use with a computer system. The program(s) of the program product define functions of the embodiments (including the methods described herein) and can be contained on a variety of computer-readable storage media. Illustrative computer-readable storage media include, but are not limited to: (i) non-writable storage media (e.g., read-only memory (ROM) devices within a computer, such as CD-ROM disks readably by a CD-ROM drive, flash memory, ROM chips, or any type of solid-state non-volatile memory) on which information is permanently stored; and (ii) writable storage media (e.g., floppy disks within a diskette drive or hard-disk drive or any type of solid state random-access memory) on which alterable information is stored. Such computer-readable storage media, when carrying computer-readable instructions that direct the functions of the disclosed embodiments, are embodiments of the present disclosure.

[0089] It will be appreciated to those skilled in the art that the preceding examples are exemplary and not limiting. It is intended that all permutations, enhancements, equivalents, and improvements thereto are apparent to those skilled in the art upon a reading of the specification and a study of the drawings are included within the true spirit and scope of the present disclosure. It is therefore intended that the following appended claims include all such modifications, permutations, and equivalents as fall within the true spirit and scope of these teachings.