Inventory Management System Using Image Processing of Codes on Shelving and Storage Bins

- DeRoyal Industries, Inc.

An apparatus for monitoring and replenishing an inventory of goods includes a first inventory area and a first movable structure having a first optical code associated with the first distinct inventory area. The first movable structure is placed in a replenishment signaling area after a supply of goods in the inventory area has been depleted. Boundary optical codes are disposed near a boundary of the replenishment signaling area. A camera generates periodic images of the replenishment signaling area and the boundary optical codes. A computer processor detects the boundary optical codes in the images and determines a boundary line of the replenishment signaling area based thereon. The processor determines a spatial relationship between the first optical code and the boundary line in the images and generates a replenishment notification based on the spatial relationship. The replenishment notification indicates that the supply of the first type of goods needs to be replenished.

Skip to: Description  ·  Claims  · Patent History  ·  Patent History
Description
FIELD

This invention relates to the field of inventory management. More particularly, this invention relates to processing images of codes on shelving units and storage bins in a Kanban inventory management system.

BACKGROUND

In the context of this application, Kanban refers to a means of supporting pull-based replenishment in an inventory management system. Kanban (pronounced “Kahn-Bahn”) is a Japanese term for “signal,” such as an inventory replenishment signal. Generally, Kanban systems are used to manage the supply of low-to-medium cost inventory items that have relatively constant demand, so as to reduce the chance of running out of such supplies. It also creates FIFO (First In, First Out) for inventory to help avoid expired supplies. Traditional Kanban requires staff labor to conduct either a physical count or a visual order, or to manually place a paper Kanban card into a reorder bin, or to move an empty bin from a lower shelf on a shelving unit to the top shelf or other location to trigger a replenishment signal.

What is needed is a system that can provide a complete, imaging-based inventory management solution that employs the Kanban methodology while reducing the need for human interaction in the system.

SUMMARY

The above and other needs are met by an apparatus for monitoring and replenishing an inventory of goods disposed within an inventory storage space. The apparatus includes a first distinct inventory area within the inventory storage space that is configured to store a supply of a first type of goods. A first optical code is disposed on a first movable structure associated with the first distinct inventory area. The first optical code encodes a first unique identification number that identifies the first type of goods. The apparatus also includes a replenishment signaling area configured to receive the first movable structure that is placed there after the supply of the first type of goods stored in the first distinct inventory area has been depleted. One or more boundary optical codes are disposed adjacent to a boundary of the replenishment signaling area.

The apparatus also includes one or more cameras that each have a field of view at least partially encompassing the replenishment signaling area and the boundary optical codes. The one or more cameras generate periodic images of the replenishment signaling area and the boundary optical codes. One or more processors execute programmed instructions to detect the boundary optical codes that are present within the images and to determine location coordinates of the detected boundary optical codes. A boundary line associated with the boundary of the replenishment signaling area is determined based on the location coordinates of the boundary optical codes. The first optical code is detected within the images and the location coordinates of the first optical code are determined. Based on the location coordinates of the first optical code, a spatial relationship between the location of the first optical code and the boundary line is determined. A replenishment notification is generated based at least in part on the spatial relationship between the location of the first optical code and the boundary line. The replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished.

In some embodiments, the apparatus includes a multi-shelf shelving unit having a top shelf that serves as the replenishment signaling area. In these embodiments, the boundary optical codes include a first boundary optical code disposed adjacent to a first end of the top shelf, and a second boundary optical code disposed adjacent to a second end of the top shelf opposing the first end. The one or more processors execute the programmed instructions to determine the boundary line to coincide with the location coordinates of the first and second boundary optical codes, and to generate the replenishment notification based at least in part on the location of the first optical code being above the boundary line.

In some embodiments, the first movable structure comprises a first bin, and the first optical code is attached to the first bin and is within the field of view of the one or more cameras, and the first distinct inventory area is disposed within the first bin.

In some embodiments, the first movable structure comprises a bookend, and the first optical code is attached to the bookend and is within the field of view of the one or more cameras, and the first distinct inventory area comprises a portion of a lower shelf of the multi-shelf shelving unit that is below the top shelf.

In some embodiments, the first distinct inventory area comprises a first portion of a shelf of a multi-shelf shelving unit, and the replenishment signaling area comprises a second portion of the shelf, wherein the boundary of the replenishment signaling area is disposed between the first and second portions of the shelf. In these embodiments, the one or more boundary optical codes comprise a first boundary optical code disposed on an upper portion of the shelving unit and a second boundary optical code disposed on a lower portion of the shelving unit. The one or more processors execute the programmed instructions to determine the boundary line associated with the boundary to coincide with the location coordinates of the first and second boundary optical codes and generate the replenishment notification based at least in part on the location of the first optical code being offset to one side of the boundary line which indicates that the first optical code is within the replenishment signaling area.

In some embodiments, the one or more processors execute the programmed instructions to determine the boundary line to comprise a horizontal line, a vertical line, a diagonal line, a curved line, or a line forming a closed shape.

In some embodiments, the one or more processors execute the programmed instructions to determine the boundary line as intersecting the location coordinates of the one or more boundary optical codes.

In some embodiments, the first optical code and the one or more boundary optical codes comprise QR codes or barcodes.

In some embodiments, the one or more cameras comprise a camera mounted on a ceiling, a camera mounted on a horizontal or vertical track system, an infrared camera, or a camera having remotely-adjustable zoom, tilt and pan.

In some embodiments, at least one of the processors is disposed in the inventory storage space.

In some embodiments, at least one of the processors is a cloud-based server that is in communication with a processor disposed in the inventory storage space via a communication network.

