This disclosure relates to the field of supply chains. In particular, it relates to management of demands in a supply chain network.
This disclosure relates generally to the field of supply chain management and more specifically to optimization of inventory demand.
Within a supply chain, products are supplied to customers in response to demand. Within the supply chain, there are entities that supply a product, components of a product, or resources needed to produce products. The supply chain also includes entities that solely receive a product. There may also be entities that receive a product, components of a product, or resources needed to produce products; and supply a product, components of a product, or resources needed to produce products to entities further down the supply chain. Each entity within the chain has a demand schedule and a safety stock schedule, to plan for orders of inventory. Both the demand schedule and the safety stock schedule are used to make planning orders for inventory to an entity within the supply chain. Often times, the safety stock of an entity may be used to fulfill an impending demand. This often leads to purchase orders that miss actual demands, and thus lead to negative consequences of supply that propagate through the supply chain.
U.S. Pat. No. 10,311,391 (issued Jun. 4, 2019) discloses a method to optimize inventory in accordance with a constrained network. In this method, service level band sets are accessed. A feasible supply chain plan that satisfies the inventory band sets is generated in order of the inventory priorities until a constrained network is depleted.
US 20130138470 discloses a system and method for supply chain optimization which comprises identifying a supply chain optimization scheme enabled by an enterprise resource planning implementation on the basis of one or more system limitations. One or more process flows and requirements associated with the supply chain are compared with pre-developed process flows and requirements. A key performance indicator framework comprising one or more performance metrics by which the time and cost efficiency of a supply chain is measured, is provided.
In an aspect, a system comprising: one or more processors; and a memory storing instructions that, when executed by the one or more processors, configure the system to: access, by a supply chain planning engine, a demand planning schedule and a safety stock schedule of a supply chain entity; process, by the one or more processors, a demand of the demand planning schedule chronologically, process, by the one or more processors, two or more demands according to level of priority from highest priority to lowest priority when the two or more demands have an identical date; and create, by an optimization engine, a transformed demand planning schedule by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule.
In some embodiments, if the demand is a safety stock demand, creating the transformed demand planning schedule may comprise: adding, by the optimization engine, the demand to a safety stock demand list; and process, by the one or more processors, a next demand of the demand planning schedule if the demand is not a last demand. In some embodiments, if the demand is a real demand and the safety stock list is empty and the real demand is not the last demand, creating the transformed demand planning schedule may comprise processing, by the one or more processors, the next demand. In some embodiments, if the demand is a real demand and the safety stock list is not empty, creating the transformed demand planning schedule may comprise: transforming, by the optimization engine, the real demand into a transformed demand using an earliest safety stock demand in the safety stock demand list; updating, by the optimization engine, a demand date of the transformed demand and a demand priority of the transformed demand; updating, by the optimization engine, the safety stock demand list based on the transformed demand; and updating, by the optimization engine, the safety stock demand list based on a current safety stock level.
In some embodiments, the system can be further configured to: determine, by the optimization engine, a demand type of the demand; if the demand type is a safety stock: add, by the optimization engine, a safety stock date and a safety stock quantity to a safety stock demand list; and if the demand type is a non-safety stock, transform the non-safety stock demand to an earliest demand in the safety stock demand list and update the safety stock list to include a safety stock demand that maintains a safety stock quantity on the date of the demand.
In some embodiments, where a non-safety stock demand quantity is less than or equal to a safety stock quantity of the earliest demand, the system can be further configured to: i) move, by the optimization engine, the non-safety stock demand to an earliest demand date in the safety stock demand list; and ii) subtract, by the optimization engine, the non-safety demand quantity from the safety stock quantity of the earliest demand in the safety stock demand list, to provide an updated safety stock quantity of the earliest demand.
In some embodiments, the system can be further configured to: compare, by the optimization engine, the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and add, by the optimization engine, a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
In another aspect, a method comprising: accessing, by a supply chain planning engine, a demand planning schedule and a safety stock schedule of a supply chain entity; processing, by one or more processors of a server, each demand of the demand planning schedule chronologically, processing, by the one or more processors, the demands according to level of priority from highest priority to lowest priority when two or more demands occur have an identical date; and creating, by an optimization engine, a transformed demand planning schedule by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule.
In some embodiments, if the demand is a safety stock demand, creating the transformed demand planning schedule, may comprise adding, by the optimization engine, the demand to a safety stock demand list; and processing, by the one or more processors, a next demand of the demand planning schedule.
In some embodiments, if the demand is a real demand, creating the transformed demand planning schedule, may comprise: processing, by the one or more processors, the next demand if the safety stock demand list is empty; transforming, by the optimization engine, the real demand into a transformed demand using an earliest safety stock demand in the safety stock demand list; updating, by the optimization engine, a demand date of the transformed demand and a demand priority of the transformed demand; updating, by the optimization engine, the safety stock demand list based on the transformed demand; and updating, by the optimization engine, the safety stock demand list based on a current safety stock level.
In some embodiments, the method may further comprise: determining, by the optimization engine, a demand type of the demand; and if the demand type is a safety stock demand, adding, by the optimization engine, a date and a quantity of the safety stock demand to a safety stock demand list.
In some embodiments, the method may further comprise: determining, by the optimization engine, a demand type of the demand; and if the demand type is a non-safety stock: transforming, by the optimization engine, the non-safety stock demand to an earliest demand in the safety stock demand list and updating the safety stock list to include a safety stock demand that maintains a safety stock quantity on the date of the demand.
In some embodiments, where the non-safety stock demand quantity is less than or equal to a safety stock quantity of the earliest demand, the method may further comprise: i) moving, by the optimization engine, the non-safety stock demand to an earliest demand date in the safety stock demand list; and ii) subtracting, by the optimization engine, the non-safety demand quantity from the safety stock quantity of the earliest demand in the safety stock demand list, to provide an updated safety stock quantity of the earliest demand.
In some embodiments, the method may further comprise: comparing, by the optimization engine, the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and adding, by the optimization engine, a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
In another aspect, a non-transitory computer-readable medium embodied with software, the software when executed using one or more processors on a server, is configured to: access a demand planning schedule and a safety stock schedule associated with a supply chain entity stored in a database coupled to the server; process each demand of the demand planning schedule chronologically to create a transformed demand planning schedule, by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule; and where two or more demands have an identical date, process the two or more demands according to level of priority from highest priority to lowest priority.
In some embodiments, if the demand is a safety stock demand, creating the transformed demand planning schedule may comprise adding, by the optimization engine, the demand to a safety stock demand list; and processing, by the one or more processors, a next demand of the demand planning schedule.
In some embodiments, if the demand is a real demand, creating the transformed demand planning schedule may comprise: processing, by the one or more processors, the next demand if the safety stock demand list is empty; transforming, by the optimization engine, the real demand into a transformed demand using an earliest safety stock demand in the safety stock demand list; updating, by the optimization engine, a demand date of the transformed demand and a demand priority of the transformed demand; updating, by the optimization engine, the safety stock demand list based on the transformed demand; and updating, by the optimization engine, the safety stock demand list based on a current safety stock level.
In some embodiments, the computer may be further configured to: determine, by the optimization engine, a demand type of the demand; if the demand type is a safety stock demand: add, by the optimization engine, a date and a quantity of the safety stock demand to a safety stock demand list; and if the demand type is a non-safety stock, transform the non-safety stock demand to an earliest demand in the safety stock demand list and update the safety stock list to include a safety stock demand that maintains a safety stock quantity on the date of the demand.
In some embodiments, where the non-safety stock demand quantity is less than or equal to a safety stock quantity of an earliest demand, the computer may be further configured to: i) move, by the optimization engine, the non-safety stock demand to an earliest demand date in the safety stock demand list; and ii) subtract, by the optimization engine, the non-safety demand quantity from the safety stock quantity of the earliest demand in the safety stock demand list, to provide an updated safety stock quantity of the earliest demand.
In some embodiments, the computer may be further configured to: compare, by the optimization engine, the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and add, by the optimization engine, a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
In another aspect, a system comprising: a database that stores information about a demand planning schedule and safety stock schedule of a supply chain entity; the demand planning schedule comprising a plurality of demands, each demand having a date, a type, a priority and a quantity; and the safety stock schedule comprising one or more safety stock quantities, each safety stock quantity having a date range; a server comprising one or more processors, the server coupled to the database and configured to: access the demand planning schedule and safety stock schedule stored in the database; process each demand of the demand planning schedule chronologically to create a transformed demand planning schedule, by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule; and where two or more demands occur on the same date, process the demands according to level of priority from highest priority to lowest priority. In some embodiments, in processing each demand, the server can be further configured to: determine the demand type; if the demand type is a safety stock, add the date and quantity of the safety stock demand to a safety stock demand list; and if the demand type is a non-safety stock, transform the non-safety stock demand to an earliest demand in the safety stock demand list and update the safety stock list to include a safety stock demand that maintains the safety stock quantity on the date of the demand. In some embodiments, in transforming the non-safety stock demand, the server can be further configured to: where the non-safety stock demand quantity is less than or equal to the safety stock quantity of the earliest demand: i) move the non-safety stock demand to the earliest demand date in the safety stock demand list; and ii) in the safety stock demand list, subtract the non-safety demand quantity from the safety stock quantity of the earliest demand to provide an updated safety stock quantity of the earliest demand. In some embodiments, in updating the safety stock demand list, the server can be further configured to: compare the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and add a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
In another aspect, a computer-implemented method comprising: accessing a demand planning schedule and a safety stock schedule of a supply chain entity stored in a database; processing, by one or more processors of a server coupled to the database, each demand of the demand planning schedule chronologically to create a transformed demand planning schedule, by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule; and where two or more demands occur on the same date, processing the demands according to level of priority from highest priority to lowest priority. In some embodiments, processing each demand chronologically may comprise: determining the demand type; if the demand type is a safety stock, adding the date and quantity of the safety stock demand to a safety stock demand list; and if the demand type is a non-safety stock, transforming the non-safety stock demand to an earliest demand in the safety stock demand list and updating the safety stock list to include a safety stock demand that maintains the safety stock quantity on the date of the demand. In some embodiments, transforming the non-safety stock demand may comprise: where the non-safety stock demand quantity is less than or equal to the safety stock quantity of the earliest demand: i) moving the non-safety stock demand to the earliest demand date in the safety stock demand list; and ii) in the safety stock demand list, subtracting the non-safety demand quantity from the safety stock quantity of the earliest demand to provide an updated safety stock quantity of the earliest demand. In some embodiments, updating the safety stock demand list may comprise: comparing the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and adding a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
In another aspect, a non-transitory computer-readable medium embodied with software, the software when executed using one or more processors on a server, is configured to: access a demand planning schedule and a safety stock schedule associated with a supply chain entity stored in a database coupled to the server; process each demand of the demand planning schedule chronologically to create a transformed demand planning schedule, by allocating one or more safety stock demands to one or more non-safety stock demands and creating one or more new safety stock demands to maintain the safety stock schedule; and where two or more demands occur on the same date, process the demands according to level of priority from highest priority to lowest priority. In some embodiments, in processing each demand chronologically, the software can be further configured to: determine the demand type; if the demand type is a safety stock, add the date and quantity of the safety stock demand to a safety stock demand list; and if the demand type is a non-safety stock, transform the non-safety stock demand to an earliest demand in the safety stock demand list and update the safety stock list to include a safety stock demand that maintains the safety stock quantity on the date of the demand. In some embodiments, in transforming the non-safety stock demand, the software can be further configured to: where the non-safety stock demand quantity is less than or equal to the safety stock quantity of the earliest demand: i) move the non-safety stock demand to the earliest demand date in the safety stock demand list; and ii) in the safety stock demand list, subtract the non-safety demand quantity from the safety stock quantity of the earliest demand to provide an updated safety stock quantity of the earliest demand. In some embodiments, in updating the safety stock demand list, the software can be further configured to: compare the safety stock demand quantity in the safety stock demand list to the safety stock quantity; and add a new safety stock demand if the safety stock quantity is greater than the safety stock demand quantity.
The details of one or more embodiments of the subject matter of this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
To easily identify the discussion of any particular element or act, the most significant digit or digits in a reference number refer to the figure number in which that element is first introduced.
Supply chain 100 may include any number of nodes 124, 126, 128, 130, 132 and 134. In addition, supply chain 100 may include any number of links 104, 106, 108, 110, 112, 114, 116, 118, and 120 that are configured between the nodes.
In the example supply chain 100 shown in
Items in the supply chain 100 may include products, parts, components, raw material, and other entities known in the art. Inventory may be a class of item that is stored at a node in order to meet demand and/or manage supply risk. While one supplier 102 is shown in example supply chain 100, it is understood that one or more suppliers may form part of supply chain 100. Similarly, while four customers are shown in
According to the illustrated embodiment, system 200 can include a client system 216, a server 202 and a database 218 coupled as shown in
According to the illustrated embodiment, server 202 may include disk 204, one or more processors 206, memory 208 and one or more applications 214 coupled as shown in
In some embodiments, memory 208 can be volatile memory, compared with disk 204 which can be non-volatile memory. While database 218 is illustrated as separate from server 202, database 218 can also be integrated into server 202, either as a separate component within server 202, or as part of at least one of memory 208 and disk 204.
System 200 can also include additional features and/or functionality. For example, system 200 can also include additional storage (removable and/or non-removable) including, but not limited to, magnetic or optical disks or tape. Such additional storage is illustrated in
According to
Supply chain planning engine 210 generates a supply chain plan. For example, supply chain planning engine 210 can generate a supply chain plan for supply chain 100 shown in
Supply chain planning engine 210 can generate a supply chain plan in accordance with input. Input may include, for example, information about demand, supply, or both. Demand information may include, for example, a demand forecast, work orders, work in progress, other information, or any combination thereof. Supply information may include, for example, the amount of supply, the supply lead times, the supply risk, other information, or any combination thereof.
Client system 216 and server 202 may each operate on one or more computers and may include appropriate input devices, output devices, mass storage media, processors, memory, or other components for receiving, processing, storing, and communicating information according to the operation of system 200. As used in this document, the term “computer” refers to any suitable device operable to accept input, process the input according to predefined rules, and produce output.
Client system 216, server 202, and database 218 may be integrated or separated according to particular needs. In some embodiments, the functions of both client system 216 and server 202 are provided using a single computer system, such as a single personal computer. In some embodiments, database 218 may reside within server 202. If any combination of client system 216, server 202, or database 218 are separated, they may be coupled to each other using a local area network (LAN), a metropolitan area network (MAN), a wide area network (WAN), a global computer network such as the Internet, or any other appropriate wireline, optical, wireless, or other link. Modifications, additions, or omissions may be made to system 200 without departing from the scope of the invention. For example, fewer or other components may perform the operations of system 200. For example, the operations of optimization engine 212 and supply chain planning engine 210 may be performed by one component, or the operations of optimization engine 212 may be performed by more than one component. Additionally, functions may be performed using any suitable logic comprising software, hardware, other logic, or any suitable combination of the preceding.
In
The real demand schedule of A 304 indicates that there is a high priority (H) demand for 400 units scheduled for April 10 and an H demand for 600 units scheduled for April 15.
In order to fulfill both the safety stock schedule of A 302 and the real demand schedule of A 304, the result is a full demand schedule of A 306, which is described as follows. On April 1, there is a safety stock (SS) demand of 600 units in order to satisfy the safety stock requirement of 600 units on April 1 (as shown in safety stock schedule of A 302). On April 10, there is a H demand of 400 units and on April 15, there is a H demand of 600 units. On April 22, the safety stock schedule of A 302 indicates a jump of 500 units (from 100 to 600), requiring a safety stock (SS) demand of 500 units.
The planned order schedule of A 308 is derived from full demand schedule of A 306 and the safety stock schedule of A 302 as follows. On April 1, there is a stock supply (SS) of 600 units required in order to satisfy the safety stock requirement of 600 units on April 1 (as shown in safety stock schedule of A 302). This results in a low priority planned order (PO) of 600 units on April 1. On April 9, there is a drop of 500 units (from 600 to 100). This drop is seen as the safety stock supply (SSS) of A. The release of safety stock supply (SSS) allows for the availability of 500 units for future demands.
On April 10, the high priority (H) real demand of 400 units is filled by the safety stock supply (SSS) of 500 units that were made available on April 9, leaving 100 units in the safety stock supply (SSS) available for future real demands. On April 15, the High Priority demand of 600 units is partially filled by the 100 units remaining in the safety stock supply (SSS), requiring a high priority PO of 500 units. This is the last of the high priority demands on A.
On April 22, the safety stock schedule of A 302 indicates a jump of 500 units (from 100 to 600), requiring a stock supply (SS) demand of 500 units, which is filled by a low priority PO of 500 units. Therefore, the planned order schedule of A 308 requires two low priority POs (600 units on April 1 and 500 units on April 22) and one high priority PO (500 units on April 15).
The planned orders created at A spins off dependent demands on B. The priorities of the planned orders at A are inherited by the demands that are created at B. That is, B has inherited: a L demand of 600 units on April 1, a H demand of 500 units on April 15 and a L demand of 500 units on April 22. These are all demands originating from A. In addition, the safety stock schedule of B 310 indicates that there are 500 units maintained in the safety stock of B from March 18 to April 10.
The safety stock schedule of B 310 and the real demand schedule of B 312 combine to provide the full demand schedule of B 314, which is described as follows. On March 18, the safety stock of B jumps from 0 to 500, resulting in a safety stock (SS) demand of 500 units. The remaining demands are 600 low priority (L) units on April 1, 500 high priority (H) units on April 16 and 500 low priority (L) units on April 22.
The planned order schedule of B 316 is derived from the full demand schedule of B 314 and the safety stock schedule of B 310 as follows. The 500 safety stock (SS) demand on March 18 is filled by a L PO of 500 units. Similarly, the L demand of 600 units on April 1 is filled by a L PO of 600. On April 10, the safety stock supply of B drops from 500 units to 0 units, making 500 units available for future demands on B. On April 15, the HP demand of 500 units is filled by the 500 units of SSS made available on April 10. There are no more units in the SSS available for future demands. Therefore, the last LP demand of 500 units on April 22 is filled by a LP PO of 500 units. That is, the planned order schedule of B 316 requires a total of three LP POs: 500 units on March 18, 600 units on April 1 and 500 units on April 22.
The problem with the planned order schedule of B 316 is that none of the planned orders are high priority, even if these are satisfying high priority demands on A. This has negative implications for fulfilling high priority demands in time, as illustrated in the conventional examples shown in
Receiver 404 has a safety stock schedule 502, real demand schedule 504 and planned order schedule 506.
The safety stock schedule 502 requires a safety stock level of 2,000 units from April 1 to April 15; a drop of 1,000 units to 1,000 units on April 15, which is maintained until April 22, and then a drop of 1,000 units to 0 units on April 22.
The real demand schedule 504 indicates a safety stock (SS) demand of 2,000 units on April 1, in order to fulfill the safety stock requirement of 2,000 units on April 1. Then there are three high priority (H) demands: on April 8, a H demand for 1,000 units; a H demand for 1,000 units on April 15; and a H demand for 1,000 units on April 22.
The planned order schedule 506 is then derived from the safety stock schedule 502 and the real demand schedule 504 as follows. On April 1, there is a PO of 2,000 units at low priority, in order to fulfill the safety stock (SS) demand of 2,000 units for the safety stock requirement of 2,000 units. On April 8, there is a high priority planned order to fulfill the H demand of 1,000 units. On April 15, the safety stock drops 1,000 units (from 2,000 to 1,000, according to the safety stock schedule 502), allowing for 1,000 units as Safety Stock Supply (SSS) to be available for any demand on or after April 15. On April 15, there is a H demand of 1,000 units, which can be filled by the 1,000 units available from the drop. Therefore, there is no need for a planned order for the high priority demand of 1,000 units on April 15. On April 22, there is further drop in the safety stock supply of 1,000 units, as the safety stock level goes from 1,000 units to 0 units. These 1,000 units are available to fill the H demand of 1,000 units on April 22. Therefore, there is no need for a planned order for the H demand of 1,000 units on April 22. The planned order schedule 506 thus include two planned orders: one SS priority PO of 2,000 units on April 1 (for the safety stock of A) and one high priority PO of 1,000 units on April 8.
Receiver 406 has a real demand schedule 508 and planned order schedule 510. In this scenario, receiver 406 has no safety stock schedule, and therefore, no safety stock demands. The real demand schedule 508 indicates a medium priority (M) demand of 500 units on April 15 and medium priority (M) demand for 500 units on April 22.
The planned order schedule 510 is then derived from the real demand schedule 508 quite straightforwardly since there is no safety stock supply. The planned order schedule 510 thus include two planned orders: one medium priority (M) PO of 500 units on April 15 (to fill the M demand of 500 units on April 15) and one medium priority (M) PO of 500 units on April 22 (to fill the M demand of 500 units on April 22).
The real demand schedule 512 of supplier 402 is derived from the planned order schedule 506 of receiver 404 and the planned order schedule 510 of receiver 406. Therefore, real demand schedule 512 includes a L demand of 2,000 units on April 1 (for safety stock of receiver 404); a H demand of 1,000 units on April 8 (based on the H planned order of 1,000 units on April 8 for receiver 404); a M demand of 500 units on April 15 (based on the M planned order of 500 units for receiver 406); and a M demand of 500 units on April 22 (based on the M planned order of 500 units for receiver 406). Since supplier 402 is providing the units for each of receiver 404 and receiver 406, it has a manufacturing schedule 514 to manufacture units required by each receiver. In this embodiment, manufacturing schedule 514 is set at the production of 1,000 units every week, for four weeks, beginning on April 8.
Similarly, the 500 units manufactured by supplier 402 on April 15 fulfill the M demand order (by supplier 402) of 500 units on April 15. This demand originates from the M demand of 500 units on April 15 by receiver 406. This demand is fulfilled successfully on time as shown by arrow 604.
Finally, the 500 units manufactured by supplier 402 on April 22 fulfill the M demand order (by supplier 402) of 500 units on April 22. This demand originates from the MP demand of 500 units on April 22 by receiver 406. This demand is fulfilled successfully on time as shown by arrow 606.
Note however, that real demand schedule 512 and manufacturing schedule 514 of supplier 402 fail to fulfill the receiver 404 H demand of 1,000 units on April 15 and the receiver 404 H demand of 1,000 units on April 22. The medium priority demands of receiver 406 are satisfied in a constrained condition ahead of two high priority demands of receiver 404. Two H demands by receiver 404 are late, which has negative consequences for receiver 404.
The safety stock schedule of A 702 and the full demand schedule of A 704 are identical with those of the conventional example shown in
The safety stock schedule of B 710 is identical with the safety stock schedule of B 310 in
In
The exemplary demand transformation shown in
If the demand is a safety stock demand (step 804), then the demand is added to a safety stock demand list at step 806. Each entry in the safety stock demand list includes the date and quantity of the safety stock demand. After step 806, the method checks to see if this is the last demand at step 818. If it is, the program ends (step 820). If not, the method proceeds to the next demand at step 822 and reverts to step 802 to begin processing the next demand.
If, on the other hand, the demand is not a safety stock demand (i.e. it is a real demand), then the method looks to the safety stock demand list at step 808. If the list is empty, then the method checks to see if this real demand is the last demand (step 818). If it is, the program ends (step 820). If not, the method proceeds to process the next demand at step 822 and begins the process of analyzing the type of demand at step 804.
If the safety stock demand list is not empty, then the demand is transformed using the earliest safety stock demand in the list at step 810. Details of the transformation are described in
Definitions 928 are as follows: a real demand has a real demand amount (DA) at a real demand date (DD). At step 810, the earliest safety stock demand (in the safety stock demand list) has a safety stock demand amount (SA) at a safety stock demand date (SD). The next steps depend on the relationship between the safety stock amount (SA) and the real demand amount (DA).
Where SA=DA (at block 902), the transformation of the real demand using the earliest safety stock demand is described at block 904. The demand amount (DA) is completely transferred to the safety stock demand date (SD). The real demand date (DD) is eliminated and the new safety stock demand amount is set to zero (since it is wholly transferred to DA). The safety stock demand list is updated at block 906 by eliminating the earliest safety stock demand in the safety stock demand list. That is, the new safety stock demand amount (New SA) (in the safety stock demand list) is zero. The safety stock demand list is then further updated by comparing the new safety stock demand amount (new SA) with the safety stock level (SSL) at the real demand date (DD) at block 918 and block 920. If the safety stock level (SSL) is greater than what is in the updated safety stock demand list, then a new safety stock demand must be created for an amount equal to (SSL-NEW SA) at the real demand date (DD) at block 924. The safety stock demand list is then updated at block 924 to reflect the new safety stock demand. If the safety stock level (SSA) is not less than the new safety stock demand amount (new SA) on the real demand date (DD), then the safety stock demand list is not updated (since no new safety stock demand has been created).
Where SA>DA (at block 908), the transformation of the real demand using the earliest safety stock demand is described at block 910. The real demand amount (DA) is completely transferred to the safety stock demand date (SD). The real demand date (DD) is eliminated and the new safety stock demand amount (new SA) is set to (SA-DA), since it is partly transferred to DA. The safety stock demand list is updated at block 916 by replacing the safety stock demand amount (SA) with the new safety stock demand amount (New SA) at the safety stock demand date (SD). The safety stock demand list is then further updated at steps 718-724, as described above.
Where SA<DA (at block 912), the transformation of the real demand using the earliest safety stock demand is described at block 914. A partial demand amount equal to the safety stock demand amount (SA) is transferred to the safety stock demand date (SD). The safety stock demand amount is thus set to zero. The remaining portion of the real demand amount (equal to DA-SA) is maintained at the real demand date (DD). At block 926, since the safety stock demand amount has been completely used, it is eliminated from the safety stock demand list. The safety stock demand list is then further updated at steps 718-724, as described above.
The flowcharts of
The initial full demand schedule of A 704 is as follows:
The above demands are processed according to the flowcharts shown
The first demand is on April 1. Block 1002 indicates a safety stock demand in an amount of 600 units (LP). According to
The safety stock demand list 1004 indicates one safety stock demand on April 1 for 600 units, which will be used when processing the next demand.
The next demand is on April 10. Block 1006 indicates a real demand in an amount of 400 units (HP). According to
Update safety stock demand list based on current safety stock level (step 816)
The last four steps are performed according to
The result is shown in block 1008, where there are now two demands on April 1: a real (H) demand of 400 units and a safety stock (SS) demand of 200 units. The updated safety stock demand list (SSDL) 1010 indicates a safety stock demand of 200 units on April 1.
The next demand is on April 15. Block 1102 indicates a real H demand in an amount of 600 units, According to
The last four steps are performed according to
The result is shown in block 1104, where there are now two demands on April 15: a HP real demand of 400 units and a safety stock (SS) demand of 100 units. The updated safety stock demand list (SSDL) 1106 indicates a safety stock demand of 100 units on April 15.
The next demand is on April 22. Block 1104 indicates a safety stock (SS) demand in an amount of 500 units. According to
The result is shown in block 1108, where there is one demand on April 22: a safety stock (SS) demand of 100 units. The updated safety stock demand list (SSDL) 1110 indicates two safety stock demands: 100 units on April 15; and 500 units on April 22.
Turning to
By following the flowchart of
The above transformed demand results for supplier B are obtained as follows.
First demand is on March 18 for 500 units for a safety stock (SS) demand
Process next demand date (step 802)
Safety Stock List (SSDL)={demand at 03-18, Qty=500}
Next chronological demand is on April 1 for 400 H units for a real demand for April 10
Safety Stock List (SSDL)={demand at 03-18, Qty=100; demand at 04-01, Qty=400}
Next chronological demand is on April 1 for 200 H units for a real demand for April 15.
Next, process real demand of 100 L units on April 15.
Final demand is on April 22 for a real demand of 500 L units:
Real Demand of 100 L units (for April 22) is on April 22
From the above transformations, we see that the following transformed demands are obtained:
Real Demand of 400 H units (for April 10) is on March 18
Real Demand of 100 H units (for April 15) is on March 18
Real Demand of 100 H units (for April 15) is on April 1
Real Demand of 100 L units (for April 15) is on April 1
Real Demand of 100 LP units (for April 22) is on April 22
This matches the transformed demand schedule of B 714 shown in
illustrates a transformation of demand schedules in accordance with one embodiment. The examples of supplier 402, receiver 404 and receiver 406, shown in
Once the demand transformation is applied to real demand schedule 504, the resulting transformed demand schedule 1404 of receiver 404 is obtained, in which there are the following three real demands:
On April 1, 1,000 (H) units for 04-08
On April 1, 1,000 (H) units for 04-15
On April 8, 1,000 (H) units for 04-22
Since receiver 406 has no safety stock schedule, the real demand schedule 508 remains unchanged.
The transformed demand schedule 1404 and real demand schedule 508 are downloaded onto supplier 402. Since supplier 402 has no safety stock schedule, the downloaded schedule becomes the transformed demand schedule 1402 of supplier 402. The implications of transformed demand schedule 1402 of supplier 402 on the supply chain management schedule are shown in
Looking to manufacturing schedule 514 and transformed demand schedule 1402 of supplier 402, the first 1,000 units produced on April 8 will fill the first transformed demand on April 1—namely the real (H) demand for 1,000 units for April 8. That is, the 1,000 (H) real demand on April 8 by receiver 404, is filled on time, as indicated by arrow 1502.
Continuing with the manufacturing schedule 514 and the transformed demand schedule 1402 of supplier 402, the next 1,000 units are produced on April 15. These will fill the next real demand order of April 1—namely 1,000 (H) units for April 15. That is, the 1,000 (H) real demand on April 15 by receiver 404, is filled on time, as indicated by arrow 1504.
Continuing with the manufacturing schedule 514 and the transformed demand schedule 1402 of supplier 402, the next 1,000 units are produced on April 22. These will fill the next real demand order of April 8—namely 1,000 (H) units for April 22. That is, the 1,000 (H) real demand on April 22 by receiver 404, is filled on time, as indicated by arrow 1506.
Continuing with the manufacturing schedule 514 and the transformed demand schedule 1402 of supplier 402, the next 1,000 units are produced on April 29. These will fill the next real demand order of April 15—namely 500 (M) units for April 15. However, this order is filled late, as indicated by 1508. The same holds true for the April 22 demand for 500 (M) units, which will be filled late.
However, the situation in
When the demand transformation is used, as shown in the embodiment of
As in
Safety stock of 2000 units from April 1 to April 14; 1000 units from April 15 to April 21; and 0 units on April 22
High priority (H) real demand on April 8
High priority (H) real demand on April 15
Low priority (L) real demand on April 22
There is no safety stock for receiver 406 The real demand schedule 1612 of receiver 406, shown in
Medium priority (M) real demand on April 15
Medium priority (M) real demand on April 22
The manufacturing schedule 1610 of supplier 402 is as follows:
1000 units produced weekly on April 8, April 15, April 22 and April 29
Once the demand transformation is applied to real demand schedule 1604, the resulting transformed demand schedule 1606 of receiver 404 is obtained, in which there are the following three real demands:
On April 1, 1,000 (H) units for 04-08
On April 1, 1,000 (H) units for 04-15
On April 8, 1,000 (L) units for 04-22
Since receiver 406 has no safety stock schedule, the real demand schedule 1612 remains unchanged.
The transformed demand schedule 1606 and real demand schedule 1612 are downloaded onto supplier 402. Since supplier 402 has no safety stock schedule, the downloaded schedule becomes the transformed demand schedule 1608 of supplier 402. The implications of transformed demand schedule 1608 of supplier 402 on the supply chain management schedule are shown in
Looking to manufacturing schedule 1610 and transformed demand schedule 1608 of supplier 402, the first 1,000 units produced on April 8 will fill the first transformed demand on April 1—namely the real (H) demand for 1,000 units for April 8. That is, the 1,000 (H) real demand on April 8 by receiver 404, is filled on time, as indicated by arrow 1702.
Continuing with the manufacturing schedule 1610 and the transformed demand schedule 1608 of supplier 402, the next 1,000 units are produced on April 15. These will fill the next real demand order of April 1—namely 1,000 (H) units for April 15. That is, the 1,000 (H) real demand on April 15 by receiver 404, is filled on time, as indicated by arrow 1704.
Continuing with the transformed demand schedule 1608 and the manufacturing schedule 1610 of supplier 402, the next 1,000 units are produced on April 22. These will fill the next two real demand medium priority orders of 500 units each. Supplier 402 fills orders in order of demand priority—not chronological order. This is why the April 15 and April 22 real demands of 500 medium priority (M) units are filled before the April 8 real demand of low priority (L) units. However, the April 15 real (M) demand of 500 units is filled late, as indicated by arrow 1706, whereas the April 22 real (M) demand of 500 units is on time (as indicated by arrow 1708).
Continuing with the transformed demand schedule 1608 and the manufacturing schedule 1610 of supplier 402, the next 1,000 units are produced on April 29. These will fill the next real demand order of April 8—namely 100 (L) units for April 22. However, this order is filled late, as indicated by 1710.
However, compared with
Although the algorithms described above including those with reference to the foregoing flow charts have been described separately, it should be understood that any two or more of the algorithms disclosed herein can be combined in any combination. Any of the methods, modules, algorithms, implementations, or procedures described herein can include machine-readable instructions for execution by: (a) a processor, (b) a controller, and/or (c) any other suitable processing device. Any algorithm, software, or method disclosed herein can be embodied in software stored on a non-transitory tangible medium such as, for example, a flash memory, a CD-ROM, a floppy disk, a hard drive, a digital versatile disk (DVD), or other memory devices, but persons of ordinary skill in the art will readily appreciate that the entire algorithm and/or parts thereof could alternatively be executed by a device other than a controller and/or embodied in firmware or dedicated hardware in a well-known manner (e.g., it may be implemented by an application specific integrated circuit (ASIC), a programmable logic device (PLD), a field programmable logic device (FPLD), discrete logic, etc.). Further, although specific algorithms are described with reference to flowcharts depicted herein, persons of ordinary skill in the art will readily appreciate that many other methods of implementing the example machine readable instructions may alternatively be used. For example, the order of execution of the blocks may be changed, and/or some of the blocks described may be changed, eliminated, or combined.
It should be noted that the algorithms illustrated and discussed herein as having various modules which perform particular functions and interact with one another. It should be understood that these modules are merely segregated based on their function for the sake of description and represent computer hardware and/or executable software code which is stored on a computer-readable medium for execution on appropriate computing hardware. The various functions of the different modules and units can be combined or segregated as hardware and/or software stored on a non-transitory computer-readable medium as above as modules in any manner and can be used separately or in combination.
Particular embodiments of the subject matter have been described. Other embodiments are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking and parallel processing may be advantageous.