System and Method of Monitoring and Quantifying Performance of an Automated Manufacturing Facility
Field of Invention
[0001] The invention relates generally to the field of monitoring performance of manufacturing facilities. In particular, the invention relates to a system and method of monitoring and managing performance of an automated manufacturing facility.
Background of Invention
[0002] In an automated manufacturing facility, optimal operation of the facility depends on individual manufacturing cells or stations (workcells or workstations) processing parts or workpieces at their respective expected production rate. Workstations not operating at their expected production rate generally constrain product flow and affects overall throughput of the manufacturing process. It is generally believed that throughput of the facility is limited by its constraints, namely, workstations causing relatively most significant disruption to the production or workflow of the facility. Continuous improvement efforts will likely be hindered if one is unable to determine the constraints in an automated manufacturing facility.
[0003] Locating the constraints, however, is not an easy task. This may be particularly so in a facility with sequential production lines. As is known, an automated manufacturing facility often consists of a number of sequential production or processing lines. Each sequential production line consists of several automated workstations linked in a sequential manner. Each of the automated workstations processes a workpiece at a fixed pace as the workpiece moves sequentially from one workstation to the next in the line. In a sequential production line, slowdown at any one of the workstations often causes a ripple effect that spreads both upstream and downstream from the source. Slowdowns can be attributed to many different causes. "Slow cycles", or losses due to a workstation running at a slower than the expected pace, can be one of the contributing factors to the slowdown of a production line. There may also be quality defects, causing processed workpieces being discarded, thus creating gaps in the workflow. Of course, there can always be downtime losses at each workstation, which not only affects the performance at the workstation in question but also creates starved conditions downstream and blocked conditions upstream. As a result, these bottlenecks and quality issues
can ripple through the sequential production line and they tend to mask the source of constraints. For example, a workstation may be idle and appear to be causing performance issues but only because it is starved or blocked due to problems upstream or downstream. Buffers between workstations or production lines are often provided to level workflow in order to achieve continuous proceeding or production. Buffering may further mask the real source of constraints.
[0004] Metrics are generally used to measure productivity of a manufacturing facility and to measure effectiveness of changes made to workstations or manufacturing environment. Typical approaches to solving the problem of improving performance or productivity in a manufacturing environment generally do not deploy methods of identifying constraints. Instead, these methods focus on collecting a different set of data such as machine faults, overall equipment efficiency ("OEE"), idle time, and scrap rates. These metrics, while providing an indication of the overall performance of a plant, generally do not provide satisfactory guidance as to where a problem may have originated and therefore assist management in locating specific workstations where corrective measures may be required.
[0005] To compound the difficulty, often, more and more data are collected in an attempt to improve predictive power of a chosen metric. This information is collected from all workstations in a manufacturing facility. Unfortunately, often a user is left to interpret this increased amount of data to try to identify where constraints in the manufacturing process exist. Because of the complexity of the data and the concurrency of information, this often is difficult. Additionally, there are also disadvantages generally associated with collecting and interpreting a large amount of data, which will only be exacerbated when more data are collected than necessary. It tends to be time consuming and expensive to implement a solution that requires a large amount of data. Any solution deployed also needs to correctly reflect the nature of the data collected. This may call for extra time and effort to understand all of the data and the interrelationship among the types of data collected, which may not be a trivial task. It is therefore desirable to collect only minimally necessary data that still can lead to correct identification of constraints.
[0006] There is therefore a need for a system and method for collecting minimum amount of data, i.e., only those relevant to identifying correctly constraints that limit the throughput,
and processing the data collected to identify the constraints, and for providing a concise and clear view of where constraints are. It is an object of the present invention to mitigate or obviate at least one of the above mentioned disadvantages.
Summary of Invention [0007] The present invention relates to a system and method for identifying and quantifying constraints in an automated manufacturing or processing facility. The facility has a number of automated workstations. A data processing system continuously receives basic event and state signals from automation equipment in the facility and evaluates and processes these signals to derive a throughput capability measure (a measure of constraint) of each given manufacturing workstation in the process. The automated collection of signals may be further augmented by manually entered information relating to a workstation's performance. The throughput capability measure is expressed as a ratio of an ideal cycle time to an accumulated time that includes any delays or overcycles at a workstation but excludes any speed-up at the workstation. A workstation experiences a speed-up if it processes a workpiece in less than the ideal cycle time. The throughput capability measures of all workstations are analyzed to identify the constraints in the facility.
[0008] In one embodiment, a constraint is identified as a workstation that has the lowest throughput. Preferably, throughput capability measures for all workstations are presented to users graphically. This gives users a clear indication of the constraints in the manufacturing flow and a representation of the material flow through the facility. Further drill-down can be provided for obtaining more detailed information about the constraint and capacity loss as well as entering information relevant to the constraint, such as a stoppage or slow-down.
[0009] In one embodiment, throughput capability measures are presented to users through a throughput capability and balance map. Each workstation is represented by an icon on the map. Shown in each icon are computed throughput capability measure, and optionally the percentages of capacity loss due to each monitored categories, such as starved and blocked conditions. Each icon is color coded, with the constraints shown in a uniquely identifiable color. Each icon is rendered actuatable for requesting and providing further information. For example, clicking an icon using a computer pointing device may bring up additional details
relating to performance of the represented workstation or allow for entering further information.
[0010] In a first aspect of the invention, there is provided a system for quantifying and identifying a constraint in an automated manufacturing facility, the automated manufacturing facility having automated workstations for automatically processing workpieces. The system comprises a plurality of signal converters, each of the plurality of signal converters continuously receiving event and state signals collected at a respective automated workstation, and transforming the event and state signals to time and count data, the time and count data including an overcycle time spent by the respective automated workstation during each process cycle of processing a workpiece and a workpiece count; a data modeling engine communicating with the plurality of signal converters; the each signal converter including a computing unit, the computing unit calculating a throughput capability measure of the respective automated workstation upon completion of the each process cycle at the respective workstation, the throughput capability measure being calculated from an expected processing time and an accumulated overcycled processing time accumulated over an accumulation period; and the data modeling engine receiving from the plurality of signal converters the throughput capability measures and identifying the constraint as a workstation whose throughput capability measure meets a pre-selected criteria, wherein the overcycle time is a non-negative quantity derived from a difference between a cycle time of the each process cycle and an ideal cycle time, the overcycle time excluding time spent by the respective workstation during starved and blocked states during the each process cycle, wherein the expected processing time and the accumulated overcycled processing time are accumulated from the ideal cycle time and an overcycled processing time, respectively, over the accumulation period, and wherein the overcycled processing time is a sum of the overcycle time and the ideal cycle time.
[0011] In a feature of this aspect of the invention, the system further includes historical data database and a queue manager, which arranges for the storing of the converted time and count data in the historical data database.
[0012] In another feature of this aspect of the invention, the system further includes further a graphical user interface for displaying a graphical representation of the throughput capability
measures of the workstations to a user, the graphical representation including workstation icons, each of the workstation icons corresponding to one of the workstations and showing a numerical value of the throughput capability measure. In a further feature of this aspect of the invention, the graphical representation includes one or more state icons positioned adjacent each workstation icon of the workstation icons, the one or more state icons each showing a time percentage the each workstation spending in a represented respective state.
[0013] In a second aspect, there is provided a system for quantifying and identifying a constraint in an automated manufacturing facility, the automated manufacturing facility having sequentially linked, automated workstations for automatically processing workpieces. The system comprises a plurality of signal converters, each of the plurality of signal converters continuously receiving starved, blocked and EOC signals collected at a respective automated workstation, and transforming the starved, blocked and EOC signals to time and count data, the time and count data including a measured cycle time spent by the respective automated workstation processing a workpiece during each process cycle, an overcycle time spent by the respective automated workstation during the each process cycle and a workpiece count; data accumulators for accumulating the time and count data received from the each signal converter, the accumulated time and count data including an accumulated overcycle time, an accumulated ideal processing time and a total workpiece count over an accumulation period; a historical data database for storing the time and count data and the accumulated time and count data; a data modeling engine communicating with the plurality of signal converters and the historical data database; the each signal converter including a computing unit, the computing unit calculating a throughput capability measure of the respective automated workstation upon completion of the each process cycle at the respective workstation, the throughput capability measure being calculated from a ratio of the accumulated ideal processing time to an accumulated overcycled processing time; and the data modeling engine receiving from the plurality of signal converters the throughput capability measures and identifying a workstation having the smallest throughput capability measure as the constraint, wherein the overcycle time is a non-negative quantity derived from a difference between the measured cycle time and an ideal cycle time, wherein the accumulated ideal processing time is a product of the ideal cycle time and the total workpiece count, and wherein the accumulated overcycled processing time is a sum of the accumulated ideal Drocessine time and the accumulated overcvcle time.
[0014] In another aspect of the invention, there is provided a method of monitoring and managing performance of an automated processing facility. The method includes the steps of: continuously receiving state and event signals automatically collected from workstations in the automated processing facility; converting the state and event signals to time and count data, the time and count data of each of the workstations including at least an overcycle time, the overcycle time being a non-negative quantity derived from a difference between a measured cycle time and an ideal cycle time; accumulating the time and count data over an accumulation period for the workstations, the accumulated time and count data including at least a total count of workpieces processed by the each workstation during the accumulation period and an accumulated overcycle time accumulated from the overcycle time; continuously computing a throughput capability measure for each workstation upon the each workstation completing processing a workpiece, the throughout capability measure being computed from the total count, the accumulated overcycle time and the ideal cycle time; and identifying a constraint in the automated manufacturing facility from the throughput capability measures of the workstations, the constraint being a workstation having the smallest throughput capability measure.
[0015] In a feature of this aspect of the invention, the time and count data of the each workstation includes a first amount of time spent by the each workstation in starved state and a second amount of time spent by the each workstation in blocked state, and the method further includes the step of displaying the throughput capability measure, information derived from the first amount of time and information derived from the second amount of time in icons associated with the each workstation. In a further feature, the method includes further the step of color coding icons associated with said each workstation in accordance with numerical values of said throughput capability measures. [0016] In other aspects the invention provides various combinations and subsets of the aspects described above.
Brief Description of Drawings
[0017] For the purposes of description, but not of limitation, the foregoing and other aspects of the invention are explained in greater detail with reference to the accompanying drawings, in which: [0018] Figure 1 shows schematically an automated processing facility, interfaced with and monitored by a computer implemented performance management system according to an embodiment of the present invention;
[0019] Figure 2 is a block diagram showing a performance management system for identifying and quantifying constraints in the automated processing facility illustrated in Figure 1;
[0020] Figure 3A illustrates schematically a workstation cycle and generation of end-of- cycle, blocked and starved signals;
[0021] Figure 3B illustrates along a time axis time markers associated with various state and event signals and conversion of these signals to basic time and count data; [0022] Figure 4 illustrates schematically along a time axis categories of losses at a workstation;
[0023] Figure 5 is a flow chart illustrating steps of a process for identifying and quantifying constraints in an automated processing facility;
[0024] Figure 5B depicts time markers associated with various state and event signals along time axis to illustrate conversion of these signals to time and count data and accumulation of converted time and count data;
[0025] Figure 6 is a graphical representation for presenting graphically throughput capability measures of workstations in two sequential production lines;
[0026] Figure 7 shows a throughput capability and balance map for presenting graphically throughput capability measures and other performance indicators for a plurality of production lines linked in sequential and parallel fashions;
[0027] Figure 8 is an exemplary screen display showing detailed information relating to losses in different categories;
[0028] Figure 9 is another exemplary screen display showing detailed information related to OEE;
[0029] Figure 10 is an exemplary screen display for a user to enter information manually, providing information relating to causes of quality loss at a workstation; and [0030] Figure 11 is an exemplary screen display that shows the statistics of quality losses over a given monitored period.
Detailed Description of Embodiments
[0031] The description which follows and the embodiments described therein are provided by way of illustration of an example, or examples, of particular embodiments of the principles of the present invention. These examples are provided for the purposes of explanation, and not limitation, of those principles and of the invention. In the description which follows, like parts are marked throughout the specification and the drawings with the same respective reference numerals.
[0032] The present invention relates to a system and method for identifying and quantifying constraints in an automated manufacturing or processing facility. The facility has a number of automated workstations. In an embodiment the system utilizes automatically collected event and state signals from each workstation and processes these signals to derive a throughput capability measure for each workstation. The automated collection of signals is further augmented by provision of input devices that allow users to manually enter information relating to a workstation's performance. Instead of collecting a large number of signals, the system collects a small number of core event and state signals (three in one embodiment), and correlates these signals with their time data to derive a throughput performance measure. A data modeling engine is provided for analyzing throughput capability measures of all workstations to identify the constraints in the facility. The throughput capability metric, comprising throughput capability measures of all monitored workstations in the facility, is presented graphically to users to provide clear indications of constraints. Results are also analyzed to provide statistics as to performance losses or causes to performance losses so that a user is provided with guidance as to where and what types of improvemefits-should be made.
[0033] Figure 1 shows schematically an automated processing facility 100. The automated processing facility may be any manufacturing facility, processing facility, or testing facility, or any facility that includes a number of processing units that are or can be automated. For example, the facility may be an automated production line of automobiles, an automated semiconductor fabrication facility, or a bottling facility that includes a number of automated bottling lines of beverages. The facility 100 has a number of automated assets 102 in the nature of workstations, workcells or processing stations. An asset 102 is a piece of equipment that is capable of functioning independently from other pieces of equipment. An asset 102 may generally correspond to a machine, a group of machines or even a part of a machine. These automated assets are generally grouped into sequential production or processing lines, such as production line A (104), production line B (106) and production C (108).
[0034] Each sequential production or processing line 104, 106, 108 has a line input point 110 and a line exit point 112. Several automated assets 102 are linked sequentially between a line's input point and the line's exit point to form the sequential production line. A workpiece 114 enters a production line at its input point 110. A workpiece is processed at each workstation and may be a partially assembled automobile in an automobile assembly line, an empty bottle in a bottling facility, or a semiconductor wafer in a semiconductor fabricating facility, among others. In an automated testing facility, a workpiece may be a finished product that is to be subject to a sequence of automated tests or a sample that is to be analyzed at each of the automated data collection and analysis workstations. The workpiece is processed sequentially at each one of the assets 102 of the production line until it reaches the exit point 112 of the production line.
[0035] A buffer 114 may be provided at a line's input point or exit point. In sequential production, a workpiece processed by the production line has only one flow path to choose from, namely the path defined by the sequentially linked assets. In such a sequential production line, the next workstation a workpiece must go is fixed. The timing of the workpiece moving from workstation to workstation, however, is not fixed and is dependent on the individual process being completed at each workstation. Because of the independent timing, a buffer 114 provided at each production line's input point or exit point helps maintaining a consistent level of workflow between production lines. Preferably, buffers are also provided
between workstations to help level workflow further so that continuous processing or production can be achieved. Buffer level often provides some indication as to whether a workstation has been operating at a designed production or processing rate.
[0036] A production line's exit point 112 may be linked to another line's input point 110, to process further the partially processed workpieces. In an iterative process, a line's exit point may also be linked back to its own input point to process the workpieces multiple times before they are handed over to the next production line for further processing. Other configurations are also possible. Figure 1 shows one exemplary configuration in which the exit points of line
A (104) and line C (108) are linked to the input point of line B (106). The first workpiece 116 processed by line A and the second workpiece 118 processed by line C are further processed by line B to produce a combined product 120 at the exit point of line B.
[0037] Each automated asset 102 may have a programmable logic controller 122 (PLC) or similar control device installed thereon. A PLC is a piece of computer hardware responsible for operating the asset 102 in a predetermined manner. It generally includes sensors or has interface for receiving inputs from sensors for detecting state and triggering events or measuring monitored conditions. A PLC contains one or more memory registers to collect data from its associated asset 102. Internal logic of PLC 122 populates its memory registers with data regarding monitored conditions of asset 102. Each memory register stores data associated with a separate monitored condition of asset 102. For example, value in one memory register tracks starved condition of asset 102 while value in another memory register tracks blocked condition of the asset. A PLC can be programmed with a number of logic conditions or "ladders" that allow it to respond to changing input and operate the asset accordingly. Some functions performed by a PLC include quality monitoring (e.g., to ensure parts are loaded correctly), process monitoring (e.g., to ensure that a given process is completed within acceptable specifications, such as rivet pressure, drill depth, etc.), and safety monitoring (such as monitoring of safety gates, light curtains, emergency stop buttons, etc.). Although PLC 122 as shown in Figure 1 is connected to asset 102 through a data link, it will be appreciated that PLC 122 may be integrated with asset 102 providing direct connection between memory registers and the means of gathering the data stored therein.
[0038] Communication links 124, such as wired or wireless data links, connect all PLCs together to form a monitoring network 126. Signals are continuously collected by PLCs and are further transmitted through the monitoring network to a computer 128, or several computers, on which a data processing system in the nature of a software system 130 is executing. Any suitable data transmission protocol or protocols may be used for transmitting the collected signals. One or several display and input devices 132, such as a computer monitor and a keyboard, or a touch screen, are provided and connected to the software system 130, for users to display status of monitored assets 102 and to enter any information relating to the assets. As will be described in great detail below, the software system 130 processes signal data collected by PLCs 122 and computes the throughput capability measure of each of the assets 102 in accordance with a methodology described herein. Preferably, the throughput capability measures are presented to a user graphically. The software system 130 can also conveniently provide a user interface, for example, a graphical user interface displayed on a computer monitor 132, for accepting user inputs relating to any one of assets 102. [0039] Figure 2 is a block diagram showing a software system 130, interfaced with PLCs, according to one embodiment of the present invention. The software system 130 includes a plurality of signal converters 202 in the nature of RTLE 204 (real-time logic engine), data accumulators 206, and a data modeling engine 208. The data modeling engine 208 includes or is interfaced with a historical data database 210, which may be standalone or as part of the software system 130, a report module 212, a visual presentation module 214, and a manual data entry tool 216. Optionally, an OLE for process control (OPC) server 218 is provided between a PLC 122 and a signal converter 202. A queue manager 220 is preferably provided between data accumulators 206 and data modeling engine 208.
[0040] The software system 130 continuously receives data inputs from a collection of PLCs 122, each PLC being installed on a workstation 102 in a plant. The arrows 222 indicate the flow of raw signal data from sensors at each workstation to PLCs 122, pre-processed or formatted by OPC server 218, processed by RTLEs 204 and data accumulators 206, possibly buffered at the queue manager 220 and written by the queue manager 220 into a historical data database 210, which are manipulated and analyzed by data modeling engine 208.
[0041] At each workstation 102, a PLC 122 is interfaced with the workstation, for continuously collecting event and state signals from the workstation. Referring to Figure 3A, the PLCs are programmed to collect a minimum set of three state and event signals: starved bit 302, blocked bit 304 and EOC ("end of cycle") bit 306. Starved bit 302 is used to indicate a "Starved" condition, i.e., when a workstation is idling and waiting for the next workpiece to arrive. This is when the work station has finished unloading from the last finished cycle (that is, has passed its completed part to the next workstation), but a new part is not present in the station after a given delay, or a new part is not ready at the previous workstation. This condition may happen when, for example, both the buffer at the input point ("input buffer") and the workstation are empty, which may be caused by a slowdown at an upstream workstation or workstations. Or, a workstation may be starved for material which prevents the workstation from completing its process cycle. Blocked bit 304 comes on when the station has finished a cycle and the downstream workstation is not available to receive the completed part. This happens when downstream workstations are not ready to receive more parts, for example, because there is a slowdown at a downstream workstation or workstations. EOC bit 306 can be programmed to come on at the same point in each cycle. Typically it is used to indicate a "Cycle Complete" or "End of Cycle" condition. For example, the EOC bit 306 is turned on each time the workstation completes processing a workpiece. Conveniently, the EOC bit remains on for a short period (e.g., 3 seconds) to ensure its detection by RTLE or OPC server. Any other suitable periods, for example from 1 to 3 seconds, depending on polling rate or such other parameters, may be used as long as the EOC bit remains on sufficiently long to ensure its detection.
[0042] Other signals, such as faulted state, quality loss, product or manufacturing process related identifiers, etc. may also be collected. Collecting additional signals can increase the amount of information that the system can report on. For example, the PLC may collect a "Quality" signal by adding a quality bit to its memory registers (not shown). Quality bit comes on in conjunction with the "EOC" signal. If at the end of a cycle the "Quality" signal is "ON" then a rejected or scrap piece is counted. The PLC may also collect one or several identifier signals. Such identifiers may include product code, product model, part types, process batch type, option content, etc., or any kind of desirable identifier. For example, a "Model ED" signal can be collected. Model ID indicates the current running model and is usually given as an
alphanumeric value, for identifying production line configuration or workpieces being processed. The system can use the Model ID to adjust or retrieve model-based parameters. As will be described later, the value of an ideal cycle time varies from model to model, which can be conveniently adjusted or retrieved from a database based on the value of Model ID. Reports and visual presentations can also make use of the "Model ID" as a filter, allowing various metrics to be displayed and sorted by model.
[0043] A workstation itself may have other status bits that the workstation uses to determine what stage of the cycle it is in. Some of the common conditions monitored by a PLC include: "Load Delay", "Part Present", "Part Complete" and "Unload Delay". In many cases a workstation has a built-in delay between the time when it discharges a finished workpiece and the time when it loads a new workpiece. "Load Delay" represents a given delay while a workpiece is being loaded. The "Load Delay" bit 308 is turned on during loading, but since this is part of the normal cycle, the workstation is neither blocked nor starved. Similarly, a workstation may have a built-in delay when it unloads a finished workpiece. The "Unload Delay" bit 310 comes on during unloading and a new cycle is ready to begin again when this bit is turned off. The "Part Present" bit 312 is turned on after the load delay. A new workpiece is considered loaded and a new processing cycle begins. The "Part Complete" bit 314 is turned on at the end of the process cycle. The EOC bit 306 may be turned on at this point and kept on for a pre-determined period, such as 3 seconds, or any other period (for example, from 1 to 3 seconds) that is sufficiently long to ensure its detection by RTLE or OPC server.
[0044] Figure 3A illustrates schematically a typical machine cycle from "Load Delay" (step 320), through "Part Present" or start of processing cycle (step 330), "Part Complete" or EOC (step 340), "Unload Delay" (step 350) and back to "Load Delay" again. A solid or filled-in circle or small rectangle indicates a bit switched on and an unfilled circle or small rectangle indicates a bit switched off. Referring to Figure 3B, the events shown in Figure 3A are also marked on a time axis 316. Time T0 indicates the start of the cycle, when the "Load Delay" bit 308 is first turned on. The "Load Delay" bit 308 is turned off at time Ti after the built-in delay. When the workpiece is in the workstation, the "Part Present" bit 312 is turned on. This is when the workstation starts processing the workpiece. After the workstation completes processing the workpiece at time T2, the "Part Complete" bit 314 is turned on. The time duration between
Ti and T2 is also generally referred to as "P2PSA" time, or part-to-part stand-alone time. As will be described in great detail later, if the P2PSA time is longer than an ideal cycle time, takt time, the workstation is considered overcycling and the difference between the P2PSA time and the takt time is collected as unit overcycle time. The EOC bit 306 is turned on at T2, for 3 seconds, which provides the end-of-cycle signal 318, or EOC signal. Finally, the "Unload Delay" bit 310 is turned on at T3 and kept on for the duration of a built-in unload delay until T4. The moment T4 also coincides with T0' of the next cycle. The time between the beginning of EOC in neighboring cycles is generally referred to as "P2P" time, or part-to-part time.
[0045] Refer to Figure 3A again. After the previous workpiece has exited, the workstation is now expecting another workpiece to enter. The "Load Delay" bit is turned on, in anticipation of the loading of a new workpiece. However, after a given time delay (may be zero), the workstation may find itself without a new workpiece (step 360) and the "Part Present" bit 312 remains off (step 370). When this happens, the station reports its condition as "starved" and the
Starved bit 302 is turned on. The workstation will remain in this state, i.e., the starved bit 302 will be kept on, until a new workpiece enters the workstation. Similarly, at the end of a cycle the EOC bit 306 is turned on and held on for 3 seconds. If after a built-in unload delay, i.e., after the "Unload Delay" bit is cleared, the completed workpiece cannot exit (step 380) and is still present in the workstation, the station reports its condition as "Blocked" and the Blocked bit 304 is turned on (step 390). The blocked bit 304 will be held on until the workpiece exits the workstation, i.e., until the 'Tart Present" bit 312 is cleared.
[0046] Signals collected by PLCs are explicitly or implicitly associated with time information. A PLC may be programmed to use the time information and accumulate amount of time the workstation spent in starved or blocked state, amount of time the workstation spent between consecutive EOC signals, or may accumulate, i.e., increment a total unit count each time an EOC signal is received to track the total number of workpieces processed. A PLC may also be programmed to perform more complicated calculations. However, although a PLC is programmable, modification of PLC logic to collect additional signals or perform additional calculations in an already operational PLC tends to be discouraged as such modification can be time consuming and may require extensive "proofing" to ensure regular operations are not impacted in any way. Preferably, any calculation and accumulation are left to signal converters
202 for improved performance and reduced implementation costs. Calculation and accumulation of time and count data will be further described in detail later.
[0047] It will be appreciated that although PLCs are described here as the device for collecting signals, it is only because typically PLCs are already installed in an automated facility for collecting signals at each workstation. In most installations, PLCs may already collect the minimally necessary signals required by the system. It is not required that PLCs must be used. Any sensors capable of collecting state and event signals used by the software system 130 can be used in addition to or in place of PLCs.
[0048] OPC servers receive data from PLCs. OPC is a standardized protocol for communicating data between systems in a controlled process and its functionalities. OPC server 218 collects and formats data stored in memory registers of each PLC 122 connected thereto and provides the standardized data to signal converters 202, or RTLEs 204. Typically,
OPC server 218 collects such data by periodically reading memory registers, commonly at a rate of once per second. OPC server 218 stores the read data in its internal memory in a standardized manner along with source information indicating the memory register and asset
102 from which the data was collected. Signal converter 202 is provided the data and source information in the standardized manner, allowing it to properly interpret and process the data collected. OPC server 218 therefore provides a standardized data access interface for data signal converter 202 to request and receive data from memory registers of PLC. Collection and format of data stored in internal memory of OPC server 218 are known to those skilled in the art.
[0049] PLC 122 and/or OPC server 218 can be configured so that the value of a particular memory register causes OPC server 218 to forward the standardized data to signal converters and data collectors. Such data collection is referred to as triggered or unsolicited data collection. Data collected this way may be further analyzed and formatted by RTLEs or data accumulations for storage in database 210. This represents a data "push" model. A signal converter may also "pull" data from OPC server 218. Such requests are typically forwarded to OPC server 218 which collects the appropriate data from its internal memory and returns the collected data to a signal converter 202, again in the standardized format. Such data collection by signal converters is referred to as non-triggered or solicited data collection. Again, signal
converters and data collectors may further analyze and format the data for storage in database 210. Examples of OPC servers, signal converters and data collectors operating together to collect data from PLCs and storing the data in a database are provided in United States Patent No. 6,862,486, which is incorporated herein by reference. [0050] Signal converters 202 receive "raw" data items, such as event and state signals, from sensors or OPC servers and convert them to counter and time data. Each data item includes data retrieved from a memory register indicating a value of a monitored condition of a PLC 122, information regarding the source of the data item (i.e. asset 102) and may also include time information about the data which is provided by OPC server 218. Each of the collected data, or information derived therefrom, is stored as records in one or more tables in database 210. The collected data may be accumulator data such as a number of parts processed by an asset in a time interval (count), or total idle time of a machine during a time interval (time), or the collected data may be incident data, typically having a start time, an end time and a duration. Such data is typically generated when a monitored condition of an asset 102 switches from an "on" status to an "off status or vice versa. Data collected at PLCs and further processed by signal converters are in general explicitly or implicitly associated with a time marker. The time marker associates each record for a data item with either a time interval or a time of recordal. Having independent records with an associated time marker provides flexibility when processing and manipulating the records. Further information, such as a percentage a machine spending in certain states, can also be derived, i.e., computed by the signal converter form basic time and counter data.
[0051] Signals collected at PLCs are forwarded to RTLEs 204 for processing. Generally, a RTLE 204 is programmable and can be used to perform a variety of calculations and logic operations. Its memory, or registers, may also be programmed as timers or counters. RTLEs are generally easier to program than PLCs and are provided to off-load any required programming from a PLC or a group of PLCs connected thereto. As described earlier, a PLC collects at least the starved bit 302, the blocked bit 304 and the EOC bit 306, which are all associated with their respective time information. By tracking the time a starved (or blocked) bit is switched on and off, i.e. correlating the time information with the state signal itself, one can measure (or derive) the amount of time the monitored asset 102 spent in the starved or
blocked state. Similarly, the turning on or off of the EOC bit 306 also allows the RTLE 204 to track the part-to-part cycle time and to generate a signal for accumulating part counts. Time spent between consecutive ends of cycle is measured or calculated to obtain a part-to-part cycle time. Total number of workpieces processed is also incremented each time the workstation is at the end of cycle. Other count data and timing signals such as buffer counts, time of a workpiece entering and exiting the workstation, may also be tracked and computed. The RTLE 204 also tracks a measured cycle time to evaluate overcycle time for each workpiece immediately or shortly after the workstation completes processing the workpiece. The measured cycle time is the time a workstation actually spent processing a workpiece. This is measured by computing, accumulating or tracking the duration between the time the workstation begins processing a workpiece and the time the workstation completes processing the workpiece. Load delays, unload delays and time spent during starved or blocked states are not included in a measured cycle time. The overcycle time, namely the difference between a measured cycle time and an ideal cycle time, is computed and accumulated. The overcycle time is a measure of extra time spent by the workstation to process a workpiece and the measured cycle time represents an overcycled processing time.
[0052] The ideal cycle time is not a measured quantity. Rather, it is a design parameter, representing a designed production or processing rate or expected pace and is often known as "takt" time. Takt time represents a "beat", or fixed pace, at which each workstation in a production line is expected to complete a processing cycle. For smooth, continuous processing, each workstation of a production line is expected to process at this pace and therefore takt time actually represents the "beat" of the production line, not just individual workstations. Each workstation is expected to process a workpiece spending precisely its takt time, no more, nor less. If a workstation spends more time than the ideal cycle time to complete processing a workpiece, it is said to be overcycling. When a workstation overcycles, it slows down the sequential line. The line then can process workpieces at best at the rate of the overcycling workstation. When a workstation overcycles, it also can create starved condition for the immediate downstream workstation and blocked condition for the immediate upstream workstation, which may ripple through the entire line or facility. On the other hand, when a workstation spends less time than the ideal cycle time to complete processing a workpiece, there is a speed-up of the workstation. A speed-up does not necessarily contribute to the
overall productivity of a facility, as other workstations are still operating at or below the expected rate, i.e., spending at least the takt time to complete a workpiece. A speed-up of a workstation actually may cause performance degradation as it may introduce blocked condition downstream into a sequential production line. [0053] Selection of a takt time may take into account the maximum processing capacity of a workstation, the tasks to be completed at a workstation, the part to be processed, and the overall production or processing rate of the line, among others. In particular, takt time is a parameter varying from product to product, or model to model. Takt time data corresponding to different products, models, parts or tasks may be conveniently stored in database 210 or other storage device for retrieval by RTLE 204. When a Model ED signal is also collected, the value of takt time can be automatically adjusted or retrieved.
[0054] Performance or throughput of a workstation can be measured by comparing its cycle time against the ideal cycle time. There is a reduction of throughput when a workstation spends extra time to process a workpiece, i.e., when there is a non-zero overcycle time. What is not evident is that speed-up at any workstation generally does not contribute to a production line's throughput and that its inclusion in the computation of throughput may obscure the source of constraints. To exclude speed-up, overcycle time is set to zero, rather than some computed negative value. The throughput capability measure can be computed from the following formula:
T Throughput capability = eχι>ecteά Q expected overcycle
Here, the total overcycle time, Tovercyde , is the time accumulated from overcycle time spent by a workstation processing individual workpieces over a given accumulation period. rexpected is the total amount of time expected for processing the total number of workpieces during the accumulation period. The sum, rexpected + ^0Vercycie > represents an accumulated overcycled processing time. In one embodiment, a simple formula can be used, which is Expected = ^ units x v a^ Time), where Takt Time is the ideal cycle time and Nunits is the total number of workpieces processed. Further variations of the simple formula (Eq. (I)) is also
possible, wherein any non-zero rovercycle reduces the value of the throughput capability measure.
Conveniently, RTLEs 204 are programmed to compute the throughput capacity for each of the workstations 102.
[0055] RTLEs 204 also analyze time and count data and carry out further computations of other performance related parameters. For example, overall attainment of a workstation (or each production line or the entire facility), a performance indicator, can be computed from a total number of workpieces processed and the total time the workstation has been available (i.e., total lapsed time excluding accumulated downtime). Other quantities that can be computed from the data collected may include jobs per hour (JPH), mean time between failures (MTBF), or mean time to repair (MTTR). Additionally, data received from workstations can be analyzed to obtain overall percentages of accumulated time a workstation spent in a loss state, such as blocked state, starved state, or downtime state, or to categorize overall percentage of losses by categories, such as uptime losses, downtime losses, or speed losses, or any other derived performance indicators. [0056] Data accumulators 206 collect data from RTLEs 204 and passes the collected data to queue manager 220 for insertion into the database 210. A data accumulator may simply pass the collected data to the queue manager, in which case the data accumulator is essentially a transitory storage for holding and buffering the collected data. The buffering helps reducing data loss in case of any network slowdown or latency, when data cannot be written in the database immediately. Further computation or manipulation may also be performed by data accumulators 206. For example, accumulation of time or count may be performed by data accumulators 206. Computation of percentages and other more complicated calculations may also be carried out by data accumulators 206 in principle.
[0057] While in general there is a 1-to-l correspondence between OPC server and RTLE, typically a data accumulator may receive data from several RTLEs, as indicated with dashed lines in Figure 2. Similarly, each queue manager may collect data from several data accumulators. The number of RTLEs a data accumulator can serve is generally determined by loads. Load also generally determines the number of data accumulators a queue manager can serve.
[0058] Queue manager 220 handles data queues and inserts data into the database. Queue manager formats data items collected from data accumulators 206, creating transaction messages, queuing such messages and updating database 210 with the data contained in these messages. Each transaction, for example, an SQL transaction, either creates or updates a record in database 210.
[0059] Data modeling engine 208 provides a platform for the modeling and manipulation of data collected by and received from signal converters 202 and data accumulators 206. It also acts as the platform for web-based applications and as the server that retrieves data from the database 210. [0060] Report module 212 is primarily a reporting tool that is part of or connected to the data modeling engine 208. Report module 212 carries out the necessary calculations using data stored in the database 210 and provides, for example, plant configured reports on constraints, metrics and performance indicators.
[0061] Visual presentation module 214 is primarily responsible for producing display screens for visualizing collected and calculated information. It may provide webportals (not shown) or other visual or graphical display tools for visual presentation of information and data.
[0062] Manual data entry tool 216 is a software module or software tool that allows for manual data collection from plant floor on constraining assets, though it may also provide a user interface for entering other information. Manual data entry tool can also be used to help troubleshoot constraint issues at individual pieces of equipment or processes.
[0063] As will be understood, although the performance monitoring and management software system 130 shown in Figure 2 includes OPC servers, RTLEs, data accumulators, a queue manager and a data modeling engine, among others, these components do not have to reside in a single object or executable computer file, nor do they have to execute on a single computer hardware. For example, there may be a large number of computers, each having a number of RTLEs executed thereon, but only a single, additional computer that hosts the data modeling engine component. Other hardware and software configurations, of course, are also
possible. How to select a suitable hardware and software configuration is mostly an engineering choice.
[0064] As described earlier, signals relating to losses at a workstation, such as "Quality" signal, can be collected at machine level for further processing and analysis. Losses can be categorized in different ways. Conveniently, one way to categorize losses is to categorize them into one of uptime, downtime, speed and quality losses. Each of these four categories highlights potential losses of throughput or first time quality capability at a machine level. These losses can be estimated from other signals, such as starved bit, blocked bit, or can be measured or validated with machine level data, i.e., data collected by PLCs or sensors installed at each workstation, or can be collected manually at each work station. As will be described below, manual entry screens can be provided for accepting user inputs and capturing the relevant information. Conveniently, a graphical user interface presented to users through display and input devices 132 may be employed for this purpose.
[0065] "Uptime losses" generally refer to losses at an asset while the asset is operational, i.e., losses not due to downtime of an asset. Both starved and blocked conditions create losses while the workstation is operational and are therefore also "uptime losses". Other examples include time spent on trial-run of a process (therefore no products produced), operator's lunchtime, change-over of product types, or idle time when there is no demand.
[0066] Time spent by a workstation from the moment a workpiece enters the workstation to the end of the ideal cycle time is referred to as cycling time 406. Spending time longer than takt time but still below a threshold is considered a speed loss 408, i.e., a loss caused by slow down at an asset. The threshold, such as 110% of takt time, is to a large degree arbitrary. This threshold is generally selected by a user and based on the user's experience and knowledge of past performance of the asset. An asset spent time longer than the threshold to complete processing a workpiece is considered to have experienced downtime. Losses attributed to downtime are referred to as "downtime losses", i.e., losses caused by downtime of an asset. ,
When computing downtime losses, however, the entire overcycle time 410, i.e., time between
100% takt time and end of cycle, is included in the calculation. Time spent processing a workpiece that is later discarded or requires reprocessing due to quality failure is categorized as quality loss.
[0067] The following chart shows examples of deriving loss data from signals collected at PLCs and augmenting the derived data with manual entry data. It will be understood that the threshold levels are for illustration only and can be fully adjustable by a user depending on each machine function and cycle time.
[0068] Diagrammatically, Figure 4 shows along a time axis losses that may be measured using signals collected by a PLC. Figure 4 shows starved loss 402 as loss occurred prior to a workpiece entering a workstation. Blocked losses occur after a workpiece is processed but unable to exit from a workstation. Blocked loss 404 is shown as loss occurred after a workpiece is processed, i.e., after end of cycle (EOC). A downtime loss is considered to have occurred if the workstation spends longer than 110% of takt time to process a workpiece. The region between 110% of takt time (the threshold in this case) and end of cycle is marked as downtime region. A speed-loss 408 is when the workstation spends less than 110% of takt time but longer than takt time to process a workpiece. [0069] In operation, the software system 130 receives three basic signal data from PLCs 122, converts the basic signals to time and count data and computes a throughput capability measure for each of the workstations 102 in the facility 100. The computation may be carried out using the expression shown in Equation (1), or a variation thereof. The results are analyzed to identity the constraint. Other signals may also be collected, converted and accumulated, to
facilitate analysis of causes of performance degradation. The results of computation and analysis are displayed graphically to a user for clear identification of constraints and further analysis.
[0070] Figure 5 is a flow chart illustrating a process 500 for quantifying and identifying constraints in an automated manufacturing or processing facility by computing and monitoring a throughput capability measure for each of the workstations. The process 500 involves the following steps:
• automated collection of starved, blocked and EOC signals from workstations in an automated manufacturing and processing facility (step 502) • conversion of collected signals to overcycle time and part count data (step 504)
• accumulation of overcycle time spent in processing each workpiece and accumulation of a total count of workpieces processed over a given period (step 506);
• computation of a throughput capability measure using the accumulated overcycle time and the total number of workpieces processed (step 508); and
• identifying a constraint or constraints (step 510).
[0071] As described earlier, signals collected at step 502 include state signals and event signals that a workstation is starved, blocked, or at the end of cycle. Also implicitly or explicitly collected are time information such as time and duration when these signals are turned on, kept on or turned off. Reason codes or brief description relating to degradation of performance of a workstation may be manually entered. The time an incident occurred may also be captured as a time stamp at the same time information is entered manually.
[0072] Collected signals are converted, i.e., transformed, to time and count data relating to performance of each workstation (step 504). For example, each time the workstation is at the end of cycle, which signals the completion of processing a workpiece, a total count of workpieces processed is incremented. Time spent between consecutive ends of cycle is calculated to obtain a part-to-part cycle time. A cycle time computed from the same workpiece' s entrance time and exit time or accumulated using a timer can be used to compute a
unit overcycle time. When amount of time in starved and blocked states is tracked, the unit overcycle time also excludes the amount of time in starved and blocked states. Similarly, when a workstation has built-in load delay or unload delay, such delays are also excluded from the unit overcycle time. A total overcycle time is accumulated from unit overcycle time of all workpieces processed over an accumulation period (step 506).
[0073] Conveniently, a downtime event trigger is generated if a workstation takes longer than a threshold to process a workpiece. The threshold may be, for example, 110% of takt time, or any suitable percentage of takt time. Any time above the threshold is counted toward the workstation's downtime loss. Of course, some other threshold, such as a value between 110% and 200% (or outside this range if appropriate), may be selected. The total time attributable to a workstation's downtime is accumulated over the accumulation period as well (step 506). By generating an event trigger and accumulating time loss in its specific category, the count and time data can be used to analyze losses in separate categories, which help isolating and identifying causes of low throughput. Other time and counts related to performance degradation, such as scrap loss, speed loss, quality loss, among others, are also accumulated at this step.
[0074] Signal collection and data conversion are further described in reference to Figure 5B. Figure 5B illustrates the processing of three consecutive workpieces by a workstation by plotting along a timeline 520 various time markers associated with monitored state and event signals. Derived state and event signals are also plotted against their own respective timelines.
[0075] Refer to the segment of timeline 520, which illustrates the cycles of a workstation. The segment of timeline 520 in Figure 5B shows only four EOC signals 522. As described earlier, the duration of an EOC signal is arbitrary and is selectable by a user. The end of an EOC signal (or any fixed point of an EOC signal) can be conveniently used to mark the beginning of a cycle. The segment of timeline 520 is divided by these four EOC signals into three sections, labeled as C1, C2 and C3, representing, respectively, the first cycle, the second cycle and the third cycle. At the end of each EOC signal, a workpiece count is generated so that the total number of workpieces processed by a workstation over a given time period can be accumulated. Also converted and accumulated in each cycle are the other two basic signals,
namely blocked signal and starved signal, and other time and count signals such as P2PSA signal, downtime loss count etc.
[0076] Consider the first cycle, C1. The cycle begins at time T0. After a built-in "Load Delay", or TLD, the workstation anticipates that a workpiece will be loaded and that the "Part Present" bit 312 will be turned on. However, in the cycle illustrated, the workpiece is not loaded until a time Ts later. Here, the time Ts represents a starved period. The workpiece is loaded at time T1 and processing of the workpiece begins. The processing is completed at time T2. The duration (T2 - T1) is the part-to-part stand-alone time, or P2PSA time. In this cycle, the P2PS A time is longer than takt time, the ideal cycle time. Therefore, there is overcycle and the overcycle time during Cj is non-zero. More precisely, the overcycle time is (P2PSA - takt). After the processing of the workpiece is completed, the workstation expects the workpiece to be unloaded within a built-in unload delay and to exit the workstation. However, in this cycle, the workstation is unable to unload the completed workpiece within the unload delay, TUD, because the workstation is blocked. The workpiece is unloaded only after TB, the duration when the workstation is blocked. The "Blocked" bit 304 is cleared at the moment T3 when the workpiece is unloaded. The EOC signal is also generated to signal the beginning of the next cycle, which begins at T4, or T0'. This example should be contrasted to that shown in Figure 3B, which depicts workstations with built-in load and unload delays but does not show any blocked nor starved conditions. It should also be noted that P2PSA time shown in this example is a measured cycle time.
[0077] Along a P2PSA timeline 524, a P2PSA signal 526 is plotted, corresponding to the duration between Ti and T2. This signal can be generated by accumulating the time using a timer from the moment T1 to the moment T2 when the signal is switched off, or can be calculated by computing the difference between the recorded time values of T1 and T2. Similarly, along a Blocked signal timeline 528, a Blocked signal 530 is plotted, corresponding to the duration TB, when the workstation is blocked. Preferably, or if desired, a blocked count signal can also be generated each time a Blocked signal is switched on so that the total number of occurrences of blocked condition can be tracked and analyzed. Likewise, along a Starved signal timeline 532, a starved signal 534 is plotted, corresponding to the duration Ts, when the
workstation is starved. A starved count signal can be generated each time the Starved signal is switched on to track the total number of occurrences of starved conditions.
[0078] Similarly, along a Overcycle signal timeline 536, an overcycle signal 538 is plotted, corresponding to the time period between T2 and takt time, when the workstation is overcycling. An overcycle count signal can also be generated each time the overcycle signal is switched on. As described earlier, when a workstation takes longer than takt time to process a workpiece, the loss can be categorized into two types: speed loss if the workstation takes longer than takt time but shorter than a threshold, or downtime loss if the workstation takes longer than the threshold to process the workpiece. A separate count signal indicating an occurrence of either a speed loss or a downtime loss can be conveniently generated, based on whether the P2PSA time is longer or shorter than the threshold, usually expressed as a percentage (e.g., 110%) of the takt time.
[0079] The cycle C2 illustrates the next cycle, i.e., the processing of the next workpiece, in which the workstation is not starved nor blocked and the workstation spends less than takt time to complete processing the workpiece. Along the P2PSA timeline 524, a P2PSA signal is plotted, corresponding to the actual time the workstation spends to process the workpiece. On each of the Blocked signal timeline 528, the Starved signal timeline 532 and the Overcycle signal timeline 536, only a spike 540 is plotted, indicating that the duration the workstation is blocked, starved and overcycling, respectively, is zero. It should be noted that because the workstation spends less than the takt time to complete processing the workpiece, there is a speed-up. However, this speed-up is excluded from the calculation and the overcycle time is set to zero.
[0080] The cycle C3 illustrates a cycle in which the workstation is starved and blocked but spends exactly the takt time to complete processing the workpiece. Non-zero blocked time and non-zero starved time are plotted on the Blocked signal timeline 528 and Starved signal timeline 532, but on the Overcycle signal timeline 536 there is only a spike to indicate that there is no overcycle time during this cycle.
[0081] When the time and count data are converted from raw signals received from a PLC, the time and count data are accumulated. For example, the P2PSA time is accumulated to obtain an accumulated P2PSA time over an accumulation period. The workpiece count data is
accumulated to obtain a total count of workpieces processed during the accumulation period. The blocked time, starved time, overcycle time, total occurrences of speed loss, downtime loss etc. can all be accumulated. Here, the accumulation of time and count data can be carried out using special purpose counters or calculated from stored signal data along with their respective time information. For example, the P2PSA time can be accumulated by turning on a P2PSA timer each time the P2PSA signal comes on and switching off the P2PSA timer when the P2PSA signal subsequently is turned off. The value accumulated by the P2PSA timer will be the accumulated P2PSA time. On the other hand, a P2PSA time also can be computed for each cycle from the formula (T2 - Ti) and an accumulated P2PSA time can be found by summing the P2PSA time from all cycles over the accumulation period. Obviously, any variation, using any combinations of timer accumulation and calculation of time values can be used to obtain the accumulated P2PSA time. Other accumulated time values and accumulated count values can also be similarly obtained either by using timers or counters, or from calculations using the converted and recorded signal data, or using a combination of timers, counters and calculations. [0082] As will be appreciated, although signal collection and data conversion are described here as two steps, they may be performed by a single piece of hardware or a combination of hardware and software. For example, a PLC can perform signal collection and part of data conversion, or a PLC or a set of sensors can be used for nothing but collecting signals and offload all of data conversion to RTLE. In other words, a time and count signal converter may be implemented as a RTLE, part of a PLC or a combination of a RTLE and a PLC, among others.
[0083] The throughput capability measure is computed from the formula at step 508, for example, using the formula shown in Equation (1). The throughput indicator, or the throughput capability measure, is calculated and updated almost in real-time, as each workpiece is being processed by the workstation or shortly thereafter. However, the value of the indicator itself reflects the behavior of a workstation over a long accumulation period, typically days, weeks or even months, over which each workstation's unit overcycling time is accumulated. In other words, the calculation of the throughput capability itself is historical in nature.
[0084] Once a throughput capability measure is obtained for each of the workstations 102, the results can be displayed graphically to clearly show the performance of each workstation. The results can also be analyzed to identify a constraint (step 510). Different criteria can be
used for identifying a constraint using the computed throughput capability measures. A criteria is generally pre-selected by a user from a pool of suitable criteria or may be directly entered by a user. For example, a constraint can be identified as a workstation that has the lowest throughput capability measure among all workstations in the production line. [0085] Conveniently, results of the throughput analysis are presented to users graphically on a computer monitor 132. Figure 6 shows a graphical representation 600 of two production lines (Line 1 and Line 2) linked sequentially together. Each production line has a number of workstation icons 602, representing sequentially linked workstations. A throughput capability measure corresponding to each workstation is displayed numerically inside the workstation's icon 602. The icons may also be color coded to indicate if the workstation is operating at or near maximum capacity, at reduced capacity, or is considered a constraint. For example, the constraint, having the lowest throughput capability, may be colored red. The next group of workstations, having the next lowest throughput capability, are colored yellow. The remaining workstations may be represented by icons colored green. Between each production line is a buffer icon 604, showing the percentage the buffer is full (right half 606 showing the present value; left half 608 showing the average value over the accumulation period). A starved icon 610, a circle to the left of each production line, indicates the percentage of capacity loss due to starved conditions at the input point of a production line. A blocked icon 612, the triangle to the right of each production line, indicates the percentage of capacity loss due to the blocked conditions at the exit point of the production line.
[0086] Preferably, throughput capability measures of all workstations in a facility 100 is presented using a throughput capability and balance map. Figure 7 is an exemplary throughput capability and balance map 700. It shows a plurality of production lines linked in sequential and parallel fashions. The throughput capability and balance map 700 shown in Figure 7 provides a concise and clear view of performances of all automated assets 102 in a facility 100.
[0087] The map 700 represents six production lines 702, Lines A to E and Line I. The output of Line A is supplied to Line B as input, in a sequential link. The output of Line C is supplied to Line D as its input. The outputs of Lines B, D, E are all provided to Line I, which are processed and combined by Line I5 as products at the exist point of Line I. In addition to throughput capability measures, starved and blocked losses, and buffer level, the map 700 also
displays numerically additional performance indicators, such as attainment 704, FTQ 706 (first time quality) and OEE 708 (overall equipment efficiency). Of course, where desirable, other performance indicators measuring the performance of the entire facility, such as JPH, MTBF, or MTTR, may also be displayed on the map 700. [0088] The map 700 may also provide actuatable regions (or "clickable areas") allowing a user to drill down, i.e., to request and display more detailed information about a workstation. Any icons corresponding to a workstation, a buffer, an input point or an exit point, such as a workstation icon 602, may be rendered "clickable". A user may "click" an icon using a computer pointing device to bring up another screen which provides more detailed information than the simple numerical value displayed in the icon. Further drill-down may be provided so that each screen activated by clicking an icon may have on it additional actuatable regions for displaying even more detailed information, and so on.
[0089] Figure 8 is an exemplary screen showing detailed information relating to different categories of losses. This screen may be displayed by actuating one of the workstation icons 602. The screen has four separate loss information regions 802, each for a type of loss. Each loss information region 802 provides details related to that type of loss. For example, in the speed loss region 804, displayed are details such as total overcycle time, total number of equivalent workpieces lost due to speed loss over the accumulation period, the total number of occurrences in which a workpiece experience overcycle, etc. Further drill-down, such as a breakdown of cycle time 806, or cycle time details 808, can be requested through actuatable regions, or clickable buttons, in the speed loss region 804. The screen 800 also provides tabs such as OEE tab 810, Cycle Breakdown tab 812, for accessing other types of detailed information. It will be appreciated that the content of the detailed information as well as the type of detailed information are not restricted to what are shown in Figure 8 and may be any that are suitable or desirable according to a specific application or user requirements. Figure 9 is another exemplary screen display showing detailed information related to OEE.
[0090] As mentioned earlier, the system also allows a user such as a floor operator to enter detailed description manually. Manually entered information may include description of slowdown or downtime of a workstation, "reason" code for conditions that cause a loss, among others. Figure 10 is one such exemplary screen display. The screen has data entry region 1002
and a form window 1004. Conveniently, an operator only needs to enter the quantity of workpieces that are discarded for quality defects and select a reason code from a pull-down menu 1006. Where appropriate, a brief comment may also be entered in the "Comment" box 1008. Once the "Submit" button 1010 is clicked, the input received from the operator will be recorded, together with a "record time" that can be automatically retrieved from the system and recorded. This new entry can also be displayed in a form window 1004 below the data entry region 1002 for review and correction, if necessary. This allows the generation of statistics of reasons or reason codes corresponding to causes of losses or performance degradation.
[0091] Figure 11 is an exemplary screen display that shows the statistics of quality losses over the monitored period. The screen display has a text region 1102 and a graph region 1104. Numerical results as well as textural information are displayed in the text region 1102. The information displayed may include the time the information was entered, the quantity of loss due to a particular reason or having a particular reason code, as well as a description of a reason code. The graph region 1104 is used for displaying a suitable graph 1106 showing the results of the statistical analysis. The graph 1106 may be a histogram graph, a line graph, a bar chart, among others. A histogram graph is shown in Figure 11, together with legends 1108 showing the reason codes and their brief description. As the chart and the graph show, one reason code corresponds to the majority one of the losses, this screen helps to identify one area that may significantly improve the throughput. [0092] Various embodiments of the invention have now been described in detail. Those skilled in the art will appreciate that numerous modifications, adaptations and variations may be made to the embodiments without departing from the scope of the invention. Since changes in and or additions to the above-described best mode may be made without departing from the nature, spirit or scope of the invention, the invention is not to be limited to those details but only by the appended claims.