In some embodiments, the one or more processors execute the programmed instructions to decode the first optical code to determine the first unique identification number that identifies the first type of goods, and to generate the replenishment notification to include the first unique identification number.

In some embodiments, the one or more processors execute the programmed instructions to maintain a state machine representing a plurality of states of the first distinct inventory area. The plurality of states include:

    • a first state in which the first optical code is not in the replenishment signaling area;
    • a second state in which the first optical code is in the replenishment signaling area; and
    • a third state in which an order has been placed or is to be placed to replenish the supply of the first type of goods in the first distinct inventory area.

The execution of the programmed instructions causes:

    • a transition from the first state to the second state based on detecting the first optical code in the replenishment signaling area;
    • a transition from the second state to the third state and generation of a replenishment notification in association with the transition from the second state to the third state, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished; and
    • a transition from the third state to the first state based on not detecting the first optical code in the replenishment signaling area for at least a predetermined period of time.

In another aspect, the invention provides a method for monitoring and replenishing an inventory of goods disposed within an inventory storage space. In a preferred embodiment, the method includes:

    • designating a first distinct inventory area within the inventory storage space that is configured to store a supply of a first type of goods;
    • providing a first movable structure associated with the first distinct inventory area, wherein the first movable structure has a first optical code that encodes a first unique identification number that identifies the first type of goods;
    • designating a replenishment signaling area within the inventory storage space that is configured to receive the first movable structure;
    • placing the first movable structure into the replenishment signaling area after the supply of the first type of goods stored in the first distinct inventory area has been depleted;
    • providing one or more boundary optical codes adjacent to a boundary of the replenishment signaling area;
    • periodically generating optical images that encompass the replenishment signaling area and the boundary optical codes;
    • executing programmed instructions on one or more processors to detect the boundary optical codes present within the images;
    • executing programmed instructions to determine location coordinates of the boundary optical codes detected within the images;
    • executing programmed instructions to determine a boundary line associated with the boundary of the replenishment signaling area based on the location coordinates of the boundary optical codes;
    • executing programmed instructions to detect the first optical code present within the images;
    • executing programmed instructions to determine location coordinates of the first optical code detected within the images;
    • executing programmed instructions to determine a spatial relationship between a location of the first optical code and the boundary line based on the location coordinates of the first optical code; and
    • executing programmed instructions to generate a replenishment notification based at least in part on the spatial relationship between the location of the first optical code and the boundary line, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished.

In yet another aspect, the invention provides an apparatus for monitoring and replenishing an inventory of goods disposed within an inventory storage space. The apparatus includes a first distinct inventory area within the inventory storage space that is configured to store a supply of a first type of goods. A first electronically detectable element is disposed on a first movable structure associated with the first distinct inventory area. The first electronically detectable element encodes a first unique identification number that identifies the first type of goods. A replenishment signaling area is disposed within the inventory storage space and is configured to receive the first movable structure that is placed therein after the supply of the first type of goods stored in the first distinct inventory area has been depleted. One or more detectors associated with the replenishment signaling area are configured to detect the first electronically detectable element. One or more processors, which are in electrical communication with the one or more detectors, are operable to execute programmed instructions to maintain a state machine representing a plurality of states of the first distinct inventory area. The plurality of states include a first state in which the first electronically detectable element is not in the replenishment signaling area, a second state in which the first electronically detectable element is in the replenishment signaling area, and a third state in which an order has been placed or is to be placed to replenish the supply of the first type of goods in the first distinct inventory area. Execution of the programmed instructions causes:

    • a transition from the first state to the second state based on the one or more detectors detecting the first electronically detectable element in the replenishment signaling area;
    • a transition from the second state to the third state and generation of a replenishment notification in association with the transition from the second state to the third state, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished; and
    • a transition from the third state to the first state based on the one or more detectors in the replenishment signaling area not detecting the first electronically detectable element in the replenishment signaling area for at least a predetermined period of time.

In some embodiments, the apparatus includes a multi-shelf shelving unit disposed within the inventory storage space, wherein the replenishment signaling area comprises a top shelf of the multi-shelf shelving unit.

In some embodiments, the first movable structure comprises a first bin, the first electronically detectable element is attached to the first bin, and the first distinct inventory area is disposed within the first bin.

In some embodiments, the first movable structure comprises a bookend, the first electronically detectable element is attached to the bookend, and the first distinct inventory area comprises a portion of a lower shelf of the multi-shelf shelving unit that is below the top shelf.

In some embodiments, the apparatus includes a multi-shelf shelving unit disposed within the inventory storage space, the first distinct inventory area comprises a first portion of a shelf of the multi-shelf shelving unit, and the replenishment signaling area comprises a second portion of the shelf of the multi-shelf shelving unit.

In some embodiments, the first electronically detectable element comprises a QR code, a barcode, or an RFID tag.

In some embodiments, the one or more detectors comprise one or more cameras or one or more RFID tag readers.

In some embodiments, the one or more processors execute the programmed instructions to decode the first electronically detectable element to determine the first unique identification number that identifies the first type of goods, and to generate the replenishment notification to include the first unique identification number.

BRIEF DESCRIPTION OF THE DRAWINGS

Other embodiments of the invention will become apparent by reference to the detailed description in conjunction with the figures, wherein elements are not to scale so as to show the details more clearly, wherein like reference numbers indicate like elements throughout the several views, and wherein:

FIGS. 1 and 2 depict a physical configuration of an inventory management system according to an embodiment of the invention;

FIGS. 3 and 4 depict block diagrams of an inventory management system according to embodiments of the invention;

FIG. 5 depicts a physical configuration of an inventory management system according to an embodiment of the invention;

