MANUFACTURING ADAPTIVE ORDER LOAD FOR COMPLEX CONFIGURE TO ORDER PRODUCTS
A data processing system (DPS) and a computer program product selectively modifies an existing production order based on a change request. An order configuration module (OCM) receives order specifications for a second order that replaces and/or modifies a first order, while the first order is being fulfilled. The OCM generates hash tag pairs respectively associated with various characteristics of the orders. For each hash tag pair, the OCM compares a first hash tag associated with the first order with a second hash tag associated with the second order, using an established pattern. If the hash tags match, the OCM includes within a second production order, an unchanged production specification corresponding to the first hash tag. If a match does not occur, the OCM initiates an order reload, which provides, within the second production order, new production specifications that are associated with the second hash tag.
Latest IBM Patents:
1. Technical Field
The present disclosure generally relates to production order management systems and in particular to production order changes within production order management systems.
2. Description of the Related Art
Sales order change management is particularly complicated in a configure-to-order environment. Each new version of a sales order must be analyzed and reloaded to a manufacturing division to update the associated production order. Translation of sales order nomenclature to manufacturing nomenclature can be very involved. For example, this translation involves conversion from sales terminology to bills of material, explosion of bills of material into underlying components, assignment of assembly configuration requirements, creation of buildable entities (i.e., units of work), process routing assignment to each unit of work, application of electronic product enablement, manufacturing instructions, etc. An initial load of a production order is quite complicated in many industries but it is greatly magnified when altering a production order that is work-in-process. These changes can often be catastrophic in nature to the manufacturing activities and result in huge loss of productivity, loss in capacity, and/or missed customer shipments and revenue exposures.
A limited portion of the changes that are sent to manufacturing are driven by true orderable content changes received from a sales division. For example, these changes can involve a different feature code or machine type. A larger portion of the remaining changes are related to other characteristics such as: entity grouping of orders, instruction changes such as placement/connection, engineering change (EC) for parts, customer date change (which impacts EC effectivity) and order to order grouping across shipments. In addition, some of these changes include address changes which can impact shipment documentation and require changes to documentation language and/or product label changes. Most systems are geared towards content changes or address/delivery change, and manufacturing plants can invoke rework via a full “change order”. With very complex configurations, it is very likely that the process is stopped, and the product is torn down and rebuilt.
BRIEF SUMMARYDisclosed are a method, a data processing system (DPS) and a computer program product that selectively modifies an existing production order based on a change request. An order configuration module (OCM) receives order specifications for a second order that replaces and/or modifies a first order, while the first order is being fulfilled. The OCM generates hash tag pairs respectively associated with various characteristics of the orders. For each hash tag pair, the OCM compares a first hash tag associated with the first order with a second hash tag associated with the second order, using an established pattern. If a match occurs between the first and second hash tags, the OCM includes within a second production order, an unchanged production specification corresponding to the first hash tag. If a match does not occur, the OCM initiates an order reload, which provides, within the second production order, new production specifications that are associated with the second hash tag.
The above summary contains simplifications, generalizations and omissions of detail and is not intended as a comprehensive description of the claimed subject matter but, rather, is intended to provide a brief overview of some of the functionality associated therewith. Other systems, methods, functionality, features and advantages of the claimed subject matter will be or will become apparent to one with skill in the art upon examination of the following figures and detailed written description.
The description of the illustrative embodiments can be read in conjunction with the accompanying figures. It will be appreciated that for simplicity and clarity of illustration, elements illustrated in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements are exaggerated relative to other elements. Embodiments incorporating teachings of the present disclosure are shown and described with respect to the figures presented herein, in which:
The illustrative embodiments provide a method, a data processing system (DPS) and a computer program product that selectively modifies an existing production order based on a change request. An order configuration module (OCM) receives order specifications for a second order that replaces and/or modifies a first order, while the first order is being fulfilled. The OCM generates hash tag pairs respectively associated with various characteristics of the orders. For each hash tag pair, the OCM compares a first hash tag associated with the first order with a second hash tag associated with the second order, using an established pattern. If a match occurs between the first and second hash tags, the OCM includes within a second production order, an unchanged production specification corresponding to the first hash tag. If a match does not occur, the OCM initiates an order reload, which provides, within the second production order, new production specifications that are associated with the second hash tag.
In the following detailed description of exemplary embodiments of the disclosure, specific exemplary embodiments in which the disclosure may be practiced are described in sufficient detail to enable those skilled in the art to practice the disclosed embodiments. For example, specific details such as specific method orders, structures, elements, and connections have been presented herein. However, it is to be understood that the specific details presented need not be utilized to practice embodiments of the present disclosure. It is also to be understood that other embodiments may be utilized and that logical, architectural, programmatic, mechanical, electrical and other changes may be made without departing from general scope of the disclosure. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present disclosure is defined by the appended claims and equivalents thereof.
References within the specification to “one embodiment,” “an embodiment,” “embodiments”, or “one or more embodiments” are intended to indicate that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present disclosure. The appearance of such phrases in various places within the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Further, various features are described which may be exhibited by some embodiments and not by others. Similarly, various requirements are described which may be requirements for some embodiments but not other embodiments.
It is understood that the use of specific component, device and/or parameter names and/or corresponding acronyms thereof, such as those of the executing utility, logic, and/or firmware described herein, are for example only and not meant to imply any limitations on the described embodiments. The embodiments may thus be described with different nomenclature and/or terminology utilized to describe the components, devices, parameters, methods and/or functions herein, without limitation. References to any specific protocol or proprietary name in describing one or more elements, features or concepts of the embodiments are provided solely as examples of one implementation, and such references do not limit the extension of the claimed embodiments to embodiments in which different element, feature, protocol, or concept names are utilized. Thus, each term utilized herein is to be given its broadest interpretation given the context in which that term is utilized.
Referring specifically to
DPS 100 further includes one or more input/output (I/O) controllers 120 which support connection to and processing of signals from one or more connected input device(s) 122, such as a keyboard, mouse, touch screen, or microphone. I/O controllers 120 also support connection to and forwarding of output signals to one or more connected output device(s) 124, such as a monitor or display device or audio speaker(s). In addition, DPS 100 includes universal serial bus (USB) 126 which is coupled to I/O controller 120. Additionally, in one or more embodiments, one or more device interface(s) 128, such as an optical reader, a universal serial bus (USB), and/or a card reader, can be associated with DPS 100. Device interface(s) 128 can be utilized to enable data to be read from or stored to corresponding removable storage device(s) 130, such as a compact disk (CD), digital video disk (DVD), flash drive, or flash memory card. In one or more embodiments, device interface(s) 128 can also provide an integration point for connecting other device(s) to DPS 100. In one implementation, DPS 100 connects to remote DPS 140 using device interface(s) 128.
DPS 100 comprises a network interface device (NID) 132. NID 132 enables DPS 100 to communicate and/or interface with other devices, services, and components that are located external to DPS 100. These devices, services, and components can interface with DPS 100 via an external network, such as example network 136, using one or more communication protocols. In particular, in one implementation, DPS 100 uses NID 132 to connect to remote DPS 140 via an external network, such as network 136.
Network 136 can be a local area network, wide area network, personal area network, and the like, and the connection to and/or between network 136 and DPS 100 can be wired or wireless or a combination thereof. For purposes of discussion, network 136 is indicated as a single collective component for simplicity. However, it is appreciated that network 136 can comprise one or more direct connections to other devices as well as a more complex set of interconnections as can exist within a wide area network, such as the Internet.
Those of ordinary skill in the art will appreciate that the hardware, firmware/software utility, and software components and basic configuration thereof depicted in
In addition, change environment 200 also includes a second work unit which is illustrated and identified as “N2/Cfg1-R1 Slot 5” 206, a third work unit which is illustrated and identified as “N3/Cfg1-R1 Slot 9” 208 and a fourth work unit which is illustrated and identified as “N6/Cfg3-R1 Slot 21” 210.
Change environment 200 also includes a shipping group in which additional components and/or accessories associated with the order (e.g., order A1) are shipped. In the example of
Change environment 200 also comprises a second rack illustrated as “R2” 222 into which completed or work-in-process “work units” for the first order are placed or inserted. As illustrated, within change environment 200, order A1 specifies a seventh work unit which is illustrated as “N7/Cfg1-R2 Slot 1” 224. In addition, change environment 200 also includes an eighth work unit which is illustrated and identified as “N8/Cfg1-R2 Slot 5” 226, a ninth work unit which is illustrated and identified as “N9/Cfg1-R2 Slot 9” 228 and a tenth work unit which is illustrated and identified as “N10/Cfg2-R2 Slot 13” 230.
Change environment 200 includes a second order, “order A2” 214, which represents an update/modification or replacement for the first order, order A1 212. A change order is used to fulfill order A2 214 by providing change specifications that can be used to modify order A1 212. In change environment 200, an identified set of change specifications can be used to target changes to a specific work unit. For example, a first set of change specifications, which is illustrated as S (specification) 218, target changes to first work unit 204. S 218 specifies work order actions which include the following: (i) removing the corresponding work unit; (ii) changing the hard disk drive (HDD) from an HDD having a first size specified using order A1 to a modified or second HDD having a second size specified using order A2; (iii) following the modification, moving the work unit from a first location at R1 (i.e., rack 1) slot 1 to a second location at R2 (i.e., rack 2) slot 1; and (iv) testing the modified work unit.
A second set of change specifications, S 220, specifies work order actions which include the following: (i) removing the corresponding work unit; (ii) changing the hard disk drive (HDD) from an HDD having a first size specified using order A1 to a modified or second HDD having a second size specified using order A2; (iii) following the modification, moving the work unit from a first location at R1 (i.e., rack 1) slot 5 to a second location at R1 slot 1; and (iv) testing the modified work unit.
A third set of change specifications, S 222, specifies work order actions which include the following: (i) removing the corresponding work unit; (ii) changing the hard disk drive (HDD) from an HDD having a first size specified using order A1 to a modified or second HDD having a second size specified using order A2; (iii) following the modification, returning the work unit retrieved from a first location at R1 (i.e., rack 1) slot 9 to the same first location at R1 slot 9; and (iv) testing the modified work unit.
A fourth set of change specifications, S 223, specifies work order actions associated with a second type of work unit. These work order actions include the following: (i) removing the corresponding work unit; (ii) following the modification, moving the work unit from a first location at R1 (i.e., rack 1) slot 13 to a second location at R1 slot 17; and (iii) testing the un-modified work unit in the new location.
A number of other change specifications involving the first type of work unit, the second type of work unit and a third type of work unit are illustrated within change environment 200. However, when these change specifications are received within a change environment having the disclosed features and capabilities, as described in
In one embodiment, OCM 110 receives, within a set of order specifications, one or more of: order content and component specifications, component grouping specifications, delivery date information, shipment information, billing information and specified changes associated with various aspects of a previous order specification.
In change environment 300, following receipt of the second order, OCM 110 generates a first set of hash tags from the first set of order specifications, according to one embodiment. In addition, OCM 110 generates a second set of hash tags from the second set of order specifications. In one embodiment, OCM 110 saves the first production order as an initial version of a second production order corresponding to the second order.
OCM 110 selects for comparison each of at least one hash tag pair using the first and second sets of hash tags. The selection is made according to an established pattern and sequence for comparing hash tag pairs. In one embodiment, the selected hash tag pair(s) includes an initial hash tag pair comprising a first hash tag from the first set of hash tags and a second hash tag from the second set of hash tags. In one or more related embodiments, each additional hash tag pair is individually selected following a result of a previous comparison of hash tags of a hash tag pair.
In one embodiment, OCM 110 utilizes the established pattern and/or sequence which is based upon a hierarchical arrangement for an identified set of hash tags generated for a corresponding order specification. In one or more related embodiments, OCM 110 determines a hierarchical arrangement for the identified set of hash tags using a pre-established hierarchy of hash tags respectively associated with at least one of (a) one or more known order specification characteristics associated with product configuration and (b) one or more order characteristic types. The pre-established hierarchy can be developed using functional relationships and dependencies between order specification characteristics associated with different hash tags. OCM 110 is able to identify the matches and mismatches between a first set of hash tags and a second set of hash tags by sequentially comparing, using the determined hierarchical arrangement and one or more results of previous comparisons, hash tags from the first set of hash tags with hash tags having a same respective characteristic type from the second set of hash tags.
Hash tags corresponding to the first order work unit specified by order specifications from the first order, order A1 312, are compared with hash tags corresponding to the second order work unit specified by order specifications from the second order, order A2 314. More specifically, a hash first tag associated with a specific characteristic type of the work unit is compared with a second hash tag having a same characteristic type, and the first and second hash tags represent an appropriate pairing. In one example implementation, HDD size can be the particular characteristic type.
OCM 110 determines whether a match exists between hash tags of a respective hash tag pair. If a match exists between hash tags of a respective hash tag pair, OCM 110 maintains, without modification, corresponding production specifications from the initial, second production order. As illustrated in change environment 300, there are no change specifications targeting cfg2 and cfg3 work units such as “N6/cfg3” 310 in change environment 300.
Compared with change environment 300, change environment 200 (
However, if a match does not exist between hash tags of the respective hash tag pair, OCM 110 selectively modifies the second production order, initiating an order reload to (a) remove and/or reverse production specifications associated with fulfilling the first order and (b) provide new production specifications corresponding to the second order. OCM 110 intelligently provides only the required changes. For example, in change environment 300, changes to the HDD and re-testing are specified and/or performed.
Compared with change environment 300, change environment 200 (
In one embodiment, OCM 110 maintains, within the second production order, a status associated with any production specifications corresponding to one or more executed actions associated with the first production order and with the matching pair of hash tags.
In one embodiment, OCM 110 identifies when there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against. In response to identifying that there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against, OCM 110 initiating an order reload that selectively removes from the second production order production specifications associated with the first hash tag. In addition, OCM 110 provides production specifications to reverse executed actions associated with production specifications associated with the first hash tag.
According to another aspect of the disclosure, OCM 110 determines whether there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against. In response to determining that there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against, OCM 110 provides within the second production order new production specifications corresponding to the at least one hash tag from the second set of hash tags.
OCM 110 performs order alteration using a configurable chain of small and manageable subsets of identity modeling, with conditional, user-defined actions and exits at each step. The configurable alteration process incorporates user-defined steps, inputs or combinations of inputs, with specific function calls driven by each step. OCM 110 utilizes this configurable process to identify types and levels of hash tags or identification tags to be calculated and applied at each step of the alteration process, based on the type of order undergoing alteration. In addition, OCM 110 generates hash tags using user-configurable hash tag generation algorithms. OCM 110 sequentially applies singular or multiple identity tests/evaluations at each alteration process step in order to determine likeness/unlikeness and to identify the “true” changes. OCM 110 applies the correct alteration algorithm or algorithms, sequentially, to the complete orders or subsets of orders requiring alteration, while leaving some orders or subsets of orders unchanged.
First row 404 describes a first hash tag type identified as “Order_Content” which is defined as a hash tag signature for all customer orderable content. First row 404 indicates that an “Order_Content” hash tag can be generated for a number of order types including box orders, miscellaneous equipment specification (MES) orders and rack orders using an algorithm identified as “PGM—1”.
Second row 406 describes a second hash tag type identified as “Peer_Orders” which is defined as a hash tag signature for group orders to be shipped together per customer request. Second row 406 indicates that “Peer_Orders” hash tags can be generated for a number of order types including box orders, miscellaneous equipment specification (MES) orders and rack orders using an algorithm identified as “PGM—2”.
Third row 408 describes a third hash tag type identified as “Work_Unit” which is defined as a hash tag signature of components, quantity, and placement for each unit of work in a system. Third row 408 indicates that a “Work_Unit” hash tag can be generated for a number of order types including box orders, miscellaneous equipment specification (MES) orders and rack orders using an algorithm identified as “PGM—3”.
Fourth row 410 describes a fourth hash tag type identified as “Ship_Group” which is defined as a hash tag signature of components, quantity for each type ‘G’ (i.e., grouping) unit of work in a system. Fourth row 410 indicates that a “Ship_Group” hash tag can be generated for a number of order types including box orders and rack orders using an algorithm identified as “PGM—4”.
In addition, table 500 comprises a second column that identifies an order type corresponding to the identified hash tag group of the first column. The third column identifies an ordered step within a sequence of hash tag evaluations/comparisons algorithm which step can be based on results of other hash tag evaluations. The fourth column identifies a next hash tag group for which hash tag evaluations are performed if a match occurs for a current evaluation of a hash tag pair from a corresponding group. The fifth column identifies a next hash tag group for which hash tag evaluations are performed if a mismatch occurs for a current evaluation of a hash tag pair from a corresponding group.
The sixth column identifies a hash tag type corresponding to the hash tag group identified in the first column. The seventh column specifies an action to be performed on a corresponding order specification if a mismatch occurs for a current evaluation of a hash tag pair from a corresponding group. The eighth column specifies an action to be performed on a corresponding order specification if a match occurs for a current evaluation of a hash tag pair from a corresponding group. The ninth column defines the specified action which is identified in the seventh or eighth column.
Table 500 comprises eight (8) rows. However, a selected subset of rows are particularly highlighted and described herein. First row 504 describes a hash tag group identified as group “10”, which includes hash tags types that are to be evaluated. In particular, a first hash tag from a first order and a second hash tag from a second order which both have a same hash tag type associated with group “10” are compared against each other as a first comparison within a sequence of ordered comparisons. First row 504 indicates that all order types provide hash tags that belong to hash tag group 10 which is associated with “Order_Content” (i.e., all customer orderable content). In addition, first row 504 indicates at the fourth column that if a match occurs when hash tags from hash tag group “10” are compared against each other, a next hash tag comparison step occurs between hash tags belonging to hash tag group 50, which includes hash tags associated with delivery information. First row 504 indicates at the fifth column that if a mismatch occurs when hash tags from hash tag group “10” are compared against each other, a next hash tag comparison step occurs between hash tags belonging to hash tag group 20 which includes hash tags associated with at least one of work units and ship group units. First row 504 indicates at the eighth and ninth columns that if a match occurs, production specifications with identical content associated with a matching hash tag from the first order is reloaded to be associated with the second production order.
Hash tag group 20 includes “Work_Unit” hash tags and “Ship_Group” hash tags and hash tag comparisons and activity models associated with the respective hash tag types are described in second row 506 and third row 508, respectively. Second row 506 indicates that “Work_Unit” hash tags which are included within group 20 can be generated for several order types including box, MES and rack orders. As previously indicated, if a mismatch was detected in a previous STR (i.e., starting) step (first row 504), group 20 identifies a second evaluation step which is identified as step 020 within second row 506. If a match occurs between hash tags for the first and second orders having a “Work_Unit” hash tag type, a next evaluation step is step 050, as indicated at the fourth column of second row 506. If a mismatch occurs between hash tags for the first and second orders having a “Work_Unit” hash tag type, a next evaluation step is step 030, as indicated at the fifth column of second row 506. Second row 506 further indicates at the eighth and ninth columns that if a match occurs, production specifications with identical/unchanged content associated with a matching hash tag from the first order is reloaded to be associated with the second production order.
Third row 508 indicates that “Ship_Group” hash tags, which are included within group 20, can be generated for several order types including box and rack orders. As previously indicated, if a mismatch was detected in a previous STR (i.e., starting) step (first row 504), group 20 identifies a second evaluation step which is identified as step 020 within third row 508. As indicated by third row 508, if a match occurs between hash tags for the first and second orders having a “Ship_Group” hash tag type, an “END” step is shown to be a next step as there are no further evaluation steps triggered from results of this evaluation. Similarly, if a mismatch occurs between hash tags for the first and second orders having a “Ship_Group” hash tag type, an “END” step is shown to be a next step as there are no further evaluation steps triggered from results of this evaluation. Third row 508 further indicates at the eighth and ninth columns that if a match occurs, production specifications corresponding to the matching ship group unit from the first production order are reloaded to be maintained within the second production order.
Table 500 also includes fifth row 510 which describes hash tag group 40 and the next evaluation steps and specified actions based on results of hash tag evaluations associated with “Peer_Orders” (i.e., peer orders). In particular, these hash tag evaluations can be used to match associations (i.e., perform an association cleanup) for peer orders. For example, OCM 110 can perform an association cleanup when OCM 110 determines that, while satisfying the overall result for a set of requested changes, no specification changes to the second production order associated with a specific work unit are required even if order specifications associated with the specific work unit was received. In addition, table 500 includes sixth row 512 which describes hash tag group 50 and the next evaluation steps and specified actions based on results of hash tag evaluations associated with “Delivery_Info” (i.e., delivery information).
However, if, at block 610, a match does not exist between the first and second hash tags, OCM 110 executes any specified action based on determining that the first and second hash tags do not match (block 614). OCM 110 selects a next (evaluation) step based on determining that the first and second hash tags do not match (block 620). For example, if the order characteristics type is “Delivery_Info”, as shown in sixth row 512 (Table 500), OCM 110, while performing an evaluation of hash tags subsequent to an initial evaluation step, can detect a non-matching pair of hash tags. As a result, OCM 110, using an established activity model, may, after specifying an action that applies new/updated delivery information to the order, identify step 60 as a next evaluation step. OCM 110 then determines whether the next evaluation step associated with determining that the first and second hash tags do not match is an “END” or completion indicator step (decision block 622). If the corresponding next evaluation step is not the “END” step, the process returns to block 606 at which OCM 110 identifies (a) the “next” step as the current evaluation step and (b) the associated order characteristics to generate hash tags specified for the current evaluation step. If the corresponding next evaluation step is the “END” step, the process proceeds to an end block.
In the above described flow charts, one or more of the methods may be embodied in a computer readable device containing computer readable code such that a series of functional processes are performed when the computer readable code is executed on a computing device. In some implementations, certain steps of the methods are combined, performed simultaneously or in a different order, or perhaps omitted, without deviating from the scope of the disclosure. Thus, while the method blocks are described and illustrated in a particular sequence, use of a specific sequence of functional processes represented by the blocks is not meant to imply any limitations on the disclosure. Changes may be made with regards to the sequence of processes without departing from the scope of the present disclosure. Use of a particular sequence is therefore, not to be taken in a limiting sense, and the scope of the present disclosure is defined only by the appended claims.
Aspects of the present disclosure are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language, without limitation. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, such as a service processor, 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, performs the method for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
As will be further appreciated, the processes in embodiments of the present disclosure may be implemented using any combination of software, firmware or hardware. Accordingly, aspects of the present disclosure may take the form of an entirely hardware embodiment or an embodiment combining software (including firmware, resident software, micro-code, etc.) and hardware aspects that may all generally be referred to herein as a “circuit,” “module,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable storage device(s) having computer readable program code embodied thereon. Any combination of one or more computer readable storage device(s) may be utilized. The 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 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 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.
While the disclosure has been described with reference to exemplary embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the disclosure. In addition, many modifications may be made to adapt a particular system, device or component thereof to the teachings of the disclosure without departing from the essential scope thereof. Therefore, it is intended that the disclosure not be limited to the particular embodiments disclosed for carrying out this disclosure, but that the disclosure will include all embodiments falling within the scope of the appended claims. Moreover, the use of the terms first, second, etc. do not denote any order or importance, but rather the terms first, second, etc. are used to distinguish one element from another.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. 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. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, 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.
The description of the present disclosure has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the disclosure in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope of the disclosure. The described embodiments were chosen and described in order to best explain the principles of the disclosure and the practical application, and to enable others of ordinary skill in the art to understand the disclosure for various embodiments with various modifications as are suited to the particular use contemplated.
Claims
1-7. (canceled)
8. A data processing system (DPS) configured for changing a production order, the DPS comprising:
- an order configuration module (OCM);
- a memory system which stores the module;
- a processor which executes the module to provide instructions for: receiving a first set of order specifications that can be used for fulfilling a first order; initiating order fulfillment for the received first order using a first production order generated from the first set of order specifications; receiving a second set of order specifications for a second order that replaces or modifies the first order, while the first order is being fulfilled; generating a first set of hash tags from the received first set of order specifications; generating a second set of hash tags from the received second set of order specifications; saving the first production order as an initial, second production order corresponding to the second order; selecting, using an established pattern, at least one pair of hash tags including an initial pair of hash tags from the first and second sets of hash tags; comparing each pair of hash tags from the at least one pair of hash tags to identify matches and mismatches between respective pairings of hash tags; and for each respective pairing of hash tags that match, maintaining, within the second production order, existing production specifications which are associated with the matching hash tags.
9. The system of claim 8, further comprising:
- for each respective pairing of hash tags that does not match, selectively modifying the second production order by initiating an order reload which provides, within the second production order, new production specifications which are associated with the second hash tag.
10. The system of claim 8, further comprising:
- determining a hierarchical arrangement for an identified set of hash tags generated for a corresponding order specification using a pre-established hierarchy of hash tags respectively associated with at least one of (a) one or more known specification characteristics associated with product configuration, and (b) one or more characteristic types, wherein the pre-established hierarchy is developed using functional relationships and dependencies between specification characteristics associated with different hash tags; and
- identifying the matches and mismatches between a first set of hash tags and a second set of hash tags by sequentially comparing, using the determined hierarchical arrangement, hash tags from the first set of hash tags with hash tags having a same respective characteristic type from the second set of hash tags.
11. The system of claim 10, further comprising:
- determining, using the hierarchical arrangement, a next hash tag from the first set of hash tags to be compared to a corresponding hash tag from the second set of hash tags to determine whether the next hash tag represents a mismatch.
12. The system of claim 8, further comprising:
- identifying when there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against; and
- in response to identifying that there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against: initiating an order reload that selectively removes from the second production order production specifications associated with the first hash tag; and providing production specifications to reverse executed actions associated with production specifications associated with the first hash tag.
13. The system of claim 8, wherein said initiating order fulfillment further comprises:
- generating, using the first order specification, the first production order which provides specifications for actions and processes that are used for one or more of configuring a product, providing targeted modifications to a previous product configuration, testing a selected configuration and fulfilling the first order.
14. The system of claim 8, further comprising:
- determining whether there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against; and
- in response to determining that there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against, providing within the second production order new production specifications corresponding to the at least one hash tag from the second set of hash tags.
15. A computer program product executing within a processor of a data processing system and providing instructions for:
- receiving a first set of order specifications that can be used for fulfilling a first order;
- initiating order fulfillment for the received first order using a first production order generated from the first set of order specifications;
- receiving a second set of order specifications for a second order that replaces or modifies the first order, while the first order is being fulfilled;
- generating a first set of hash tags from the received first set of order specifications;
- generating a second set of hash tags from the received second set of order specifications;
- saving the first production order as an initial, second production order corresponding to the second order;
- selecting, using an established pattern, at least one pair of hash tags including an initial pair of hash tags from the first and second sets of hash tags;
- comparing each pair of hash tags from the at least one pair of hash tags to identify matches and mismatches between respective pairings of hash tags; and
- for each respective pairing of hash tags that match, maintaining, within the second production order, existing production specifications which are associated with the matching hash tags.
16. The computer program product of claim 15, said computer program product providing instructions for:
- for each respective pairing of hash tags that does not match, selectively modifying the second production order by initiating an order reload which provides, within the second production order, new production specifications which are associated with the second hash tag.
17. The computer program product of claim 15, said computer program product providing instructions for:
- determining a hierarchical arrangement for an identified set of hash tags generated for a corresponding order specification using a pre-established hierarchy of hash tags respectively associated with at least one of (a) one or more known specification characteristics associated with product configuration, and (b) one or more characteristic types, wherein the pre-established hierarchy is developed using functional relationships and dependencies between specification characteristics associated with different hash tags;
- identifying the matches and mismatches between a first set of hash tags and a second set of hash tags by sequentially comparing, using the determined hierarchical arrangement, hash tags from the first set of hash tags with hash tags having a same respective characteristic type from the second set of hash tags; and
- determining, using the hierarchical arrangement, a next hash tag from the first set of hash tags to be compared to a corresponding hash tag from the second set of hash tags to determine whether the next hash tag represents a mismatch.
18. The computer program product of claim 15, said computer program product providing instructions for:
- identifying when there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against; and
- in response to identifying that there is at least one hash tag from the first set of hash tags for which there is no corresponding hash tag from the second set of hash tags to be compared against: initiating an order reload that selectively removes from the second production order production specifications associated with the first hash tag; and providing production specifications to reverse executed actions associated with production specifications associated with the first hash tag.
19. The computer program product of claim 15, said computer program product providing instructions for:
- generating, using the first order specification, the first production order which provides specifications for actions and processes that are used for one or more of configuring a product, providing targeted modifications to a previous product configuration, testing a selected configuration and fulfilling the first order.
20. The computer program product of claim 15, said computer program product providing instructions for:
- determining whether there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against; and
- in response to determining that there is at least one hash tag from the second set of hash tags for which there is no corresponding hash tag from the first set of hash tags to be compared against, providing within the second production order new production specifications corresponding to the at least one hash tag from the second set of hash tags.
Type: Application
Filed: Sep 2, 2014
Publication Date: Mar 3, 2016
Applicant: INTERNATIONAL BUSINESS MACHINES CORPORATION (ARMONK, NY)
Inventors: IVORY WELLMAN KNIPFER (ROCHESTER, MN), JASON SCOTT LEE (ORONOCO, MN), ANTOINE GEORGE SATER (ROCHESTER, MN), MATTHEW H. ZEMKE (ROCHESTER, MN)
Application Number: 14/474,493