|Publication number||US7757203 B2|
|Application number||US 10/741,123|
|Publication date||Jul 13, 2010|
|Priority date||Dec 19, 2003|
|Also published as||EP1544764A1, US20050138060|
|Publication number||10741123, 741123, US 7757203 B2, US 7757203B2, US-B2-7757203, US7757203 B2, US7757203B2|
|Inventors||Juergen Scholl, Stephan Toebben, Helga Walter, Ralf Kau|
|Original Assignee||Sap Ag|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (10), Non-Patent Citations (3), Referenced by (3), Classifications (11), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The present invention relates to computer-implemented methods, systems, programs and computer program products, and data objects for providing automated process flow in product development, in particular in computer-aided product development.
Trial management plays an important role throughout the product development process of product life cycle management. From the early stages of product design and development, to industrialization, it is important to have proper tools to prove product quality, and to evaluate the production process of trials in a consistent way. During the product development process, trials have to be carried out and evaluated. Carrying out trials requires functions as those provided in the execution, and quality management of regular manufacturing, but with a higher flexibility.
Trials based on recipe management (RM) system recipes may be executed without any additional maintenance of master data on a bench scale or pilot plant scale. Factory trials may also be supported. All results of a trial, including in-process, post-process, and further analyses, are recorded and may be evaluated. A trial object may then deliver a recipe, including key manufacturing instructions, and additional information concerning manufacturing and quality management.
However, to allow efficient product development, the trials within the different stages of development—bench scale, pilot plant scale, and factory scale—need to be supported by a sufficient data structure. Functions need to be provided allowing maintenance of specifications and recipes.
A trial is an action for testing a product in order to achieve the required product quality/specification. During pilot plant phases, a trial allows finding product specifications for a product on a defined product line at optimal cost. More specifically, a trial is the manufacture of a product by using a recipe. A recipe may consist of formula, processing conditions, quality inspection parameters, in-process control, and equipment specification. Not all of these parameters are required. A recipe also allows the subsequent evaluation of all trial results. The trial may be carried out on a bench scale, pilot plant scale, or industrial scale.
A document providing information for product development on a pilot plant scale and an industrial scale might be a preliminary manufacturing dossier (PMD). This PMD describes a production situation in a factory. Such a document may be required for any production start up of a new product.
A PMD template may comprise material specifications, ingredients, and packaging materials, recipes comprising formulae, manufacturing instructions, process block diagrams, in-process controls, and equipment specifications. Furthermore, a finished product specification with all quality management data required for a post-process control, and product release may be included. In addition, label declaration, transport, and storage information may be included.
However, during trials different specifications, recipes, and equipment specifications are necessary for different stages. With known methods, it is not possible to recycle data, which have already been acquired during previous stages. For each stage, the relevant information has to be manually copied. Also, process flow is not supported. Furthermore, users are not provided with a data structure that guides them through the different stages of a product development process.
For different stages within a development process, different actions, recipes, formulae and equipment specifications are necessary. Users have to manually select these to provide trial results for later trial evaluation. This manual selection is error prone.
To overcome these drawbacks and to provide a user-friendly, flawless, and process flow supporting product development, the invention proposes a computer-implemented method for providing automated process flow in product development, in particular in computer-aided product development, with the steps of defining a structured data object, whereby within said structured data object at least one recipe, and at least one formula is defined, defining trial stages within said product development, defining object types within said data object referring to said trial stages, instantiating an instance of said data object from said data object definition, specifying a type of said instance from one of said object types, and providing said recipe and/or said formula to a user according to the specified type.
A data structure is provided, comprising at least one recipe and at least one formula. This data structure may define a trial object, which handles the life cycle of the trial and links different objects to this trial object. Functions and processes of different stages within product development are simplified so that they can be performed easily by users, which have very different, and non-repetitive tasks.
As during product development, different stages are necessary. These stages are defined and object types referring to said stages are defined within said structured data object. Within the data object, different types are defined, each type referring to a different trial stage.
With this structured data object, it is possible to create an instance of a data object with all properties of the object model. When selecting one of the defined trial stage types within an instance, the instance of the data object may be assigned to a certain type of trial stage.
According to the invention, said recipes and formulae within the data object may be assigned to certain stage types. After selecting and assigning a stage type to an instance of said object, the respective recipes and formulae may become accessible. Recipes and formulae which are not assigned to the respective stage may be hidden from user access.
In this way, the user may be provided with the appropriate information for carrying out the respective trial stage. Information not necessary for the respective stage may be hidden from user view.
A user interface may be provided for trial objects. This user interface may have a header block and multiple tab strips for the single stages of the trial. Depending on the trial type, single tab strips or individual fields on the screen may be hidden, may be editable, or might be mandatory. The user will be guided through the development process using the inventive method. Only relevant data needs to be recorded and presented to the user.
In embodiments consistent with the present invention, trial stages may be defined for laboratory tests, pilot production tests, and/or factory production tests or other stages within product development. Further stages may be included and configured by users. For each of these stages, different recipes and formulae as well as different manufacturing instructions, in-process controls and equipment specifications may be necessary. The specifications are assigned to respective stages. This means that, for example, different equipment specifications may be available for different stages. According to the selected type within an object, the appropriate specification may be selected and presented to a user. Users may record trial results with respect to the appropriate stage.
During the different stages, a trial may have different states. For each trial stage, different tasks and sub-tasks may have to be accomplished. These tasks and sub-tasks may also be defined within the structured object data definition. Corresponding to the selected type of the object, the different stages together with their respective tasks and sub-tasks may be presented to a user.
Different states of a trial stage may be, for example, trial planning, trial execution, move to production, material management, and/or quality management. These states define which actions (tasks, sub-tasks) may need to be carried out to accomplish a trial stage.
To guide a user through a trial, it is proposed that said recipe comprises process flow instructions which are assigned to objects types and which define a succession of object states. When carrying out a trial, different tasks and sub-tasks to be carried out. Rules may define which tasks have to be accomplished to process the object to a next state. Also, it may be defined which states are required to finish a stage and to move to a next object stage. Therefore, by providing the rules, a process flow may be applied. A user may be guided through the development process by said rules.
To allow guidance of a user through the development process, it is also proposed that said stages are changed according to user selections in a succession provided by said process flow. Once a stage is accomplished, the user may set the state activity to finish. The next stage may be automatically selected according to process flow information.
To allow user inputs of results, and comparison of different trials, it is proposed that process results for respective trial stages are stored within said instance. For that reason, the structured data objects may provide data input fields, which allow the respective process results to be stored. As the user only sees formulae relating to the respective stage and state of the trial, he may edit only these values, which refer to the current process results. Other values do not have to bother the user.
To recycle results of previous trials and to allow transfer of knowledge, it is proposed that for each trial stage a new instance of said data object is created. It is further proposed, that for a new instance of a data objects at least some of the results of a previous stage are copied. By that, it may be possible to recycle object definitions as a new instance of the data object already comprises all object definitions. It is also possible to recycle results from previous stages of a trial, as these may be copied into the new instance of the data object.
To trace all actions and processes carried out for a trial, it is proposed that an object trail is created, which may comprise links to trial objects of a product development process. By this trail, it may be possible to reconstruct which trial objects have been instantiated when, and which were the results of the respective trials. This may be helpful for later comparison of trials and for quality management.
To reconstruct a trial, it is proposed that said object trail comprises information about a succession of different trial objects.
Another aspect of the invention is a computer program for providing automated process flow in product development, in particular in computer-aided product development, operable to cause a processor to define a structured data object, whereby within said structured data object at least one recipe, and at least one formula is defined, define trial stages within said product development, define object types within said data object referring to said trial stages, instantiate an instance of said data object from said data object definition, specify a type of said instance from one of said object types, and provide said recipe and/or said formula to a user according to the specified type.
A further aspect of the invention is a computer program product for providing automated process flow in product development, in particular in computer-aided product development, with a computer program stored thereon operable to cause a processor to define a structured data object, whereby within said structured data object at least one recipe, and at least one formula is defined, define trial stages within said product development, define object types within said data object referring to said trial stages, instantiate an instance of said data object from said data object definition, specify a type of said instance from one of said object types, and provide said recipe and/or said formula to a user according to the specified type.
Yet a further aspect of the invention is a data structure for providing automated process flow in product development, in particular in computer-aided product development, comprising at least one recipe, and at least one formula definition, at least one definition for trial stages within said product development, at least one definition for object types referring to said trial stages, wherein an instance of said data structure specifies a type of trial stage from its definition, and wherein said instance provides said recipe and/or said formula to a user according to the specified type.
Eventually, another aspect of the invention is a computer for providing automated process flow in product development, in particular in computer-aided product development, comprising definition means to define a structured data object, whereby within said structured data object at least one recipe, and at least one formula is defined, to define trial stages within said product development, and to define object types within said data object referring to said trial stages, storage means to store an instance of said data object from said data object definition, computing means to specify a type of said instance from one of said object types, and display means to provide said recipe and/or said formula to a user according to the specified type.
Referring now to the drawings, in which like numerals represent like elements throughout the several figures, aspects of the present invention and the exemplary operating environment will be described.
Computer 900 can communicate with computers 901 and 902 over network 990. Computer 900 has processor 910, memory 920, bus 930, and, optionally, input device 940 and output device 950 (I/O devices, user interface 960). As illustrated, the invention may be implemented by computer program product 100 (CPP), carrier 970 and signal 980.
In respect to computer 900, computer 901/902 is sometimes referred to as a “remote computer.” Computer 901/902 may be, for example, a server, a peer device or other common network node, and typically has many or all of the elements described relative to computer 900.
Computer 900 may be, for example, a conventional personal computer (PC), a desktop device or a hand-held device, a multiprocessor computer, a pen computer, a microprocessor-based or programmable consumer electronics device, a minicomputer, a mainframe computer, a personal mobile computing device, a mobile phone, a portable or stationary personal computer, a palmtop computer or the like.
Processor 910 may be, for example, a central processing unit (CPU), a micro-controller unit (MCU), digital signal processor (DSP), or the like.
Memory 920 is elements that temporarily or permanently store data and instructions. Although memory 920 is illustrated as part of computer 900, memory can also be implemented in network 990, in computers 901/902 and in processor 910 itself (e.g., cache, register), or elsewhere. Memory 920 can be a read only memory (ROM), a random access memory (RAM), or a memory with other access options. Memory 920 is physically implemented by computer-readable media, for example: (a) magnetic media, like a hard disk, a floppy disk, or other magnetic disk, a tape, a cassette tape; (b) optical media, like optical disk (CD-ROM, digital versatile disk—DVD); (c) semiconductor media, like DRAM, SRAM, EPROM, EEPROM, memory stick.
Optionally, memory 920 is distributed. Portions of memory 920 can be removable or non-removable. For reading from media and for writing in media, computer 900 uses well-known devices, for example, disk drives, or tape drives.
Memory 920 may store modules such as, for example, a basic input output system (BIOS), an operating system (OS), a program library, a compiler, an interpreter, and a text-processing tool. Such modules are commercially available and can be installed on computer 900. For simplicity, these modules are not illustrated.
CPP 100 has program instructions and—optionally—data that cause processor 910 to execute method steps of the present invention. In other words, CPP 100 can control the operation of computer 900 and its interaction in network system 999 so that is operates to perform in accordance with the invention. For example, and without the intention to be limiting, CPP 100 can be available as source code in any programming language, and as object code (“binary code”) in a compiled form.
Although CPP 100 is illustrated as being stored in memory 920, CPP 100 can be located elsewhere. CPP 100 can also be embodied in carrier 970.
Carrier 970 is illustrated outside computer 900. For communicating CPP 100 to computer 900, carrier 970 is conveniently inserted into input device 940. Carrier 970 is implemented as any computer-readable medium, such as a medium largely explained above (cf. memory 920). Generally, carrier 970 is an article of manufacture having a computer-readable medium with computer-readable program code to cause the computer to perform methods of the present invention. Further, signal 980 can also embody computer program product 100.
Having described CPP 100, carrier 970, and signal 980 in connection with computer 900 is convenient. Optionally, further carriers and further signals embody computer program products (CPP) to be executed by further processors in computers 901 and 902.
Input device 940 provides data and instructions for processing by computer 900. Device 940 can be a keyboard, a pointing device (e.g., mouse, trackball, cursor direction keys), microphone, joystick, game pad, scanner, or disc drive. Although the examples are devices with human interaction, device 940 can also be a device without human interaction, for example, a wireless receiver (e.g., with satellite dish or terrestrial antenna), a sensor (e.g., a thermometer), a counter (e.g., a goods counter in a factory). Input device 940 can serve to read carrier 970.
Output device 950 presents instructions and data that have been processed. For example, this can be a monitor or a display, (cathode ray tube (CRT), flat panel display, liquid crystal display (LCD), speaker, printer, plotter, vibration alert device. Output device 950 can communicate with the user, but it can also communicate with further computers.
Input device 940 and output device 950 can be combined to a single device. Devices 940 and 950 are also optional.
Bus 930 and network 990 provide logical and physical connections by conveying instruction and data signals. While connections inside computer 900 are conveniently referred to as “bus 930”, connections between computers 900-902 are referred to as “network 990”. Optionally, network 990 includes gateways which are computers that specialize in data transmission and protocol conversion.
Devices 940 and 950 are coupled to computer 900 by bus 930 (as illustrated) or by network 990 (optional). While the signals inside computer 900 are mostly electrical signals, the signals in the network may be electrical, electromagnetic, optical or wireless (radio) signals.
Networks are commonplace in offices, enterprise-wide computer networks, intranets and the Internet (e.g., world wide web WWW). Network 990 can be a wired or a wireless network. To name a few network implementations, network 990 can be, for example, a local area network (LAN), a wide area network (WAN), a public switched telephone network (PSTN); a Integrated Services Digital Network (ISDN), an infra-red (IR) link, a radio link, like Universal Mobile Telecommunications System (UMTS), Global System for Mobile Communication (GSM), Code Division Multiple Access (CDMA), or satellite link.
A variety of transmission protocols, data formats and conventions is known, for example, as transmission control protocol/internet protocol (TCP/IP), hypertext transfer protocol (HTTP), secure HTTP, wireless application protocol (WAP), unique resource locator (URL), a unique resource identifier (URI), hypertext markup language (HTML), extensible markup language (XML), extensible hypertext markup language (XHTML), wireless markup language (WML), Standard Generalized Markup Language (SGML).
Interfaces coupled between the elements are also well known in the art. For simplicity, such interfaces are not illustrated. An interface can be, for example, a serial port interface, a parallel port interface, a game port, a universal serial bus (USB) interface, an internal or external modem, a video adapter, or a sound card.
A computer and the computer programs operating thereupon are closely related. As used hereinafter, phrases, such as “the computer provides” and “the program provides”, are convenient abbreviations to express actions by a computer that is controlled by a program.
After a new trial has been planned upon a request for product innovation or renovation, the research and development department responsible for that product group may consolidate all information into a brief using a predefined “brief template” (206). A project for the product request is started (208).
Upon starting, a structured data object 204 may be defined (204 a). Within this structured data object, material specifications, such as ingredients and packaging material, recipes comprising formula, manufacturing instructions, process block diagrams, in-process control and equipment specifications may be defined. In some embodiments, finished product specifications may also be defined. These specifications may comprise quality management data required for post-process control and product release, label declaration, storage test results, transport, and storage information. Structured data definition 204 may comprise for various trial stages different definitions for at least recipe and formula.
The various stages of a product development process are recipe design on bench scale with a focus on the formula and its properties (210), recipe design on a pilot plant scale with a focus on process and finished product quality (212) and a transfer of the pilot plant results, and confirmation and approval to industrial scale (214).
Loops between steps 210-214 are possible within a product development process. In some specific cases, a direct transformation can occur as well, depicted by dotted lines.
Structured data object definition 204 may be used to create an instance of the data object 204 a. This data object 204 a is specified as being of the type of bench scale laboratory (210). This specification defines which recipes, material specifications, and product specifications are accessible for users. During bench scale laboratory (210), trial results may be stored within the instance of data objects 204 a. Various instances of the data object 204 a may be created, each instance storing results of different trials, e.g. different recipes tested.
After finalizing bench scale trials (210), instances of data objects 204 a may be selected, which should serve as basis for pilot plant scale trials (212). From these instances, copies are created, creating new data objects 204 b, being specified to have a type of pilot plant scale. Within this data object 204 b, recorded values of data objects 204 a may be copied. As data object 204 b is of the type pilot plant scale, different actions, tasks, recipes and formula may be presented to users. During pilot plant trials (212), new trial results may be created and stored within data object 204 b.
After the pilot plant trials (212) are finalized, a new data object 204 c may be created. This data object 204 c may be an instance of the previously defined structured data object. The data object 204 c may be based on data object 204 b. Therefore, values stored within data object 204 b may be recycled with data object 204 c. Data object 204 c is specified as being industrial scale trial type.
During industrial scale trials (214) different recipes, tasks, specifications and process flows than during bench scale laboratory trials (210) and pilot plants trials (212) may be presented to the users. Trial results may be recorded, for example, in the data objects 204 c.
After finalizing industrial scale trials (214), a new data object 204 d may be created. Within this data object 204 d, all relevant information resulting from the various trials for production may be stored. In data object 204 d, results from bench scale laboratory trials (210), pilot plant scale trials (212), and industrial scale trials (214) may be stored.
As all data objects 204 may be based on the same specifications, object definition work has to be done only once. Users are guided through the process flow of each stage 210-214 by instances of these data objects, whereby these instances are specified as being of a certain type. Thereby, only relevant information of the data object is accessible by and presented to users.
All these recipes may be taken from instances of data objects, which are based on a data object definition.
For a new product, an initial recipe B1 may be designed in the bench scale phase 310. This recipe B1 may be focused on its formula and may be based on brief requirements. During the trial, different recipe drafts B2 may be necessary to create a satisfying product with a resulting recipe B3. The bench scale development process may be finalized in case a satisfying recipe B3 is found.
After finalising the bench scale trial 210, a new data object may be created to be used during pilot plant trials 312. Into this newly created data object, the recipe B3 may be copied serving as a basis for the pilot plant trials 212. During pilot plant trials 212, different tasks are to be accomplished as during bench scale trials 210. These tasks may be presented to the user automatically, as the data object is of the type pilot plant trial.
Several iterations of recipe changes, pilot plant trial executions, and analyses may be necessary until a pilot plant recipe P2 is approved for industrial scale. This recipe P2 may be copied into a new data object of the type industrial scale. Within this newly created object, recipe P2 may be adjusted into recipe F1 valid for factoring production. Based on this recipe F1, a preliminary manufacturing document may be created.
During pilot plant trial 312, or during factory trials 314, it may be found that additional pilot plant trials based on recipe P3 or recipe F2 are necessary, in order to find a satisfying product.
Based on the recipe F1 or F2, depending which is the better result, the factory will start producing the new or modified product for commercial use.
A trial trail may be created which records all stages of the data objects throughout the different trial stages 210-214. This allows comparison of different trials and quality management monitoring. Also, the development process may be guided by process flow rules, which are stored within the data objects.
For each trial ID object 400, a project object 402, a plant object 404, a process order object 408, a recipe object 410, a primary product object 412, and a line object 414 may be defined. These may comprise information referring to the respective objects. Depending on the trial type, some of these objects may change. Also depending on the trial type, the objects may be accessible to users or locked.
For each trial ID object 400, a plurality of classification objects 406, batch objects 424, inspection lot objects 422, material consolidation and output objects 420, process parameter objects 418 and resource assignment objects 416 may be stored. Within these objects information concerning the respective product may be stored.
A trial may be a central object within trial management. Different trial attributes may be accessible during bench scale trials, pilot plant trials or factory scale trials. The user interface for a trial object provides a header block and multiple tab strips for single parts of a trial. Depending on the trial type, single tab strips or individual fields on the screen may be hidden, editable or mandatory.
Fixed attributes must be entered at the time of the trial creation and cannot be changed afterwards. Mandatory (M) attributes must be entered but may be changed afterwards. Editable (E) attributes are optional, not mandatory, and may be changed. Display only (D) attributes may be shown but may not be editable. Attributes which are not visible are depicted with “-” symbol.
As can be seem from
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US6370542 *||Oct 23, 1998||Apr 9, 2002||Qwest Communications International, Inc.||Method and apparatus for knowledge acquisition and management|
|US6834370 *||Jul 8, 1999||Dec 21, 2004||Osi Software, Inc.||Method for creating master recipes|
|US6983458 *||Jun 29, 2000||Jan 3, 2006||Kabushiki Kaisha Toshiba||System for optimizing data type definition in program language processing, method and computer readable recording medium therefor|
|US7051036 *||Dec 3, 2001||May 23, 2006||Kraft Foods Holdings, Inc.||Computer-implemented system and method for project development|
|US7080351 *||Apr 4, 2002||Jul 18, 2006||Bellsouth Intellectual Property Corp.||System and method for performing rapid application life cycle quality assurance|
|US20010052108 *||Aug 31, 1999||Dec 13, 2001||Michel K. Bowman-Amuah||System, method and article of manufacturing for a development architecture framework|
|US20030069659 *||Apr 23, 2002||Apr 10, 2003||Kabushiki Kaisha Toshiba||Product development management system, product development management method, product reliability decision system and product reliability decision method|
|US20030070159 *||Apr 6, 2001||Apr 10, 2003||Intrinsic Graphics, Inc.||Object decription language|
|US20040031014 *||Jun 13, 2002||Feb 12, 2004||Baecker Thomas Peter||Method of producing a software product|
|US20050188351 *||Oct 4, 2004||Aug 25, 2005||Siemens Aktiengesellschaft||Device and method for automatically generating automation software|
|1||*||Automating software specification, design and synthesis for computer aided control system design tools Ranville, S.; Bostic, D.; Toeppe, S.; vol. 1, Oct. 7-13, 2000 pp. 4C3/1-4C312 vol. 1, IEEE.|
|2||*||Experiments in automatic programming for general purposes Reformat, M.; Chai Xinwei; Miller, J.; Nov. 3-5, 2003 pp. 366-373, IEEE.|
|3||*||Implementing reusable, instrument independent test programs in the factory Neblett, B.; Sep. 16-19, 1996 pp. 206-212, IEEE.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US8165912 *||Jul 16, 2008||Apr 24, 2012||Ciena Corporation||Methods and systems for portfolio investment thesis based on application life cycles|
|US20100017243 *||Jul 16, 2008||Jan 21, 2010||Prasad Dasika||Methods and systems for portfolio investment thesis based on application life cycles|
|US20130060597 *||Mar 7, 2013||Infosys Limited||Knowledge and process based estimation system for engineering product design|
|U.S. Classification||717/102, 717/117, 717/106|
|International Classification||G06Q10/00, G06F17/50, G06F17/00, G06F9/44|
|Cooperative Classification||G06Q10/06, G06F17/50|
|European Classification||G06Q10/06, G06F17/50|
|Jul 1, 2004||AS||Assignment|
Owner name: SAP AKTIENGESELLSCHAFT, GERMANY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TOEBBEN, STEPHAN;WALTER, HELGA;KAU, RALF;AND OTHERS;REEL/FRAME:015543/0120
Effective date: 20040625
|Dec 21, 2005||AS||Assignment|
Owner name: SAP AG, GERMANY
Free format text: CHANGE OF NAME;ASSIGNOR:SAP AKTIENGESELLSCHAFT;REEL/FRAME:017358/0778
Effective date: 20050609
Owner name: SAP AG,GERMANY
Free format text: CHANGE OF NAME;ASSIGNOR:SAP AKTIENGESELLSCHAFT;REEL/FRAME:017358/0778
Effective date: 20050609
|Dec 23, 2013||FPAY||Fee payment|
Year of fee payment: 4
|Aug 26, 2014||AS||Assignment|
Owner name: SAP SE, GERMANY
Free format text: CHANGE OF NAME;ASSIGNOR:SAP AG;REEL/FRAME:033625/0334
Effective date: 20140707