FIG. 6 depicts a state machine of an inventory management system according to an embodiment of the invention;

FIGS. 7A, 7B and 7C depict a physical configuration of an inventory management system according to an embodiment of the invention;

FIG. 8 depicts a physical configuration of an inventory management system according to an alternative embodiment of the invention; and

FIG. 9 depicts a normal two-dimensional algebraic coordinate system compared with a two-dimensional image pixel coordinate system.

DETAILED DESCRIPTION

As shown in FIGS. 1 and 2, an inventory management system 10 includes an inventory shelving unit 12 having multiple shelves 12a, 12b, 12c on which bins 14a, 14b, 14c, 14d are placed for holding inventory items in an inventory room. An end view of the shelving unit 12 is depicted in FIG. 1 and a front view is depicted in FIG. 2. It will be appreciated that the shelving unit 12 may include fewer or more than the number of shelves depicted in FIGS. 1 and 2.

A storage bin, such as the bins 14a-14d, is one example of a distinct inventory area in which inventory may be stored while awaiting use. A portion of a shelf is another example of a distinct inventory area.

In one version of a Kanban inventory replenishment system, bins that contain inventory items are kept on the lower shelves, such as shelves 12b and 12c, whereas the top shelf 12a is reserved for the placement of empty bins. The placement of an empty bin on the top shelf is a “signal” that replenishment of inventory is needed. In conventional Kanban systems, prompted by this signal, a person responsible for maintaining the stock of supplies in the inventory room would take action to reorder or otherwise obtain resupply of the items associated with an empty bin placed on the top shelf. In such prior systems, the responsible person would have to take some manual action to initiate the reorder/resupply process.

The top shelf of a shelving unit is one example of the replenishment signaling area in which the placement of an optically encoded structure causes generation of a replenishment signal. This area is also referred to herein as a “landing zone.” It will be appreciated that another area besides the top shelf of a shelving unit may be designated as the replenishment signaling area. For example, a left or right portion of any of the shelves of the shelving unit may be so designated, or a separate structure altogether may be so designated, such as a table, countertop, or cart.

In a preferred embodiment of the present disclosure, one or more cameras 16 are mounted to the ceiling or other mounting structure within an inventory storage room in which the shelving unit 12 is located. Preferably, each camera 16 is positioned such that it has a field of view that encompasses all or a portion of the shelves 12a-12c of the unit 12, such as the view depicted in FIG. 2. The positioning of each camera 16 should take into account the distance and the angle of the camera 16 with respect to the shelving unit 12. In some embodiments, the field of view of at least one camera 16 may encompass only the top shelf 12a. In some embodiments, one or more of the cameras 16 are mounted on a horizontal and/or vertical track system that provides for moving the position of the camera(s) 16 with respect to one or more shelving units 12. This enables the system to image more shelving space with fewer cameras. In some embodiments, one or more of the cameras 16 include infrared capabilities for operating in low light conditions. In some embodiments, one or more of the cameras 16 may include other features such as remotely-adjustable zoom, tilt and pan.

Each camera 16 is in communication with a processor 20 that is operable to periodically capture images corresponding to the camera's field of view. The connection between the camera(s) 16 and the processor 20 may be wired or wireless, such as via a communication network. In a preferred embodiment, each captured image comprises a rectangular grid of x number of pixels by y number of pixels. The captured image is of sufficient quality and resolution to allow processing of the image to extract optical codes therefrom reliably and accurately.

As shown in FIG. 2, each bin 14a-14d includes an electronically detectable element, such as an optical code 18a-18d, disposed on a visible portion of the bin. In some embodiments, the optical codes 18a-18d are QR codes or bar codes. In an alternative embodiment, the electronically detectable elements are RFID tags attached to the bins. In the RFID embodiment, RFID readers are employed to detect and decode information encoded in the tags.

In a preferred embodiment, each bin code encodes a unique identification number identifying a particular supply item in an associative inventory database 24 that resides on a cloud-based server 26, such as depicted in FIGS. 3 and 4. If the field of view of the camera 16 is properly aligned with the shelving unit 12, and the bins are properly placed so that the bin codes 18a-18d are within the camera's field of view, images captured by the processor 20 will include the bin codes 18a-18d attached to the bins 14a-14d. Image processing software 22 processes the pixels in each captured image to find and decode the bin codes 18a-18d present therein. One example of such software 22 is barcode scanner software from Dynamsoft that is operable to detect multiple codes in a single image.

In a preferred embodiment, it is desirable to determine, based on one or more captured images, whether a bin has been placed on the top shelf 12a. For example, in the image depicted in FIG. 2, the image processing software 22 should identify four bin codes 18a, 18b, 18c, 18d, extract the encoded unique identification number for each, and assign an x-y coordinate location to each code based on x-y coordinates of image pixels associated with each of the codes.

In order to determine if any bins are on the top shelf 12a, it must first be determined where the top shelf is in relation to the locations of the bin codes 18a-18d detected in the image. In preferred embodiments, the top shelf 12a is identifiable in the captured image based on one or more optical top shelf codes attached to a forward-facing surface of the top shelf 12a. In a most preferred embodiment, there are two top shelf codes: a top shelf code 28L disposed at the left end of the top shelf 12a and a top shelf code 28R disposed at the right end, as shown in FIG. 2. The image processing software 22 identifies the left and right top shelf codes 28L and 28R and assigns a reference x-y coordinate location to each identified code based on x-y coordinates of image pixels associated with each of the top shelf codes 28L and 28R. For example, coordinates x=0, y=0 may be assigned to top shelf code 28L and coordinates x=48, y=0 may be assigned to top shelf code 28R. The equation of a straight line is y=mx+b, where m is the slope and b is the y-intercept. In this case wherein m=0 and b=0, the equation of a line through the locations of the top shelf codes 28L (x=0, y=0) and 28R (x=48, y=0) is simply y=0. In this example, any bin code having location coordinates in which the y coordinate component is a non-zero positive number is above the boundary line and thus above the top shelf 12a.

