1. Field of the Invention
The embodiments disclosed herein relate to production planning and, more particularly, to a method, system and program storage device for production planning in manufacturing.
2. Description of the Related Art
Generally, in production planning in manufacturing, a customer demand refers to a demand (e.g., an actual order or forecasted order) to produce an item and, specifically, to produce a specified number (i.e., quantity) of that item by a given date. The item can refer, for example, to an end product, an assembly, a sub-assembly, a component, etc. A fundamental problem in production planning is that, at any given time, customer demands for the item may be either greater than the current manufacturing production capacity (i.e., greater than the expected output, by the manufacturer, of that item in a given period of time) or less than the current manufacturing production capacity. If the customer demands in a given period of time are greater than the manufacturing production capacity, at least some of those demands will not be met. However, if the customer demands in a given period of time are less than the manufacturing production capacity, manufacturing resources (i.e., anything required for production, such as production facilities or plants, production lines, supplies, etc.) will be under-utilized. Therefore, there is a need in the art for a production planning technique that, for a given time horizon, levels out customer demands in a manner that both achieves near-capacity manufacturing and, thereby avoids under-utilization of manufacturing resources and also ensures that at least some customer demands and, particularly, all high priority customer demands, are met.
In view of the foregoing, disclosed herein are embodiments of a production planning method, system and program storage device. The embodiments can calculate and compare, in sequence, a first running cumulative sum of the average item quantity per a regular time interval (e.g., per day) for all demands within a specified time period and a second running cumulative sum of specific item quantities per the same regular interval (e.g., per day) for only high priority demands within the same specified time period. When a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, demand leveling can be performed. That is, a leveling item quantity can be added to the average item quantities associated with at least some entries up to and including the given entry. Then, the first running cumulative sum can be re-calculated to generate an updated first running cumulative sum. The comparing and demand leveling processes can be iteratively repeated until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the second running cumulative sum (i.e., until demand leveling is achieved). The results of such demand leveling can then be used for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands.
More particularly, disclosed herein are embodiments of a computer-implemented production planning method in manufacturing. The method embodiments can comprise storing, in memory, multiple demands. These multiple demands can comprise high priority demands and low priority demands.
The method embodiments can further comprise determining the total item quantity associated with all demands within a specified time period. Then, based on the total item quantity and for each regular time interval (e.g., each day) within the specified time period, an average item quantity can be determined (e.g., a daily average item quantity). Next, for all demands within the specified time period, a first running cumulative sum of the average item quantities can be calculated from a first regular time interval (e.g., a first day) to a last regular time interval (e.g., a last day) in sequence. Additionally, for only high priority demands within the specified time period, a second running cumulative sum of specific item quantities can be calculated from the first regular time interval (e.g., the first day) to the last regular time interval (e.g., the last day) in sequence.
Entries in the first running cumulative sum can then be compared, in sequence beginning with the first regular time interval (e.g., beginning with the first day), to corresponding entries in the second running cumulative sum. Specifically, the entries in the running cumulative sums can be compared in sequence to determine if a given entry in the first running cumulative sum associated with all of the demands within the specified time period is less than a corresponding entry in the second running cumulative sum associated with only the high priority demands within the specified time period.
When a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, demand leveling can be performed. Specifically, a demand-leveling item quantity can be added to the average item quantity associated with at least some entries up to and including the given entry. Then, the first running cumulative sum can be re-calculated in order to generate an updated first running cumulative sum. The comparing and demand leveling processes can be iteratively repeated until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the running cumulative sum associated with only high priority demands (i.e., until demand leveling is achieved). The results of such demand leveling can then be used for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands.
Also disclosed herein are embodiments of a computer system for production planning in manufacturing. This system can comprise a memory and one or more processors in communication with the memory.
The memory can store multiple demands. The multiple demands can comprise high priority demands and low priority demands.
The processor(s) can determine the total item quantity associated with all demands within a specified time period. Next, based on the total item quantity and for each regular time interval (e.g., each day) within the specified time period, the processor(s) can determine an average item quantity (e.g., daily average item quantity). Then, the processor(s) can calculate two different running cumulative sums: (1) for all demands within the specified time period, a first running cumulative sum of the average item quantities from a first regular time interval (e.g., a first day) to a last regular time interval (e.g., a last day) in sequence; and (2) for the high priority demands only, a second running cumulative sum of the specific item quantities from the first regular time interval (e.g., the first day) to the last regular time interval (e.g., the last day) in sequence.
The processor(s) can further compare, in sequence beginning with the first regular time interval (e.g., beginning with the first day), entries in the first running cumulative sum to corresponding entries in the second running cumulative sum. Specifically, the processor(s) can compare, in sequence, the entries in the running cumulative sums to determine if a given entry in the first running cumulative sum associated with all of the demands within the specified time period is less than a corresponding entry in the second running cumulative sum associated with only the high priority demands within the specified time period.
When a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, the processor(s) can further perform demand leveling. Specifically, the processor(s) can add a demand-leveling item quantity to the average item quantity associated with at least some entries up to and including the given entry. Then, the first running cumulative sum can be re-calculated in order to generate an updated first running cumulative sum. The comparing and demand leveling processes can be iteratively repeated by the processor(s) until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the running cumulative sum associated with only high priority demands (i.e., until demand leveling is achieved). The results of such demand leveling can then be output by the computer system and used for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands.
Also disclosed herein are embodiments of a non-transitory program storage device. The program storage device can be readable by a computer and can tangibly embody a program of instructions executable by the computer to perform the production planning method, as described in detail above.
The embodiments herein will be better understood from the following detailed description with reference to the drawings, which are not necessarily drawing to scale and in which:
The detailed description of the embodiments below is provided for purposes of illustration and is not intended to be exhaustive. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, and/or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
As mentioned above, generally, in production planning in manufacturing, a customer demand refers to a demand (e.g., an actual order or forecasted order) to produce an item and, specifically, to produce a specified number (i.e., quantity) of that item by a given date. The item can refer, for example, to an end product, an assembly, a sub-assembly, a component, etc.
In view of the foregoing, disclosed herein are embodiments of a production planning method, system and program storage device. The embodiments can calculate and compare, in sequence, a first running cumulative sum of the average item quantity per a regular time interval (e.g., per day) for all demands within a specified time period and a second running cumulative sum of specific item quantities per the same regular interval (e.g., per day) for only high priority demands within the same specified time period. When a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, demand leveling can be performed. That is, a leveling item quantity can be added to the average item quantities associated with at least some entries up to and including the given entry. Then, the first running cumulative sum can be re-calculated to generate an updated first running cumulative sum. The comparing and demand leveling processes can be iteratively repeated until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the second running cumulative sum (i.e., until demand leveling is achieved). The results of such demand leveling can then be used for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands.
More particularly, referring to the flow diagram of
Specifically, the method embodiments can comprise receiving, by the computer system, and storing, in memory, multiple demands (e.g., customer orders, either actual or forecasted) for an item (202). This item can, for example, comprise an end product, an assembly, a sub-assembly, a component, etc. Each demand can specify an item quantity (i.e., a specified quantity of the item) and a date (e.g., a delivery date, a due date, etc.).
The demands can further be sorted, by the computer system, into two groups: high priority demands and low priority demands (204). The process 204 of sorting the demands into high and low priority demands can be performed according to predefined sorting rules (e.g., as stored in memory). Such sorting rules can specify, for example, that any demands associated with actual customer orders are to be considered high priority demands and any demands associated with forecasted customer orders are to be considered low priority demands. Alternatively, the sorting rules can specify that any demands associated with large item quantities (e.g., >100, >1000, >10,000, etc.) are to be considered high priority demands and any demands associated with low item quantities (e.g., <100, <1000, <10,000, etc.) are to be considered low priority demands. Alternatively, the sorting rules can specify that any demands associated with specific customers by name are to be considered high priority demands and all other demands are to be considered low priority demands. It should be understood that the exemplary sorting rules discussed above are offered for illustration purposes and, alternatively, any other predefined rules that can be used to sort demands into groups with different priorities for purposes of production planning could be used.
It should be noted that this sorting process could be performed in conjunction with or immediately following (as shown) the storage of the demands in memory at process 202. Alternatively, this sorting process can be performed at some later time prior to the calculation or a running cumulative sum at process step 214, discussed in detail below (e.g., in conjunction with or immediately following the selection of any demands falling within the specified time period at process 206, as discussed in detail below).
Once the demands are stored in memory, the memory can be accessed in order to select (i.e., identify), for production planning purposes, any demands that fall within a specified time period in the future (i.e., a specified time horizon) (206). That is, the stored demands can be reviewed to identify any demand having a date that falls within the specified time period. The specified time period can comprise, for example, a specified number of days, a week, a month, a quarter year, a half year, a year, etc. and can begin as of the current date or some further date.
The method embodiments can further comprise performing, by the computer system, a number of calculations with respect to all the demands falling within the specified time period and also with respect to only high priority demands falling within the specified time period (208-216).
Specifically, the total item quantity associated with all demands that fall within the specified time period can be calculated (208). That is, the demands that fall within the specified time period can be reviewed, and the total sum of items to be manufactured according to those demands can be determined. Then, a regular time interval within the specified time period (e.g., a work shift, a day, a specified number of days, a week, a month, etc.) can be selected and, for all demands within the specified time period, the average item quantity at that regular time interval can be calculated (210). For example, if the selected regular time interval is a day, a daily average item quantity within the specified time period can be calculated; if the selected regular time interval is a single work shift, the average item quantity for each work shift within the specified time period can be calculated; and so on.
Next, for all of the demands within the specified time period, a first running cumulative sum of average item quantities can be calculated from a first regular time interval (e.g., a first day) to a last regular time interval (e.g., a last day) in sequence (212). Specifically, in calculating the first running cumulative sum: a first entry for the first regular time interval (e.g., the first day) will be equal to the average item quantity determined at process 210; a second entry for the second regular time interval (e.g., the second day) will be equal to the value from the first entry plus the average item quantity determined at process 210; a third entry for the third regular time interval (e.g., the third day) will be equal to the value of the second entry plus the average item quantity determined at process 210; and so on.
Additionally, for only the high priority demands within the specified time period, a second running cumulative sum of specific item quantities can be calculated from the first regular time interval (e.g., the first day) to the last regular time interval (e.g., the last day) in sequence (214). Specifically, in calculating the second running cumulative sum: a first entry for the first regular time interval (e.g., the first day) will be equal to the specific item quantity associated with the high priority demands only and due in the first regular time interval (e.g., due on the first day); a second entry for the second regular time interval (e.g., the second day) will be equal to the value from the first entry plus the specific item quantity associated with the high priority demands only and due in the second regular time interval (e.g., due on the second day); a third entry for the third regular time interval (e.g., a third day) will be equal to the value from the second entry plus the specific item quantity associated with the high priority demands only and due in the third regular time interval (e.g., on the third day); and so on.
Entries in the first running cumulative sum can then be compared, by the computer system and in sequence beginning with the first regular time interval (e.g., beginning with the first day), to corresponding entries in the second running cumulative sum and demand leveling can be performed (216). Specifically, referring to
If or when it is determined (e.g., at 301a, 301b, 301c, . . . or at 301e) that a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, demand leveling can be performed (e.g., automatically and immediately) by the computer system (302). That is, a leveling item quantity can be added to the average item quantities associated with at least some of the entries up to and including the given entry.
Specifically, when a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, the difference between the given entry and the corresponding entry can be divided by the entry number within the first running cumulative sum wherein the difference is found (e.g., the day number, such as day 20). Then result (i.e., the quotient) can be added to the average item quantity associated with at least some entries up to and including the given entry (e.g., to the daily average item quantity associated with at least some entries between the first day and the day on which the given entry is found). This process can be performed according to pre-defined demand-leveling rules.
For example, a demand-leveling rule can indicate that, if the difference between the given entry in the first running cumulative sum and its corresponding entry in the second running cumulative sum divided by the number of the given entry is less than one time, one item can be added to each of the average item quantities in sequence starting with the average item quantity associated with the first entry until the entire difference is accounted for. For example, a difference of 15 divided by an entry number of 20 is less than one, so one item can be added to the average item quantity associated with each of the first fifteen entries. Alternatively, in this case, the demand-leveling rule can indicate that one item can be added to the average item quantity associated with 15 different uniformly distributed entries from the entry 1 to entry 20 (e.g., to entries 1-3, 5-7, 9-11, 13-15 and 17-29). Alternatively, in this case, the demand-leveling rule can indicate that the result (i.e., the quotient) be rounded up to one and one item can be added to the average item quantity associated each of the entries 1-20.
Another demand-leveling rule can indicate that, if the difference between the given entry in the first running cumulative sum and its corresponding entry in the second running cumulative sum divided by the number of the given entry is equal to a whole number (i.e., if the difference can be divided equally be the entry number), that whole number of items can be added to the average item quantities associated with all entries up to and including the given entry. For example, a difference of 100 divided by an entry number of 20 is exactly 5, so 5 can be added to the average item quantity associated with entries 1-20.
Finally, yet another demand-leveling rule can indicate that, if the difference between the given entry in the first running cumulative sum and its corresponding entry in the second running cumulative sum cannot be divided equally by the entry number and if the result is greater than one (i.e., if the result is a whole number plus a remainder), that whole number of items can be added to the average item quantities associated with the first entry through the given entry, plus one additional item can be added to the entries in sequence starting with the average item quantity associated with the first entry until the entire remainder is accounted for. For example, a difference of 83 divided by an entry number of 20 is 4 with a remainder of 3, so 4 can be added to the average item quantities associated with entries 1-20 and one additional item can be added to the entries 1-3. Alternatively, in this case, the demand-leveling rule can indicate that, instead of adding one additional item to entries 1-3, the one additional item can be distributed approximately uniformly to the average item quantities associated with 3 different uniformly distributed entries from the first entry to twentieth entry (e.g., to entries 1, 10, and 19). Alternatively, in this case, the demand-leveling rule can indicate that the result (i.e., the quotient) can be rounded up to the next whole number (e.g., 5) and that next whole number of items can be added to the average item quantities associated with all of the entries 1-20.
Once the leveling item quantity is added, as discussed above, the first running cumulative sum can be re-calculated in order to generate and updated first running cumulative sum (302).
Then, the comparing and demand leveling processes can be iteratively repeated (303) until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the second running cumulative sum associated with only high priority demands (i.e., until demand leveling is achieved). That is, referring again to
It should be noted that, as a result of demand leveling, demands are shifted towards the beginning of the specified time period and, thus, the total item quantity associated with all demands will likely be met prior to the end of the specified time period.
The results of such demand leveling (i.e., the final output and, particularly, the finally updated first running cumulative sum following process step 301e) can then be used as the goal for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands (218).
Referring to
Specifically, the system 400 can comprise memory device(s) that store (i.e., are adapted to store, are configured to store, etc.) multiple demands 401 (e.g., customer orders, either actual or forecasted) for an item. This item can, for example, comprise an end product, an assembly, a sub-assembly, a component, etc. Each demand can specify an item quantity (i.e., a specified quantity of the item) and a date (e.g., a delivery date, a due date, etc.). The memory device(s) can further store (i.e., can be adapted to store, configured to store, etc.) pre-defined demand sorting rules 402, pre-defined demand-leveling rules 403, etc., as discussed in detail below.
The demand sorter 410 can sort (i.e., can be adapted to sort, programmed to sort, configured to sort, etc.) demands into two groups: high priority demands and low priority demands. The demand sorter 410 can specifically sort the demands into high and low priority demands according to predefined sorting rules 402 stored in memory (e.g., in the same manner as discussed in detail above with regard to process step 204 of
The demand selector 420 can access and review the demands and, based on the review, can select (i.e., can be adapted to select, can be configured to select, can be programmed to select, etc.) any demands that fall within a specified time period in the future (i.e., a specified time horizon) for production planning purposes (e.g., in the same manner as discussed in detail above with regard to process step 206 of
The calculator 430 can be in communication with the demand selector 420 and can perform (i.e., can be adapted to perform, can be configured to perform, can be programmed to perform, etc.) a number of calculations with respect to all those demands falling within the specified time period and also with respect to only high priority demands falling within the specified period of time. Specifically, the calculator 430 can calculate the total item quantity associated with all demands that fall within the specified time period can be calculated. That is, demands that fall within the specified time period can be reviewed, and the total sum of items to be manufactured can be determined (e.g., in the same manner as discussed in detail above with regard to process step 208 of
Based on the total item quantity, the calculator 430 can further calculate the average item quantity at a regular time interval within the specified time period (e.g., in the same manner as discussed in detail above with regard to process step 210 of
Next, the calculator 430 can calculate, for all of the demands within the specified time period, a first running cumulative sum of average item quantities from a first regular time interval (e.g., a first day) to a last regular time interval (e.g., a last day) in sequence (e.g., in the same manner as discussed in detail above with regard to process step 212 of
Additionally, the calculator 430 can calculate, for only the high priority demands within the specified time period, a second running cumulative sum of specific item quantities from the first regular time interval (e.g., the first day) to the last regular time interval (e.g., the last day) in sequence (e.g., in the same manner as discussed in detail above with regard to process step 214 of
Next, the calculator 430 can compare entries in the first running cumulative sum, in sequence beginning with the first regular time interval (e.g., beginning with the first day), to corresponding entries in the second running cumulative sum and, based on the comparison, perform demand leveling (e.g., in the same manner as discussed in detail above with regard to process step 216 of
Specifically, the calculator 430 can compare the entries in the running cumulative sums in sequence to determine if a given entry in the first running cumulative sum associated with all of the demands within the specified time period is less than a corresponding entry in the second running cumulative sum associated with only the high priority demands within the specified time period. If or when the calculator 430 determines that a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, the calculator 430 can immediately and automatically perform demand leveling. That is, when a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, the calculator 430 can add a leveling item quantity to the average item quantities associated with at least some of the entries up to and including the given entry, as discussed in detail above with regard to process step 302 of
The calculator 430 can iteratively repeat the comparing and demand leveling processes until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the second running cumulative sum associated with only high priority demands (i.e., until demand leveling is achieved).
The computer system 400 can further comprise an output (e.g., a printer, a display, etc.) that outputs the results of such demand leveling (i.e., the final output and, particularly, the finally updated first running cumulative sum from the calculator 430) to be used as a goal for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands.
It should be noted that, as a result of demand leveling by the calculator 430, demands are shifted towards the beginning of the specified time period and, thus, the total item quantity associated with all demands will likely be met prior to the end of the specified time period.
It should be understood that the various components of the system 400 (e.g., the demand selector 420, demand sorter 410 and calculator 430) could be implemented, as illustrated, by discrete units (e.g., discrete computer systems or discrete computer processing units within the same computer system (i.e., discrete processors)). Alternatively, any two or more of these components could be implemented by a single unit (e.g., by a single computer system or by a single computer processing unit (i.e., a single processor)). Similarly, as described above and illustrated in
As indicated in column 501, each row in the table refers to a regular time interval and, particularly, a single day, in sequence within a specified time period of thirty days.
Column 502 shows the calculation, for all demands that fall within the specific time period, specific item quantities that fall due on specific days, also referred to as the demand quantity (see process steps 202 and 206 of
Column 506 shows the calculation of the average item quantity for each day (i.e., the daily average item quantity), which is equal to 103 and determined by dividing the total item quantity of 3100 from column 505 by the total number of days 30 within the specified time period from column 501, also referred to as the simply-leveled demand (see process step 210 of
Column 507 shows the calculation of the first running cumulative sum of the daily average item quantities associated with all demands within the specified time period from column 506, also referred to as the cumulative of the simply-leveled demand (see process step 212 of
Column 508 shows only the high priority demands from column 503 by day, also referred to as the prioritized demands. Column 509 shows only the low priority demands from column 503 by day, also referred to as the non-prioritized demands.
Column 510 shows the calculation of a second running cumulative sum of the specific item quantities associated with only the high priority demands from column 508 (i.e., the item quantities of 500, 1500 and 500 from days 7, 14, and 25, respectively), also referred to as the cumulative of prioritized demands (see process step 214). Specifically, in calculating this second running cumulative sum: days 1-6 will be 0; days 7-13 will 500, days 14-24 will be 2000 and days 25-30 will be 2500.
Column 511 shows the comparison of the first and second running cumulative sums and particularly, the calculation, for each day 1-30 in sequence, of the difference between an entry in the running cumulative sum of the daily average quantities associated with all demands, as shown in column 507, and the corresponding entry in the running cumulative sum of specific item quantities associated with the high priority demands only, as shown in column 510, also referred to as the delta between the cumulative of the simply-leveled demands and the cumulative of the prioritized demands (see process step 216 and also process steps 301a-e of
Columns 512-513 show demand leveling based on the comparison shown in column 511. Specifically, column 512 shows that the entry of −558 on day 14 of column 511 can be divided by the entry number (i.e., 14), that the result (i.e., the quotient) of 39.86 can be rounded up to 40 and that this 40 can be added to the average item quantities associated with each of the entries 1-14 of column 506. Thus, in column 512, which is also referred to as the re-leveled demand, the item quantities in entries 1-14 are increased to 143 and the item quantities in entries 15-30 remain at 103. Furthermore, column 513 shows re-calculation of the first running cumulative sum using the updated item quantities from column 513, also referred to as the updated first running cumulative sum or the cumulative of the re-leveled demands (see process step 216 and also process step 302 of
As mentioned above, the comparing and demand leveling processing should be repeated iteratively. For example, corresponding entries in column 514 and column 510 can be compared and, if necessary, demand leveling will again be performed. However, as illustrated, in this case none of the entries in column 514 are less than the corresponding entries in column 510.
It should be noted that, as a result of demand leveling, demands are shifted towards the beginning of the specified time period and, thus, the total item quantity of 3100 association will all demands is actually met on day 25 and production can stop at that time.
Also disclosed herein are embodiments of a non-transitory program storage device. The program storage device can be readable by a computer and can tangibly embody a program of instructions executable by the computer to perform the production planning method, as described in detail above. More specifically, as will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or program storage device (i.e., a computer program product). Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a non-transitory computer readable storage device or a computer readable signal medium. A non-transitory computer readable storage device may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the non-transitory computer readable storage device would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a non-transitory computer readable storage device may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
As mentioned above, the computer readable medium can alternatively comprise a computer readable signal medium that includes a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. This computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device. Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the disclosed embodiments may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the disclosed embodiments are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products. It will be understood that each block of the flowchart illustrations and/or D-2 block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
Referring now to
It should be understood that the flowcharts and block diagrams in the Figures referenced above illustrate the architecture, functionality, and operation of the various possible implementations of the disclosed systems, methods and computer program products. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in any block may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
It should further be understood that the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. Additionally, as used herein, the terms “comprises” “comprising”, “includes”, and/or “including”, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. It should further be understood that the corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. Additionally, it should be understood that the detailed description above is presented for purposes of illustration and is not intended to be exhaustive or limiting. More specifically, the detailed description was provided to best explain the principles and practical application of the disclosed embodiments and to enable others of ordinary skill in the art to understand the disclosed embodiments. Many modifications and variations to the embodiments will be apparent to those of ordinary skill in the art without departing from the scope and spirit thereof.
Therefore, disclosed above are embodiments of a production planning method, system and program storage device. The embodiments can calculate and compare, in sequence, a first running cumulative sum of the average item quantity per a regular time interval (e.g., per day) for all demands within a specified time period and a second running cumulative sum of specific item quantities per the same regular interval (e.g., per day) for only high priority demands within the same specified time period. When a given entry in the first running cumulative sum is less than a corresponding entry in the second running cumulative sum, demand leveling can be performed. That is, a leveling item quantity can be added to the average item quantities associated with at least some entries up to and including the given entry. Then, the first running cumulative sum can be re-calculated to generate an updated first running cumulative sum. The comparing and demand leveling processes can be iteratively repeated until none of the entries in the first running cumulative sum, as updated, are less than the corresponding entries in the second running cumulative sum (i.e., until demand leveling is achieved). The results of such demand leveling can then be used for production planning in order to achieve near-capacity manufacturing and meet at least the high priority customer demands. It should further be noted that the above-described embodiments base demand leveling on forward-looking customer inputs (e.g., actual and/or forecasted customer orders) as opposed to historical data. The results allow manufacturers to avoid potentially sacrificing customer satisfaction in order to benefit manufacturing, without requiring continuous updates as demands change. Additionally, the embodiments eliminate the potential of overbuilding by backing demand off at the end of the horizon (i.e., planning for less demand and the end of the horizon) and, as a result, minimize inventory costs. Consequently, the embodiments have the advantage of improving product yield, improving capacity utilization and increasing overall manufacturing output.