Products and/or services (further referred to herein generally as “products”) are typically delivered to consumers through a network of manufacturers, distributors, transporters, retailers, and so on. Such a network of facilities that together deliver products to consumers is commonly referred to as a “supply chain” network.
Suppliers of products and services (e.g., manufactures, vendors, retailers, and so on) often face the task of forecasting the demand for the products in order to provide smooth and efficient flow of the products through the supply chain network in the presence of constantly-changing market conditions. Overestimating the demand can result in overproduction and increased costs associated with holding inventories (e.g., storage costs, obsolescence, and so on). Underestimating the demand, on the other hand, can result in lost revenues. Accordingly, the accuracy of a supplier's demand forecasts can directly affect the supplier's profits.
One technique for forecasting demand for a product (further referred to as “conventional method”) is to forecast the demand based primarily on historical demand information for that product (e.g., based on past purchase orders, past shipments, past point-of-sales data, and so on). However, such a technique may poorly adapt to the ever-changing market conditions and can result in an inaccurate forecast.
Methods and apparatus, including computer program products, are provided that include techniques for forecasting demand. In one aspect, a method is provided that includes identifying event data associated with a demand forecast. The method further includes determining a first portion of a demand forecast using the event data. The method further includes determining a second portion of the demand forecast using at least order history data. The method further includes identifying weights to be applied to the first and second portions. The method further includes determining an aggregate demand forecast including applying respective identified weights to and combining the first and second portions of the demand forecast.
Aspects can include one or more of the following features. The event data can be real-time event data. The event data can also be downstream event data. The event data can further be RFID data, including EPC data.
The method can be performed at a manufacturer distribution center for orders received from one or more retail distribution centers.
The first portion can be determined using event data corresponding to shipments made from a retail distribution center. Determining the first portion can include determining a relationship between the event data and prior orders. Determining a relationship can include determining a one-to-one relationship. Determining a relationship can also include determining a one-to-one relationship between shipment information from a retail distribution center to subsequent orders received therefrom. Determining the second portion can include using historical order data from a respective downstream element in the supply chain to calculate a partial demand.
Determining weights can include determining predetermined weights. Determining weights can also include determining estimated weights. Determining estimated weights can include determining estimates based on historical data associated with an associated product. Determining the weights can also include estimating the weights. Estimating can include determining a correlation associated with the aggregate forecast using other data. Other data can be historical data related to a demand forecast for a product. Other data can also be data related to another product. Other data can be related to another downstream element.
The aggregate demand forecast can be associated with a product. The aggregate demand forecast can also be associated with a service. The aggregate demand forecast can also be associated with a product and the history data can be associated with previous orders for the product received from a downstream element in a supply chain for the product.
In another aspect, a method is provided that includes identifying event data downstream from a location in a supply chain where a demand forecast is to be determined. The method further includes identifying a relationship of the event data with the demand forecast. The method further includes using the relationship to determine estimates for weights to be used in determining an associated aggregate demand forecast. The method further includes determining a first portion of a demand forecast using the event data. The method further includes determining a second portion of the demand forecast using at least order history data. The method further includes applying the estimated weights to the respective first and second portions. The method further includes determining an aggregate demand forecast including combining the first and second portions of the demand forecast.
In another aspect, a method is provided that includes identifying event data associated with a first product downstream from a location in a supply chain where a demand forecast is to be determined. The method further includes determining a correlation between event data and order forecast in the supply chain. The method further includes using the correlation to determine estimates for weights to be used in determining an associated aggregate demand forecast for the second product. The method further includes determining a first portion of a demand forecast using the event data.
The invention can be implemented to realize one or more of the following advantages. Real-time events and event data collection can be used to generate more accurate demand forecasts.
Details of one or more implementations of the invention are set forth in the accompanying drawings and in the description below. Further features, aspects, and advantages of the invention will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
Referring to
Products can be manufactured at a manufacturing production facility 102 (e.g., a plant). Manufacturing products, for example, can include procuring raw materials and turning the raw materials into finished and/or intermediate products.
The manufactured products can then be transferred to a M-DC 104, which can distribute the products. The products can be transferred to a respective M-DC in accordance with replenishment orders that are received from the M-DC.
In one implementation, distributing products includes delivering the products to one or more retail distribution centers (R-DC) 106, e.g., in accordance with purchase orders that are received from the retail distribution centers 106. In one implementation, one general inventory rule requires that a large enough inventory must be maintained at a respective M-DC 104 to be able to respond quickly to purchase orders from any of the M-DC's respective R-DCs. At the same time, it may be preferable to control the size of the inventory at the M-DC 104 to avoid overstocking.
In one implementation, the R-DC's 106 can ship the products received from the manufacturer distribution centers 104 to one or more retail stores 108 (e.g., based on store orders received from the respective retail stores 108). Again, an optimal inventory at an R-DC 106 can, in one implementation, be maintained large enough to accommodate the retail stores 108 but also small enough to be liquid.
The retail stores 108 can in turn sell the products to consumers. As the products travel from manufacturing production facilities 102 to consumers, the products can take on different shapes and forms. That is, the products can be packaged, assembled into sets, transformed into other products, and so on.
Products flowing through the supply chain network 100 can be tracked using, for example, EPC and the RFID technologies. For example, each product can include a tag with an electronic product code (EPC) uniquely identifying the product. An EPC can be electronically read and transmitted over a network using Radio Frequency Identification (RFID) technology. Electronically reading an EPC tag of a product can include determining the unique ID of the product, determining the location of the product, recording the time when the EPC tag is read, and so on. Other tracking means can be used including bar codes and bar code records. Additionally, other tracking methodologies can be used including tracking at the product level, pallet level or otherwise. Further, tracking, as it used herein refers to the receipt and processing at a node in the supply chain network 100 (e.g., an M-DC 104) of event data that relates to the processing of the product or products at downstream facilities, up to and including the retail store level. The event data can take many forms, and plural event data can be used in the generation of replenishment requests. The generation of replenishment requests is discussed in greater detail below.
By way of example, demand forecasting can be required to be implemented at one or more locations along the supply chain network 100. For example, an M-DC can use demand forecasting to determine the amount of product that needs to be ordered from an associated manufacturing production facility 102 to support incoming orders for the product from one or more R-DCs 106 in the supply chain network 100. Other locations in the supply chain network 100 can use demand forecasting methodologies similar to those described herein, or other conventional means. For the purpose of clarity, a demand forecasting methodology according to aspects of the invention is described below with reference to structures in an M-DC 104. Those of ordinary skill in the art will recognize that similar methods can be used at other locations in the supply chain network 100.
Referring to
Inputs of the demand planning module 200 can include persistent data inputs 210. The persistent data inputs 210 can include products master data, which can define the stock keeping unit (SKU) attributes of each product. For example, master data for a given product can include the global trade item number (GTIN) of the product, the packaging information for the product, category information for the product, special shipment requirements for the product (e.g., whether the product has to be transported on refrigerated trucks), dimensions of the product, manufacturers of the product, and so on.
The persistent data inputs 210 can further include location master data, which can identify different locations and sub-locations in the supply chain network 100. For example, location master data (for a given location) can include a global location number (GLN), type of the location, address of the location, capacity of the location, relationship of the location to other locations, and so on.
Inputs of the demand planning module 200 can further include configurable data inputs 212. For a given product (or for a given retailer), configurable data inputs 212 can include the minimum required service level, frequency of purchase orders, order processing delays, and lead times and variability between different locations in the supply chain network 100. Configurable data inputs 212 for a given product can further include rounding policies for shipping, estimates of pilferage (e.g., thefts, damages, disposals due to expiration of dated products, and so on), and historical bullwhip factors. Other configurable data inputs 212 can include various constraints, such as no delivery on Saturday and Sunday.
Inputs of the demand planning module 200 can further include dynamic data inputs 214. Dynamic data inputs 214 can include purchase orders, point-of-sales data, and real-time events, e.g., electronic product code (EPC) events and other downstream event data. The downstream event data can be received from various locations in the supply chain network 100 (e.g., retail stores 108, R-DC 106, and so on). Examples of events include outbound shipments from an R-DC to one or more retail stores 108, receipt of shipments at an R-DC, outbound shipment of product from an R-DC to retail stores 108, receipt at retail stores 108, store-level movement of inventory (e.g., from back room of the store to the shopping floor), and so on. In some implementations, dynamic data inputs 214 can include upstream event data (e.g., manufacturing production facility 102 shipment data) to facilitate improved demand forecasting (e.g., to take into account an unexpected shipment or fulfillment or short fill of a current order).
Outputs of the demand planning module 200 can include replenishment requirements 216 to be directed to an upstream manufacturing enterprise and required to fulfill the demand from all retail distribution centers 106 associated with a given M-DC. For example, the replenishment requirements 216 can be sent to (e.g., as part as a replenishment order) a manufacturing production facility 102 in order to restock the inventory at the M-DC 104.
Outputs of the demand planning module 200 can further include an allocation strategy 218, which can be a set of rules for distributing the in-stock products in case the demand from all R-DCs 106 is not met by the M-DC on-hand inventory.
Outputs of the demand planning module 200 can further include various kinds of out-of-stock alerts and actions 220. For example, out-of-stock alerts and actions 220 can be generated when inventory falls below predicted demand forecasts. An out-of-stock alert 220 can be used to trigger certain exception management procedures, such as expediting, transfer shipments, and so on.
In one implementation, the demand planning module 200 can include a plurality of engines including one or more forecast engines 202, one or more inventory optimization engines 204, one or more replenishment engines 206, and one or more allocation engines 208.
A forecast engine 202 can predict order quantities of the forthcoming purchase orders from retail distribution centers 106, as will be described in greater detail below. In one implementation, the demand planning module 200 can include one forecast engine 202 for each product or SKU. In other implementations, the demand planning module 200 can include one forecast engine 202 per product, per R-DC 106, or one forecast engine 202 per product, per R-DC 106, per retail store 108, or other configurations.
An inventory optimization engine 204 can determine a desired inventory for an M-DC 104, e.g., based on the predictions provided by the forecast engines 202. In one implementation, the demand planning module 200 can include one inventory optimization engine 204 for each product. In other implementations, the demand planning module 200 can include one inventory optimization engine 204 per product, per R-DC 106, or one inventory optimization engine 204 per product, per R-DC 106, per retail store 108, and or other configurations.
In one implementation, the desired inventory can be calculated as a sum of the cycle stock and the safety stock. The cycle stock can be determined as the sum of all predicted orders within an order cycle. The safety stock can be a demand buffer, calculated as a function of the forecast variability and lead time variability of the order cycle. The calculation of cycle stock is based on the purchase order forecast. Determining the purchase order forecast is discussed in greater detail below.
A replenishment engine 206 can determine the actual replenishment quantities, e.g., based on the results provided by an associated inventory optimization engine 204. The demand planning module 200 can include one replenishment engine 206 for each product. In other implementations, the demand planning module 200 can include one replenishment engine 206 per product, per R-DC 106, or one replenishment engine 206 per product, per R-DC 106, per retail store 108, or other configurations.
In one implementation, the replenishment quantity can be calculated as the difference between the optimal inventory (e.g., provided by the inventory optimization engine 204) and the inventory on hand and in transit. This amount can be adjusted based on shipping constraints (e.g., transportation schedules, minimum order quantities required by the suppliers, and so on).
An allocation engine 208 can provide an allocation strategy in case the demand from all R-DCs 106 is not met by the M-DC on-hand inventory, as described earlier. In one implementation, the allocation engine 208 can equally allocate in-stock products to various retail distribution centers 106. Alternatively, a prioritization system can be used to allocate in-stock products unequally to different retail distribution centers 106 based on the different requirements of the different retail distribution centers 106, or other considerations.
Referring to
The forecast engine 202 can further include an event-based forecast unit 306, which uses event data (e.g., real-time event data) 308 to predict order quantities for forthcoming purchase orders. For example, the event-based forecast unit 306 can make a prediction based on EPC events (e.g., outbound shipments from an R-DC 106 to retail stores 108) and various forecast parameters, as will be described in greater detail below.
The forecast engine 202 can further include an integration unit 310 which can provide an aggregate prediction 312 of order quantities for forthcoming purchase orders based on the predictions provided by the conventional forecast unit 302 and the event-based forecast unit 306. In one implementation, the aggregate prediction 312 provided by the integration unit 310 can be a weighted sum of the prediction provided by the conventional forecast unit 302 and the prediction provided by the event-based forecast unit 306.
In one implementation, the integration unit 310 can assign weights to the predictions provided by the conventional forecast unit 302 and the event-based forecast unit 306. The integration unit 310 can then provide the aggregate prediction 312 by combining predictions provided by the conventional forecast unit 302 and the event-based forecast unit 306 in accordance with the assigned weights. Alternatively, the conventional forecast unit 302 and the even-based forecast unit 306 can determine their own weights, and the integration unit merely only need to combine the respective forecasts.
The forecast engine 202 can further include an adaptive feedback unit 314. When a purchase order is received from an R-DC 106, the adaptive feedback unit 314 can compare the received order quantities of the purchase order with the predicted order quantities (e.g., aggregate prediction 312 determined by the integration unit 310) for that order and provide a value of forecast error 316. The adaptive feedback unit 314 can further tune the conventional forecast unit 302 and the event-based forecast unit 306 outputs, e.g., by adjusting forecast parameters of each unit, based on the forecast error 316. Optionally, the adaptive feedback unit 314 can use historical data 304 and event data 308 to tune the conventional forecast unit 302 and the event-based forecast unit 306.
Referring to
In a first example scenario, a known relation is identified between purchase orders received and downstream event data. Based on this relationship, a first portion of the prediction of a future purchase order for a given downstream element will be made using collected event data. A second portion of the demand forecast is determined using conventional demand planning forecasting methodologies. For example, in the scenario shown in
Referring to
An order-shipment relation can be typically described as Dt+L=w1·dt+w2·dt+1+ . . . +wL·dt+L−1, where w1, . . . ,wL are known weights on the daily shipments. In a simple example, w1= . . . =wL=1. That is, the R-DC 106 orders the exact amount of inventory that has been withdrawn from it in the last L days.
Within a given order cycle, relevant event data can be collected and provided to a prediction device to determine a first portion of a purchase order prediction (step 404). In this example the relevant data can be of the form of data associated with outbound shipments from the R-DC 106 to the retail stores 108 up until the time demand forecasting is performed (i.e., dt, dt+1 . . . dt+m−1). The data can be obtained using real-time events, e.g., real-time EPC events at the point of shipment. A second portion of the purchase order prediction associated with the downstream element (e.g., to support the R-DC's outbound shipments from the R-DC 106 to the retail stores 108 in that order cycle, i.e., future shipments) is denoted as wt+md′t+m+ . . . +wt+L−1d′t+L−1, and is predicted by disaggregating the conventional forecast of the next purchase order, or by using historical information, e.g., of the R-DC 106 daily shipments to the retail stores 108 (step 406).
The obtained outbound shipments dt, dt+1 . . . dt+m−1 and the predicted future shipments d′t+m . . . d′t+L−1 (or in the aggregate form of wt+md′t+m+ . . . +wt+L−1d′t+L−1) can be used to forecast the forthcoming purchase order Dt+L. That is, the obtained outbound shipments dt, dt+1 . . . dt+m−1 and the predicted future shipments d′t+m . . . d′t+L−1 can be substituted into the order-shipment relation (step 408) to forecast the forthcoming purchase order Dt+L as, for example expressed below (where D′t+L denotes the forecast of Dt+L):
D′t+L=w1d1+ . . . +wmdt+m−1+wm+1d′t+m . . . +wLd′t+L−1.
The substitution can include applying appropriate weightings (e.g., using the known weights w1 . . . wL) as required. For example, in a simple seven day order cycle that includes three days of shipment data where each day in the cycle is equally weighted (e.g., w1= . . . =wL=1), the aggregate purchase order prediction (the sum of the first and second portions of the purchase order prediction) can be determined based on a sum of the event data received (the real time data that indicates the downstream shipments in this example) and an appropriate weighting of a conventional prediction of the next purchase order (e.g., 4/7 weighting in this simple example).
Other weightings can be used. For example, historical data relating to the order cycle, other shipments, other orders, other data associated with other upstream or downstream elements can be used to adjust the relevance of each portion of the aggregate prediction. Further, other weights can be used to adjust for example, for known relationships with unknown weights, or for unknown relationships with unknown weights as will be discussed in greater detail below in relationship to
In one implementation, the process for forecasting a forthcoming purchase order described in reference to
As discussed above, a combination of conventional and event-based forecasting can be used when known relationships with known weights exist between the collected event data and future purchase orders. In some implementations, these relationships and/or weights may not be known.
Referring to
Referring now to
Referring to
Referring to
Relevant data associated with the determined correlation is identified (step 604). Relevant data can be, for example, the event data for another product, another location, and so on. The correlation is then used to determine estimated weights (606). Note, if no correlation can be made, then the weights used for the event data are set to zero and the weight applied to the conventional forecast is set to one. Hence, effectively the purchase order forecast is generated by the conventional forecasting method. Once the weights w1, . . . ,wL are estimated, the method described with reference to
In a given supply chain network 100, there may exist various correlations between different supply chain network quantities. For example, there may exist a correlation between purchase orders of an R-DC 106 and outbound shipments of that R-DC 106. Similarly, there may exist a correlation between purchase orders of an R-DC 106 and purchase orders and/or outbound shipments of another R-DC 106. Likewise, there may exist a correlation between purchase orders for different products (e.g., a complementary good and substitute goods). Therefore, the method outlined in reference to
The invention and all of the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structural means disclosed in this specification and structural equivalents thereof, or in combinations of them. The invention can be implemented as one or more computer program products, i.e., one or more computer programs tangibly embodied in an information carrier, e.g., in a machine-readable storage device or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program (also known as a program, software, software application, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file. A program can be stored in a portion of a file that holds other programs or data, in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification, including the method steps of the invention, can be performed by one or more programmable processors executing one or more computer programs to perform functions of the invention by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus of the invention can be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
The invention can be implemented in a computing system that includes a back-end component (e.g., a data server), a middleware component (e.g., an application server), or a front-end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the invention), or any combination of such back-end, middleware, and front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
The invention has been described in terms of particular embodiments, but other embodiments can be implemented and are within the scope of the following claims. For example, the operations of the invention can be performed in a different order and still achieve desirable results. As one example, the process depicted in
Furthermore, the described demand forecasting technique can be performed at an R-DC 106 (or at other locations in the supply chain network 100). Historical data about store orders can be used to generate the conventional forecasts, and case movements and point-of-sale data can become contributors to the correlation. Moreover, an M-DC 106 can be “co-located” (i.e, at the same physical location) with the manufacturing production facility 102. In such a case, the requirements generated for the demand forecast become production orders.
Outbound shipments from retail distribution centers 106 to retail stores 108 have been used as examples of event data for illustrative purposes. However, other event data can also be used either in adjusting or estimating portions of the order forecast or elements thereof including store-level inventory movement, point-of-sale data, and so on.
The supply chain network 100 including a manufacturing production facility 102, and M-DC 104, and R-DC 106, and a retail store 108 is one example implementation. The techniques disclosed herein are applicable to demand forecasting in other supply chain networks and in other systems.
This application claims the benefit of U.S. Provisional Patent Application Nos. 60/626,194, filed Nov. 8, 2004, and 60/583,832 filed Jun. 28, 2004, which are incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
60626194 | Nov 2004 | US | |
60583832 | Jun 2004 | US |