Now consider an example such as depicted in FIG. 5 in which the camera 16 is tilted with respect to the shelving unit 12 (or the shelving unit 12 is tilted with respect to the camera 16). Again, the image processing software 22 identifies the left and right top shelf codes 28L and 28R and assigns location x-y coordinates to each identified code based on x-y coordinates of image pixels associated with each of the codes 28L and 28R. For example, coordinates x=0, y=0 may be assigned to top shelf code 28L and coordinates x=46, y=8 may be assigned to top shelf code 28R. In this case, the slope m=8÷46=0.174, and the y-intercept b=zero, in which case the equation of the boundary line passing through the top shelf codes 28L and 28R is:

y = mx + b , y = 0.174 x + 0 , y = 0.174 x .

In this example, if a bin code has location coordinates defining a point that is above the boundary line passing through the top shelf codes 28L and 28R as defined by the equation y=0.174x, the location of the bin code is above the top shelf 12a. In other words, a bin code is located above the top shelf 12a if the shortest distance between the location of the bin code and the boundary line passing through the top shelf codes 28L and 28R is a non-zero positive number.

Determining whether the bin code is located above or below the top shelf 12a may be done as follows. Given a line y=mx+b and a point (x3, y3) at which the bin code is located, substitute the point's x value (i.e., x3) into the equation of the line (i.e., y=m×x3+b) and solve for y. The relationship between the point's y value (i.e., y3) and the y value (computed in the preceding step) determines whether the point is above or below the line.

It will be appreciated that the relationship condition (y3>y or y3<y) is determined based on the location of the origin. As depicted in FIG. 9, in normal algebra in the positive quadrant (Quadrant I), the origin is in the bottom left. In image processing, the origin is frequently in the top left, such that lower y values are above higher y values. In normal algebra, higher y values are above lower y values.

In a preferred embodiment, the following programming code is used for the above-described calculations.

private static bool Is Above Line (double x1, double y1, double x2, double y2, double x3, double y3)

{  // slope of the line  double m = (y2 − y1) / (x2 − x1);  // y-intercept of the line  double b = y1 − (m * x1);  // y-coordinate of the point when plugged into the equation of the line  double y = (m * x3) + b;  // check if the point is above or below the line  if (y3 > y)  {   return false;  }  else  {   return true;  } }

In some embodiments, if only one of the shelf top codes 28L and 28R is detected in the image, the top right and top left points of the code can be used to construct a boundary line corresponding to the position of the top shelf 12a. In some embodiments, unique identification information encoded in the top shelf codes is used to identify the shelving unit 12 and its location within an inventory room or storage facility.

In some embodiments the top shelf codes may also be used to confirm the camera 16 is working properly, and to tune the camera setup, such as by adjusting the focus, zoom level, tilt angle, and other settings. This setup operation may also include computing an estimated distance to each of the top shelf codes.

In some embodiments, a light source is included to illuminate the replenishment signaling area in which empty bins should be placed on the top shelf 12a. Alternatively, LEDs may be attached to the top shelf 12a to indicate the location of the landing zone.

In the embodiment of the system 10 depicted in FIG. 3, the image processing software runs on the processor 20 connected to the one or more cameras 16. The connection between the one or more cameras 16 and the processor 20 may be wired or wireless. In the embodiment of FIG. 3, the data transferred from the processor 20 across the communication network to the cloud-based server 26 generally comprises non-image data, such as product identification numbers and location coordinates associated with bin codes. The data in this case would be on the order of a few bytes per shelf. In an alternative embodiment depicted in FIG. 4, the image processing software runs on the cloud-based server 26. In this embodiment, the data transferred from the processor 20 across the communication network to the cloud-based server 26 comprises image data captured by the one or more cameras 16. The data in this case would be on the order of hundreds of kilobytes per shelf, and will vary depending on the type of the camera(s) 16 employed.

According to various embodiments, images are pulled from the camera 16 or are pushed from the camera 16 to the processor 20 or to the cloud-based server 26. Images may be pulled one at a time or pulled in various parallel processing configurations. In some embodiments, image processing and enhancing mechanisms may be utilized to improve the accuracy of the system 10, such as focus shifting, image stacking, etc.

The system described herein can also be used in situations in which there are two or more distinct inventory areas on a shelf for each product, and each of the inventory areas include an optically encoded element that may be placed on the top shelf when stock in the corresponding inventory area is depleted. For example, some inventory items are not compatible with placement in bins due to their size or shape. In those situations, the inventory items may be placed within distinct inventory areas on the shelf, along with an optically encoded “bookend,” card, sliding panel, or other structure that identifies each of the distinct inventory areas.

FIGS. 7A-7C depict a shelving unit 12 that includes two distinct inventory areas 12b1 and 12b2 of shelf 12b for holding the same type of product, and two bookend codes 32 each associated with a corresponding one of the inventory areas. As shown in FIG. 7A, when both distinct inventory areas contain stock of the product, both bookend codes 32 are placed on one side, and stock is accessed from the other side until it is depleted. As shown in FIG. 7B, when stock of the product in area 12b2 has been depleted, one of the bookend codes 32 is placed on the top shelf 12a as a replenishment signal and the other bookend code 32 is placed within the depleted area 12b2. As shown in FIG. 7C, when stock of the product in area 12b1 has also been depleted, both of the bookend codes 32 are placed on the top shelf 12a. Thus, the bookend codes 32 of this embodiment provide the same replenishment signal function in the resupply process as the bin codes of other embodiments.

In an alternative embodiment, a coded element may automatically become visible on the top shelf 12a when a user does something to indicate a distinct inventory area is empty. For example, moving a sliding panel from covering one distinct inventory area to covering another distinct inventory area could cause a coded card on the top shelf 12a to move from a horizontal position to a vertical position so as to become visible to the camera 16.

Some embodiments include features that enhance the readability of an optical code so that the image processing software 22 will have a higher rate of success in detecting and properly decoding a code within an image being processed. These features may include one or more of:

    • using less reflective label stock on which the optical codes are printed;
    • using less reflective ink for printing the optical codes;
    • using a lower density code;
    • using a larger code size;
    • providing more white space around the code;
    • using infrared responsive ink to improve detection in low light conditions;
    • providing a protective coating over the printed code to extend its life;
    • using a protective coating that is less reflective so as to not interfere with image processing.

In all Kanban inventory systems (manual, semi-manual, or automated), a common problem is double ordering. Double ordering occurs when the event that triggered the order triggers the order a second time. For example, consider the following semi-manual scenario.

    • 1. An empty bin is placed on the top shelf.
    • 2. A user scans each bin on the top shelf using a handheld scanner which generates 15 orders for the needed supplies.
    • 3. A few hours later, 14 of the 15 ordered supplies are brought to the room, and 14 of the 15 bins are restocked and put back on lower shelves. One of the 15 bins is left on the top shelf.
    • 4. The next day, a user scans each bin on the top shelf using a handheld scanner which generates an order. Because the bin from the previous day is still on top, a second order is generated for that bin.
    • 5. The next day, both orders are filled resulting in twice as many of the supplies being delivered to the inventory location.

Another example involves an automated Kanban system having high-frequency (HF) RFID cards attached to each bin. The HF RFID cards have a very short reading range (i.e., a few inches). When a bin is empty, a user removes the card from the bin and places the card on a board that is equipped with an HF RFID reader. Once a day an order is generated for any supplies for which corresponding HF RFID cards are on the board. Consider the following scenario involving such a system.

    • 1. A user puts a card from an empty bin on the board at 3 pm on Monday.
    • 2. An order for the supplies associated with the card is generated at 6 pm Monday.
    • 3. The supplies are received at 10 am Tuesday.
    • 4. The user restocks the bin but forgets to remove the card from the board.
    • 5. Another order is generated at 6 pm Tuesday because the card is still on the board.
    • 6. The supplies are received at 10 am Wednesday resulting in overstocking of the supplies associated with the card that was inadvertently left on the board.

The key to avoiding such problems is to know the state of each bin. Otherwise, if a bin is left on the top shelf (or an RFID card is left on the board) through multiple order cycles, orders will be generated each time.

In a preferred embodiment of the system 10, three possible states are always known for each distinct inventory area, such as each bin:

    • OnShelf;
    • OnTop; and
    • OnOrder.

If a user has 10,000 bins, the system tracks 10,000 states (one for each bin). Bins can only transition to other states in very specific ways, as illustrated in the state machine diagram depicted in FIG. 6. If a bin is in the OnShelf state 32, it can change to only the OnTop state 34. If a bin is in the OnTop state 34, it can change to either the OnShelf state 32 or the OnOrder state 36. If a bin is in the OnOrder state 36, it can change to only the OnShelf state 32. The act of transitioning from OnTop 34 to OnOrder 36 results in an order being placed for the supplies associated with the bin. Because this transition can happen only once, regardless of how long the bin is left on the top shelf, supplies are ordered only once.

A preferred embodiment of the system 10 implements transition controls to prevent transient errors from triggering false state transitions.

    • OnShelf to OnTop. It is very unlikely that a transient error condition would cause a bin to appear on the top shelf when the bin is not on the top shelf. No transition controls are needed for the OnShelf to OnTop state transition.
    • OnTop to OnShelf. Since it is very likely that a transient error could cause an optical code to not be seen in any given image, a preferred embodiment of the system 10 implements transition controls for this state transition.
      • Examples of transient errors:
        • A person standing in front of the shelving unit 12 blocks the camera's view of one or more optical codes.
        • A transient change in lighting makes one or more optical codes temporarily unreadable.
      • Exemplary transition control: An optical code must not be detected on the top shelf in at least six consecutive images in at least 60 consecutive minutes before this state transition is allowed.
    • OnTop to OnOrder. Since it is very unlikely that any bin would be in the OnTop state due to an error condition, no transition controls are needed for the OnTop to OnOrder transition.
    • OnOrder to OnShelf. A preferred embodiment of the system 10 implements the same transition control for this state transition as are implemented for the OnTop to OnShelf transition.

Thus, as depicted in FIG. 6, a preferred embodiment of the state machine requires certain criteria to be met before a state transition is allowed. As discussed above, each distinct inventory area (such as a bin or a portion of a shelf) associated with an optical code is in one of the three states: OnShelf 32, OnTop 34, or OnOrder 36. The initial state of a distinct inventory area represented by a code is OnShelf. Whenever the code representing a distinct inventory area that is currently OnShelf is detected as being on the top shelf 12a, the state of that distinct inventory area transitions to OnTop. If the code representing a distinct inventory area that is OnTop ceases to be detected on the top shelf 12a for a configurable amount of time or number of consecutive times, the state of that distinct inventory area transitions to OnShelf. Periodically the system processes orders by transitioning any distinct inventory area that is OnTop to OnOrder and based on the transition, sending or queuing a replenishment notification for that distinct inventory area. Optionally, the system may be configured to not immediately process distinct inventory areas that recently transitioned to OnTop (e.g., transitioned within the last 30 minutes).

If the code representing a distinct inventory area that is OnOrder ceases to be detected on the top shelf 12a for a configurable amount of time or number of consecutive times, the state of that distinct inventory area transitions to OnShelf. Since replenishment notifications are sent or queued based only on a distinct inventory area transitioning from OnShelf to OnOrder, any distinct inventory area that is OnOrder does not generate a new replenishment notification until after it has been removed from the top shelf 12a and placed back on one of the lower shelves.

With reference to FIG. 6, following is an example of a possible state machine flow for a distinct inventory area, assuming m=6 and n=60:

    • State is OnShelf
    • . . .
    • Image 1: Detected-> OnTop (update last time detected)
    • . . .
    • Image 48: Detected-> N/A (update last time detected)
    • Order processed:-> OnOrder
    • Image 49: Detected-> N/A (update last time detected)
    • . . .
    • Bin is restocked (a human physically restocks the bin and puts it back on the lower shelf)
    • Image 550: Not Detected (count++)=1 (last time detected =10 min ago)-> N/A
    • Image 551: Not Detected (count++)=2 (last time detected =20 min ago)-> N/A
    • Image 552: Not Detected (count++)=3 (last time detected =30 min ago)-> N/A
    • Image 553: Not Detected (count++)=4 (last time detected =40 min ago)-> N/A
    • Image 554: Not Detected (count++)=5 (last time detected =50 min ago)-> N/A
    • Image 555: Not Detected (count++)=6 (last time detected =59.9 min ago)-> N/A
    • Image 556: Not Detected (count++)=7 (last time detected =69.9 min ago)-> OnShelf

In some embodiments, it may be desirable to determine whether an optically encoded object, such as a bin, is disposed to the left or right of a vertical boundary line. In one such embodiment depicted in FIG. 8, vertically-aligned shelf codes are provided, such as a top shelf code 28T disposed on the top shelf 12a and a bottom shelf code 28B disposed on the bottom shelf 12c. The image processing software 22 identifies the top and bottom shelf codes 28T and 28B and assigns a reference x-y coordinate location to each identified code based on x-y coordinates of image pixels associated with each of the top shelf codes 28T and 28B. For example, coordinates x=24, y=0 may be assigned to the top shelf code 28T and coordinates x=24, y=−24 may be assigned to the bottom shelf code 28B, wherein the vertical boundary line passing through the two codes is defined by the equation x=24. Distinct inventory areas could be defined to occupy portions of the shelves either to the right (x>24) or to the left (x<24) of the vertical boundary line.

Those of ordinary skill in the art will appreciate that various embodiments of the system may employ other positions of shelf codes to also construct diagonal boundary lines, and combinations of horizontal, vertical and diagonal boundary lines. It should also be appreciated that such boundary lines need not be straight but could be curved in various and complex orientations to accomplish desired Kanban inventory replenishment functions. A boundary line may also be defined by an equation of a rectangle, triangle, circle, or any other closed shape, wherein decisions are made regarding inventory replenishment based on whether an optically encoded structure is disposed inside or outside the closed boundary shape.

It will be appreciated that the image processing of optical codes is prone to errors. A code may be recognized in one image but not in the next. The m and n thresholds in the above example are a mechanism to compensate for the error in the image processing. Image processing errors could be caused by external environmental items (e.g., lighting level changes in the inventory room, humidity changes, etc.) or by external transitive items (e.g., a tall person standing in front of a shelving unit, a worker temporarily placing a ladder in front of a shelving unit, etc.).

The foregoing description of preferred embodiments for this invention have been presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise form disclosed. Obvious modifications or variations are possible in light of the above teachings. The embodiments are chosen and described in an effort to provide the best illustrations of the principles of the invention and its practical application, and to thereby enable one of ordinary skill in the art to utilize the invention in various embodiments and with various modifications as are suited to the particular use contemplated. All such modifications and variations are within the scope of the invention as determined by the appended claims when interpreted in accordance with the breadth to which they are fairly, legally, and equitably entitled.

Claims

1. An apparatus for monitoring and replenishing an inventory of goods disposed within an inventory storage space, the apparatus comprising:

a first distinct inventory area within the inventory storage space, the first distinct inventory area configured to store a supply of a first type of goods;
a first optical code disposed on a first movable structure associated with the first distinct inventory area, the first optical code encoding a first unique identification number that identifies the first type of goods;
a replenishment signaling area within the inventory storage space, the replenishment signaling area configured to receive the first movable structure that is placed therein after the supply of the first type of goods stored in the first distinct inventory area has been depleted;
one or more boundary optical codes disposed adjacent to a boundary of the replenishment signaling area;
one or more cameras that each have a field of view at least partially encompassing the replenishment signaling area and the one or more boundary optical codes, the one or more cameras for generating periodic images of the replenishment signaling area and the one or more boundary optical codes;
one or more processors in electrical communication with the one or more cameras, the one or more processors operable to execute programmed instructions to: detect the one or more boundary optical codes present within the images generated by the one or more cameras; determine location coordinates of the one or more boundary optical codes detected within the images generated by the one or more cameras; based on the location coordinates of the one or more boundary optical codes, determine a boundary line associated with the boundary of the replenishment signaling area; detect the first optical code present within the images generated by the one or more cameras; determine location coordinates of the first optical code detected within the images generated by the one or more cameras; based on the location coordinates of the first optical code, determine a spatial relationship between a location of the first optical code and the boundary line; and generate a replenishment notification based at least in part on the spatial relationship between the location of the first optical code and the boundary line, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished.

2. The apparatus of claim 1 further comprising:

a multi-shelf shelving unit disposed within the inventory storage space, the multi-shelf shelving unit having a top shelf,
wherein: the replenishment signaling area comprises the top shelf of the multi-shelf shelving unit; the one or more boundary optical codes comprise: a first boundary optical code disposed adjacent to a first end of the top shelf; and a second boundary optical code disposed adjacent to a second end of the top shelf opposing the first end; and the one or more processors execute the programmed instructions to: determine the boundary line to coincide with the location coordinates of the first and second boundary optical codes; and generate the replenishment notification based at least in part on the location of the first optical code being above the boundary line.

3. The apparatus of claim 2 wherein:

the first movable structure comprises a first bin;
the first optical code is attached to the first bin and is within the field of view of the one or more cameras; and
the first distinct inventory area is disposed within the first bin.

4. The apparatus of claim 2 wherein:

the first movable structure comprises a bookend;
the first optical code is attached to the bookend and is within the field of view of the one or more cameras; and
the first distinct inventory area comprises a portion of a lower shelf of the multi-shelf shelving unit that is below the top shelf.

5. The apparatus of claim 1 further comprising:

a multi-shelf shelving unit disposed within the inventory storage space,
wherein: the first distinct inventory area comprises a first portion of a shelf of the multi-shelf shelving unit; the replenishment signaling area comprises a second portion of the shelf of the multi-shelf shelving unit, wherein the boundary of the replenishment signaling area is disposed between the first and second portions of the shelf; the one or more boundary optical codes comprise: a first boundary optical code disposed on an upper portion of the multi-shelf shelving unit; and a second boundary optical code disposed on a lower portion of the multi-shelf shelving unit; and the one or more processors execute the programmed instructions to: determine the boundary line associated with the boundary to coincide with the location coordinates of the first and second boundary optical codes; and generate the replenishment notification based at least in part on the location of the first optical code being offset to one side of the boundary line which indicates that the first optical code is within the replenishment signaling area.

6. The apparatus of claim 1 wherein the one or more processors execute the programmed instructions to determine the boundary line to comprise one or more of a horizontal line, a vertical line, a diagonal line, a curved line, and a line forming a closed shape.

7. The apparatus of claim 1 wherein the one or more processors execute the programmed instructions to determine the boundary line as intersecting the location coordinates of the one or more boundary optical codes.

8. The apparatus of claim 1 wherein the first optical code and the one or more boundary optical codes comprise QR codes or barcodes.

9. The apparatus of claim 1 wherein the one or more cameras comprise one or more of a camera mounted on a ceiling, a camera mounted on a horizontal or vertical track system, an infrared camera, and a camera having remotely-adjustable zoom, tilt and pan.

10. The apparatus of claim 1 wherein at least one of the one or more processors is disposed in the inventory storage space.

11. The apparatus of claim 10 wherein at least one of the one or more processors is a cloud-based server that is in communication with the at least one processor disposed in the inventory storage space via a communication network.

12. The apparatus of claim 1 wherein the one or more processors execute the programmed instructions to:

decode the first optical code to determine the first unique identification number that identifies the first type of goods, and
generate the replenishment notification to include the first unique identification number.

13. The apparatus of claim 1 wherein the one or more processors execute the programmed instructions to maintain a state machine representing a plurality of states of the first distinct inventory area, wherein the plurality of states include: wherein execution of the programmed instructions causes:

a first state in which the first optical code is not in the replenishment signaling area;
a second state in which the first optical code is in the replenishment signaling area; and
a third state in which an order has been placed or is to be placed to replenish the supply of the first type of goods in the first distinct inventory area,
a transition from the first state to the second state based on detecting the first optical code in the replenishment signaling area;
a transition from the second state to the third state and generation of a replenishment notification in association with the transition from the second state to the third state, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished; and
a transition from the third state to the first state based on not detecting the first optical code in the replenishment signaling area for at least a predetermined period of time.

14. The apparatus of claim 1 further comprising:

a second distinct inventory area within the inventory storage space, the second distinct inventory area configured to store a supply of a second type of goods;
a second optical code disposed on a second movable structure associated with the second distinct inventory area, the second optical code encoding a second unique identification number that identifies the second type of goods;
the replenishment signaling area configured to receive the second movable structure that is placed therein after the supply of the second type of goods stored in the second distinct inventory area has been depleted; and
the one or more processors operable to execute programmed instructions to: detect the second optical code present within the images generated by the one or more cameras; determine location coordinates of the second optical code detected within the images generated by the one or more cameras; based on the location coordinates of the second optical code, determine a spatial relationship between a location of the second optical code and the boundary line; and generate a replenishment notification based at least in part on the spatial relationship between the location of the second optical code and the boundary line, wherein the replenishment notification indicates that the supply of the second type of goods in the second distinct inventory area needs to be replenished.

15. A method for monitoring and replenishing an inventory of goods disposed within an inventory storage space, the method comprising:

designating a first distinct inventory area within the inventory storage space, the first distinct inventory area configured to store a supply of a first type of goods;
providing a first movable structure associated with the first distinct inventory area, the first movable structure having a first optical code disposed thereon, the first optical code encoding a first unique identification number that identifies the first type of goods;
designating a replenishment signaling area within the inventory storage space, the replenishment signaling area configured to receive the first movable structure;
placing the first movable structure into the replenishment signaling area after the supply of the first type of goods stored in the first distinct inventory area has been depleted;
providing one or more boundary optical codes adjacent to a boundary of the replenishment signaling area;
periodically generating optical images that encompass the replenishment signaling area and the one or more boundary optical codes;
executing programmed instructions on one or more processors to detect the one or more boundary optical codes present within the images;
executing programmed instructions on the one or more processors to determine location coordinates of the one or more boundary optical codes detected within the images;
executing programmed instructions on the one or more processors to determine a boundary line associated with the boundary of the replenishment signaling area based on the location coordinates of the one or more boundary optical codes;
executing programmed instructions on the one or more processors to detect the first optical code present within the images;
executing programmed instructions on the one or more processors to determine location coordinates of the first optical code detected within the images;
executing programmed instructions on the one or more processors to determine a spatial relationship between a location of the first optical code and the boundary line based on the location coordinates of the first optical code; and
executing programmed instructions on the one or more processors to generate a replenishment notification based at least in part on the spatial relationship between the location of the first optical code and the boundary line, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished.

16. The method of claim 15 wherein:

the replenishment signaling area comprises a top shelf of a multi-shelf shelving unit; and
the one or more boundary optical codes comprise: a first boundary optical code disposed adjacent to a first end of the top shelf; and a second boundary optical code disposed adjacent to a second end of the top shelf opposing the first end; and
wherein the method further comprises: executing programmed instructions on the one or more processors to determine the boundary line to coincide with the location coordinates of the first and second boundary optical codes; and executing programmed instructions on the one or more processors to generate the replenishment notification based at least in part on the location of the first optical code being above the boundary line.

17. The method of claim 16 wherein the first movable structure comprises a first bin, the first optical code is attached to the first bin, and the first distinct inventory area is disposed within the first bin.

18. An apparatus for monitoring and replenishing an inventory of goods disposed within an inventory storage space, the apparatus comprising:

a first distinct inventory area within the inventory storage space, the first distinct inventory area configured to store a supply of a first type of goods;
a first electronically detectable element disposed on a first movable structure associated with the first distinct inventory area, the first electronically detectable element encoding a first unique identification number that identifies the first type of goods;
a replenishment signaling area within the inventory storage space, the replenishment signaling area configured to receive the first movable structure that is placed therein after the supply of the first type of goods stored in the first distinct inventory area has been depleted;
one or more detectors associated with the replenishment signaling area, the one or more detectors configured to detect the first electronically detectable element; and
one or more processors in electrical communication with the one or more detectors, the one or more processors operable to execute programmed instructions to maintain a state machine representing a plurality of states of the first distinct inventory area, wherein the plurality of states include: a first state in which the first electronically detectable element is not in the replenishment signaling area; a second state in which the first electronically detectable element is in the replenishment signaling area; and a third state in which an order has been placed or is to be placed to replenish the supply of the first type of goods in the first distinct inventory area,
wherein execution of the programmed instructions causes: a transition from the first state to the second state based on the one or more detectors detecting the first electronically detectable element in the replenishment signaling area; a transition from the second state to the third state and generation of a replenishment notification in association with the transition from the second state to the third state, wherein the replenishment notification indicates that the supply of the first type of goods in the first distinct inventory area needs to be replenished; and a transition from the third state to the first state based on the one or more detectors in the replenishment signaling area not detecting the first electronically detectable element in the replenishment signaling area for at least a predetermined period of time.

19. The apparatus of claim 18 further comprising a multi-shelf shelving unit disposed within the inventory storage space, wherein the replenishment signaling area comprises a top shelf of the multi-shelf shelving unit.

20. The apparatus of claim 19 wherein:

the first movable structure comprises a first bin;
the first electronically detectable element is attached to the first bin; and
the first distinct inventory area is disposed within the first bin.

21. The apparatus of claim 19 wherein:

the first movable structure comprises a bookend;
the first electronically detectable element is attached to the bookend; and
the first distinct inventory area comprises a portion of a lower shelf of the multi-shelf shelving unit that is below the top shelf.

22. The apparatus of claim 18 further comprising a multi-shelf shelving unit disposed within the inventory storage space, wherein:

the first distinct inventory area comprises a first portion of a shelf of the multi-shelf shelving unit; and
the replenishment signaling area comprises a second portion of the shelf of the multi-shelf shelving unit.

23. The apparatus of claim 18 wherein the first electronically detectable element comprises a QR code, a barcode or an RFID tag.

24. The apparatus of claim 18 wherein the one or more detectors comprise one or more cameras or one or more RFID tag readers.

25. The apparatus of claim 18 wherein at least one of the one or more processors is disposed in the inventory storage space.

26. The apparatus of claim 25 wherein at least one of the one or more processors is a cloud-based server that is in communication with the at least one processor disposed in the inventory storage space via a communication network.

27. The apparatus of claim 18 wherein the one or more processors execute the programmed instructions to:

decode the first electronically detectable element to determine the first unique identification number that identifies the first type of goods, and
generate the replenishment notification to include the first unique identification number.
Patent History
Publication number: 20240338650
Type: Application
Filed: Apr 5, 2023
Publication Date: Oct 10, 2024
Applicant: DeRoyal Industries, Inc. (Powell, TN)
Inventors: Gregory S. Hodge (Knoxville, TN), Daniel W. Marzahl, JR. (Knoxville, TN), Dhanvin S. Desai (Knoxville, TN), Kenneth L. Jones (Lenoir City, TN), Sallie P. Patrick (Maryville), Mark E. McKnight (Knoxville, TN), James W. Tucker (Knoxville, TN), Joe L. Smith (Powell, TN)
Application Number: 18/131,056
Classifications
International Classification: G06Q 10/087 (20060101);