The subject matter of this patent applications relates to modeling software systems, and more particularly to modeling the composition and interaction of components in a software system.
Enterprise software systems are generally large and complex. Such systems can require many different components, distributed across many different hardware platforms, possibly in several different geographical locations. Typical software modeling systems may not be able to reduce this complexity for end users. In order to design, configure, update or implement an enterprise software system, one is required to understand details of the system at varying levels, depending on his or her role in designing, managing or implementing the system. For example, a systems administrator may need a high-level technical understanding of how various software modules are installed on physical hardware, such as a server device or a network, and how those software modules interact with other software modules in the system. A person responsible for configuring the software may need a high-level functional understanding of the operations that each functional component provides. An application designer may need a low-level technical understanding of the various software interfaces that portions of the application require or implement. And an application developer may need a detailed understanding of the interfaces and functionality he or she is implementing in relation to the remainder of the system.
One of a plurality of process components is specified by defining at least one inbound operation initiated by an external process component to read or modify data encapsulated in a business object solely associated with the process component, and additionally defining at least one outbound operation to read or modify data encapsulated in a business object solely associated with an external process component. Each of the process components characterizes software implementing a respective and distinct process, and each of the process components defines a respective at least one service interface for communicating and interacting with other process components. In addition, all communication and interaction between process components takes place through the respective interfaces of the process components.
The outbound operations can be called after their respectively associated business objects are read or modified. In addition, the outbound operations can be operable to send a message after they are called. The outbound operations can be asynchronous outbound operations operable to generate asynchronous messages for receipt by an asynchronous inbound operations defined by an external process component (i.e., one of the other process components). The inbound operations can be synchronous operations operable to receive synchronous messages generated by external synchronous outbound operations defined by an external process component.
The process components can also include process agents that characterize software to implement the inbound and/or outbound operations. Some of the process agents can handle only one inbound or outbound operations while other process agents can handle more than one such operation. In some variations, an interface can be defined to handle more than one inbound or outbound operation. In addition, the inbound operation can be operable to receive a message of a first type and convert it into a message of a second type.
The process components can be associated with different deployment units that each characterize independently operable software that can, in some variations, be deployed on separate platforms. Communications between process components in different deployment units can be message based. Communications between process components within the same deployment unit need not be message based, and in some cases, such communications can utilize shared memory, database records, and the like.
In an interrelated aspect, at least one inbound operation, at least one outbound operation, and at least one business object are defined for a process component. The process component characterizes software implementing a respective and distinct process. Additionally, the process components defines at least one service interface for communicating and interacting with other process components, and all communication and interaction between process components taking place through the respective interfaces of the process components. The inbound operation is operable to start an execution of a step requested in an inbound message originating from an external process component by reading or modifying its respective business object. The outbound operation is called after the business object is modified or read and is operable to trigger a generation of an outgoing message requesting a step reading or modifying a business object associated with the other process component.
In a further interrelated aspect, at least one process agent is defined. Each process agent is either an inbound process agent or an outbound process agent. An inbound process agent is operable to receive a message from an inbound operation. An outbound process agent is operable to cause an outbound operation to send a message. Interactions are defined between at least one inbound process agent of the process component and at least one outbound process agent of an external component. In addition, interactions are defined between at least one inbound process agent of an external process component and at least one outbound process agent of the process component. With this arrangement, each of the process components characterizes software implementing a respective and distinct process, and each of the process components defines a respective at least one service interface for communicating and interacting with other process components.
Computer program products, which can be tangibly encoded on computer readable-material, are also described. Such computer program products can include executable instructions that cause a computer system to implement one or more of the acts and/or components described herein.
Similarly, computer systems are also described that can include a processor and a memory coupled to the processor. The memory can encode one or more programs that cause the processor to implement one or more of the acts and/or components described herein.
The subject matter described herein provides many advantages. A model provides modeling entities to represent aspects of a software system. Multiple views of the model are provided in a user interface. The model views offer varying levels of detail, allowing users to focus on the information that is important for their task. Model entities can be reused and correspond to reusable software that implements functionality corresponding to the model entity. The model supports dynamic mapping between incompatible message formats. A model can incorporate external components. The models can be used to generate metadata, which can be stored in a repository and used in various downstream processes and tools.
Moreover, the subject matter described herein provides a logical abstraction of how various software modules can interact to effect a business scenario. In particular, effective use can be made of process components as units of software reuse, to provide a design that can be implemented reliably in a cost effective way. Deployment units, each of which is deployable on a separate computer hardware platform independent of every other deployment unit, enable a scalable design. Furthermore, service interfaces of the process components can define a pair-wise interaction between pairs of process components that are in different deployment units in a scalable manner.
One implementation of the subject matter described in this specification provides all of the above advantages.
Details of one or more implementations of the subject matter described in this specification are set forth in the accompanying drawings and in the description below. Further features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
In the context of this document, a model is a representation of a software system, part of a software system, or an aspect of a software system. A model can be associated with one or more views. A view of a model represents a subset of the information in the model. For purposes of discussion, the term “model” will be used to refer to both a model or a view of the model. A modeling system can be used to create, modify and examine a model. A model can be used in a software development process to describe or specify a software application, or parts or aspects of a software application, for developers implementing or modifying the application. The model specifies the design to a useful level of detail or granularity. A compliant implementation of the modeled functionality will conform to the specification represented by the model.
A process component is a software package that realizes a business process and exposes its functionality as services. The functionality contains business transactions. A process component contains one or more semantically related business objects (e.g., 330, 310). A business object belongs to no more than one process component.
Process components are modular and context-independent. Context-independent means that a process component is not specific to a given integration scenario. (Integration scenarios are described later.) Therefore, process components are reusable, that is, they can be used in different integration scenarios.
A process component has one or more service interface modeling entities (316, 318, 320, 322, 336, 338) (or “interfaces”). An interface is a named grouping of one or more operations. It specifies offered (inbound service interface) or used (outbound service interface) functionality. While in general process components will have service interfaces, it is permissible to define a process component having no service operations. This would be appropriate, for example, for process components that inherently or by design interact only with process components deployed on the same hardware platform, in which circumstances a non-service method of interacting, e.g., through shared memory or database records, might be preferred.
An operation belongs to exactly one process component. A process component generally has multiple operations. An operation is the smallest, separately-callable function, described by a set of data types used as input, output, and fault parameters serving as a signature. An operation can use multiple message types for inbound, outbound, or error messages. An operation is specific to one interface, i.e., the same operation cannot be used in more than one interface.
Operations are described for purposes of exposition in terms of process agents. A process agent (or “agent”) is an optional modeling entity representing software that implements an operation. Operations can be implemented through other conventional techniques. Operations (and hence agents) can be synchronous or asynchronous, and inbound or outbound.
Synchronous outbound operations send synchronous request messages and process response messages. Synchronous inbound operations respond to messages from synchronous outbound operations. Synchronous communication is when a message is sent with the expectation that a response will be received promptly. Asynchronous communication comes with the expectation that a response will be provided by a separate operation invoked at a later point in time.
An asynchronous outbound operation is specific to a sending business object. If the asynchronous outbound operation is triggering a new communication to another process component, it is specific for the triggered process component. However, the same asynchronous outbound process operation can be used for two operations which are part of the same message choreography. If the asynchronous outbound operation is sending only a confirmation (not triggering), it might be re-used for different receiving process components.
Inbound operations are called after a message has been received. Based on a business object's status, inbound operations may initiate communication across deployment units, may initiate business-to-business (B2B) communication, or both by sending messages using well-defined services.
The model can describe the potential invocation by one process component of an operation on another process component. Graphically, this is depicted as an arc (340, 342) in
Messages are described by message modeling entities (or “messages”) in the model.
An process agent can be associated with a single interface. For example, interface 338 is associated with process agent 332, interface 336 is associated with process agent 334, interface 316 is associated with process agent 312, and interface 318 is associated with process agent 314. In one variation, each operation is associated with a process agent.
An output operation generally responds to a change in a business object associated with the operation. The operation will generally perform some processing of the data of the business object instance whose change triggered the event. An outbound operation triggers subsequent business process steps by sending messages using well-defined outbound services to another process component, which generally will be in another deployment unit, or to a business partner. For example, outbound process agent 324 in process component 306 can invoke an operation of interface 322 to send a message that will be received by the inbound process agent 312 in process component 308. The message is routed to a specific operation in interface 316 according to the signature or type of the message, which the inbound process agent 312 handles.
Inbound process agents when implemented are pieces of software that are used for the inbound part of a message-based communication. An inbound process agent starts the execution of the business process step requested in a message by creating or updating one or multiple business object instances, e.g., for associated business objects (330, 310) in response to receiving a message. Outbound process agents when implemented can send messages in response to a business object changing or interaction with a business object. For example, the inbound process agent 312 may modify business object 310, thus triggering outbound process agent 314 to send a message to the inbound process agent 328. If two operation invocations are part of the same message choreography, they are associated with the same process agent.
A business object model entity models a business object. A business object is a representation of a type of a uniquely identifiable business entity (an object instance) described by a structural model and zero or more service interfaces. Implemented business processes operate on business objects.
A business object represents a specific view on some well-defined business content. A business object represents content, which a typical business user would expect and understand with little explanation. Business objects are further categorized as business process objects and master data objects. A master data object is an object that encapsulates master data (i.e., data that is valid for a period of time). A business process object, which is the kind of business object generally found in a process component, is an object that encapsulates transactional data (i.e., data that is valid for a point in time). The term business object will be used generically to refer to a business process object and a master data object, unless the context requires otherwise. Properly implemented, business objects are implemented free of redundancies.
Business process objects are associated with exactly one process component. Master data objects are either associated with exactly one process component or exactly one deployment unit.
Business objects residing in a foundation layer are called business foundation objects. The foundation layer is deployed on every platform, and its business objects, process components, and reuse services are available to be used by all application scenarios. It is assumed that business objects in the foundation layer will be local in all integration scenarios and can be directly accessed synchronously from business objects within deployment units in an application layer. Business objects in the foundation layer can be associated with more than one process component.
Groups of process components can be organized into scenarios and deployment units. An integration scenario modeling entity (or “scenario”) describes a group of process components that interact directly or indirectly (i.e., through one or more other process components) with each other. A process component belongs to one deployment unit. Scenarios are discussed below.
A deployment unit modeling entity (e.g., 402, 410, 412) models a deployment unit, which includes one or more process components that can be deployed together on a single computer system platform.
Separate deployment units can be deployed on separate physical computing systems and include one or more process components. For example, a physical system can be a cluster of computers having direct access to a common database. The process components of one deployment unit interact with those of another deployment unit only using messages passed through one or more data communication networks or other suitable communication channels. Thus, a deployment unit software entity deployed on a platform belonging to Company A can interact with a deployment unit software entity deployed on a separate platform belonging to Company B, allowing for business-to-business communication. Or deployment units in different divisions of the same company can interact with each other. More than one instance of a given deployment unit software entity can execute at the same time.
The PCM models operations incorporated in a process component. For example, inbound operation Change Sales Order based on Customer Requirement Fulfillment Confirmation 508, and outbound operations Request Invoicing 520 and Confirm Sales Order 522. The arc 530 connecting the process component 504 to the interface 502 represents that the process component 504 can invoke an operation on that interface. The arcs 532 and 534 represent that the process component illustrated in 500 can invoke an operation on process components 525 and 528, respectively.
The PCM optionally models process agents (e.g., 510, 516, 518) corresponding to the process component's operations. For example, the Change Sales Order based on Customer Requirement inbound process agent 510 models processing or responding to a message routed to inbound operations 508 or 540. The inbound process agent 510, for example, will access and modify the Sales Order business object 514 as part of the processing, e.g., change the delivery date of goods or services on the sales order.
Process component 525 can receive one or more messages by way of outbound operation 520, as denoted by the arc 532 connecting outbound operation 520 to the process component 525. Based on the change associated with the business object 514, the Request Invoicing from Sales Order to Customer Invoice Processing outbound process agent 518 invokes operation 520 in interface 526 to send a message to process component 525. Likewise, external process component 528 can receive one or more messages sent by outbound operation 522, as denoted by the arc 534 connecting operation 522 to the process component 528. Based on the state or a state change associated with the business object 514, outbound process agent 516 can invoke operation 522 to send a message to external process component 528.
The Time and Labor Management process component 602 includes an Employee Time Calendar business object 606 that gives a read-only information of a calendar based overview of different time data (e.g., Planned working time, an absences and working time confirmation) of employees and their superposition (e.g., illness, vacation, etc). The Employee Time Calendar business object 606 may use a Notify Goods and Services Acknowledgement outbound process agent 608 to invoke a Notify of Goods and service Acknowledgement Notification operation 610 or a Notify of Goods and Service Acknowledgement Cancellation operation 612, which are both included in the Internal Service Acknowledgement Out interface 614. The Notify of Goods and service Acknowledgement Notification operation 610 notifies the Goods and Service Acknowledgement process component 604 of a service provided by an external employee. The Notify of Goods and service Acknowledgement Notification operation 610 sends a Goods and Service Acknowledgement Request message 616 when an active employee time with Goods and Service Acknowledgement relevant information is created or changed.
The Goods and Service Acknowledgement process component 604 receives the Goods and Service Acknowledgement Request message 616 via an Internal Acknowledgement In interface 618. Upon receipt of the Goods and Service Acknowledgement Request message 616, a Create Goods and Service Acknowledgement operation 620 is invoked to create Goods and service Acknowledgement, and Time and Labor Management by initiating a Maintain GSA based on Internal Acknowledgment inbound process agent 622. The Maintain GSA based on Internal Acknowledgment inbound process agent 622 updates or creates a Goods and Service Acknowledgement business object 624 to report the receipt of goods and services. The Goods and Service Acknowledgement business object 624 may be used when employees of a company can confirm that they have received the goods and services they ordered through internal requests, purchasers, or designated recipients of goods and services, can confirm that they have received the goods and services they ordered on behalf of the employees for whom they are responsible, or suppliers or service providers can report that they have delivered the requested goods, or have rendered they requested services.
The Notify Goods and Services Acknowledgement outbound process agent 608 may also invoke the Notify of Goods and Service Acknowledgement Cancellation operation 612 to notify the Goods and Service Acknowledgement process component 604 of a cancellation of goods and service. The Notify of Goods and Service Acknowledgement Cancellation operation 612 sends a Goods and Service Acknowledgement Cancellation Request message 626 when an active employee time with Goods and Service Acknowledgement relevant information is cancelled. Upon receipt of the Goods and Service Acknowledgement Cancellation Request message 626, a Cancel Goods and Service Acknowledgement operation 628 is invoked to cancel Goods and service Acknowledgement. Next, the Maintain GSA based on Internal Acknowledgment inbound process agent 622 updates the Goods and Service Acknowledgement business object 624 to report the cancellation of goods and services.
The message format of a message sent by an outbound operation need not match the message format expected by an inbound operation. If the message formats do not match, and the message is transformed, or mapped. Message mapping is indicated by interposition of an intermediary mapping model element between the source and the destination of the message in a PCM or a PCIM (see below).
The illustrated integration scenario 800 is for a service procurement software application. The service procurement application is software that implements an end-to-end process used to procure services. The scenario 800 includes nine deployment units: a Financial Accounting unit 802, a Project Management unit 804, a Purchasing unit 806, a Supplier Invoicing unit 808, a Payment unit 810, a RFQ Processing unit 812, a Due Item Management unit 814, a Requisitioning unit 816, and a Human Capital Management unit 818.
The Financial Accounting deployment unit 802 includes an Accounting process component 803 that records all relevant business transactions.
The Project Management deployment unit 804 includes a Project Processing component 820 that is responsible for structuring, planning, and executing measures or projects (e.g., short-term measures, complex projects, etc).
The Purchasing deployment unit 806 includes four process components: a Purchase Request Processing process component 828, a Purchase Order Processing process component 830, a Purchasing Contract process component 832, and a Goods and Service Acknowledgement process component 833.
The Purchase Request Processing process component 828 provides a request or instruction to the purchasing department to purchase specified goods or services in specified quantities within a specified time.
The Purchase Order Processing process component 830 includes a purchase order business object and a purchase order confirmation business object. The purchase order is a request from a purchaser to an external supplier to deliver a specified quantity of goods, or perform a specified service within a specified time. The purchase order confirmation is a communication from a supplier to a purchaser to advise that a purchase order has been received. In particular, a purchase order confirmation may advise the purchaser of the supplier accepting the purchase order, or the supplier proposing changes to the purchase order, or the supplier not accepting the purchase order.
The Purchasing Contract process component 832 handles an agreement between a purchaser and a supplier that details the supply of goods or the performance of services at agreed conditions. The Purchasing Contract process component includes the purchasing contract business object.
The Goods and Service Acknowledgement 833 includes a Goods and Service Acknowledgement business object. The Goods and service Acknowledgement business object is a document that states the recipient's, for example, a purchaser's, obligation to pay the supplier for goods received or services rendered. An invoice is normally created after the goods and service acknowledgement has been confirmed.
The Supplier Invoicing deployment unit 808 includes a Supplier Invoice Processing process component 836. The Supplier Invoice Processing process component 836 includes a supplier invoice business object and a supplier invoice request business object. The supplier invoice is a document that states the recipient's obligation to pay the supplier for goods received or services rendered. The invoice may be created after the goods and service acknowledgment has been confirmed. The supplier invoice request is a document that is sent to invoice verification, advising that an invoice for specified quantities and prices is expected and may be created through evaluation settlement. The system uses the invoice request as a basis for invoice verification, as well as for the automatic creation of the invoice. The Payment deployment unit 810 includes a Payment Process component 838. The Payment Processing process component 838 is used to handle all incoming and outgoing payments as well as represent the main database for a liquidity status.
The RFQ deployment unit 812 includes an RFQ Processing process component 840. An RFQ Processing deployment unit includes a Request for Response business object and a quote business object. The request for quotation (RFQ) is a description of materials and services that purchasers use to request responses from potential suppliers. Requests for Quotation can be one of the following types: a request for (price) information, a request for quote that may run over a certain period of time, a request for proposal in complex purchasing situation or live auctions that may be performed over a short time frame. The quote is a response to a request for quotation in which a supplier offers to sell goods and services at a certain price. The quote can be subject to complex pricing and conditions.
The Due Item Management deployment unit 814 includes a Due Item Processing process component 842. The Due Item Processing process component 842 is used to manage all payables, receivables from service and supply and corresponding sales including a withholding tax.
The Requisitioning deployment unit 816 includes an Internal Request Processing process component 844. The Internal Request Processing deployment unit 816 includes an Internal Request business object. Employees of a company may make an internal request for the procurement of goods or services for the company. For example, the employees may order stationary, computer hardware, or removal services by creating an internal request. The internal request can be fulfilled by an issue of a purchase request to the purchasing department, a reservation of goods from stock, or a production request.
The Human Capital Management deployment unit 818 includes a Time and Labor Management process component 848. The Time and Labor Management process component 848 supports the definition of employees' planned working time as well as the recording or the actual working times and absences and their evaluation.
The foundation layer includes a Source of Supply Determination process component 834, a Customer Invoice Processing at Supplier process component 837, a Sales Order Processing at Supplier process component 846, a Payment Processing at Business Partner process component 850, a Bank statement creation at bank process component 852, and a Payment order processing at house bank process component 854.
The service procurement design includes a Source of Supply Determination process component 834 that uses two business objects to determine a source of supply: a supply quota arrangement business object, and a source of supply business object. A supply quota arrangement is a distribution of material requirements or goods to different sources of supply, business partners, or organizational units within a company. An example of the use of supply quota arrangements is the distribution of material requirements between in-house production and different sources for external procurement. A supply quota arrangement can also define the distribution of goods to customers in case of excess production or shortages. A source of supply is an object that describes a logical link between a possible source of products and a possible target.
A number of external process components, described below, will be used to describe the architectural design. These include a Customer Invoice Processing at Supplier process component 837, a Sales Order Processing at Supplier process component 846, a Payment Processing at Business Partner process component 850, a Bank statement creation at bank process component 852, and a Payment order processing at house bank process component 854.
The Supplier Invoicing deployment unit 808 receives messages from a Customer Invoice at Supplier processing component 837, which is used, at a supplier, to charge a customer for the delivery of goods or services.
The service procurement design includes a Sales Order Processing at Supplier process component 846 that may receive messages from the RFQ Processing process component 840. The Sales Order Processing at Supplier process component 846 handles customers' requests to a company for delivery of goods or services at a certain time. The requests are received by a sales area, which is then responsible for fulfilling the contract.
The Payment Processing at Business Partner process component 850, the Bank statement creation at bank process component 852, and the Payment order processing at house bank process component 854 may interact with the Payment Processing process component 838. The Payment Processing Process component 838 may send updates to a Payment Processing at Business Partner processing component 850, which is used to handle, at business partner, all incoming and outgoing payments and represent the main data base for the liquidity status. The Payment Processing Process component 838 also receives messages from the Bank statement creations at bank process component 852. The message may include a bank Statement for a bank account. The Payment Processing Process component 838 sends messages to the Payment order processing at house bank process component 854. The message may include a Bank Payment Order that is a Payment Order which will be sent to a house bank. The bank payment order may contain bank transfers as well as direct debits.
The connector 829 symbol is a graphical convention to improve graphical layout for human reading. A connector is a placeholder for another process component. For example, the connector 829 could be a placeholder for an Accounting process component.
In one implementation, the aforementioned graphical depictions can be presented singularly or in combination with each other in the GUI 204. Moreover, a given graphical depiction can present all of its underlying information or a portion thereof, while allowing other portions to be viewed through a navigation mechanism, e.g., user selection of a graphical element, issuance of a command, or other suitable means.
Information can also be represented by colors in the display of model entities. For example, color can be used to distinguish types of business objects, types of process agents and types of interfaces.
In this example, potential interactions are shown between a Purchase Order Processing process component 1102 and an external Sales Order Processing at Supplier process component 1104. The Purchase Order Processing process component 1102 includes a Purchase Order business object 1106 which is a request from a purchaser to an external supplier to deliver a specified quantity of goods, or perform a specified service, within a specified time. The Request Purchase Order to Supplier outbound process agent 1108 can request invocation of a Request Purchase Order Creation operation 1112, a Request Purchase Order Cancellation operation 1114, or a Request Purchase Order Change operation 1116 in an Ordering Out interface 1110.
The Request Purchase Order Cancellation operation 1114 requests a Cancellation of a Purchase Order that was formerly ordered at a supplier which creates a Purchase Order Cancellation Request message 1118. The Request Purchase Order Change operation 1116 requests a change of a purchase order that was formerly ordered at the supplier which creates a Purchase Order Change Request message 1120. The Request Purchase Order Creation operation 1112 requests a Purchase Order from a Supplier which creates a Purchase Order Request 1122.
Upon receiving a create, a change, or a cancellation message, the Sales Order Processing process component 1104 may create a Purchase Order Confirmation message 1123 to update the Purchase Order Processing component 1102. To complete the update, a Create Purchase Order Confirmation operation 1124, included in an Ordering In interface 1125, may transfer the update to the Purchase Order Confirmation business object 1128 by using a Create Purchase Order inbound process agent 1126. The Purchase Order Confirmation business object 1128 is a confirmation from an external supplier to the request of a purchaser to deliver a specified quantity of material, or perform a specified service, at a specified price within a specified time.
The subject matter described in this specification and all of the functional operations described in this specification can be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structural means disclosed in this specification and structural equivalents thereof, or in combinations of them. The subject matter described in this specification can be implemented as one or more computer program products, i.e., one or more computer programs tangibly embodied in an information carrier, e.g., in a machine-readable storage device or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program (also known as a program, software, software application, or code) can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program does not necessarily correspond to a file. A program can be stored in a portion of a file that holds other programs or data, in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
The processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, the subject matter described in this specification can be implemented on a computer having a display device, e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor, for displaying information to the user and a keyboard and a pointing device, e.g., a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
The subject matter described in this specification can be implemented in a computing system that includes a back-end component (e.g., a data server), a middleware component (e.g., an application server), or a front-end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described herein), or any combination of such back-end, middleware, and front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”), e.g., the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
The subject matter has been described in terms of particular variations, but other variations can be implemented and are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking and parallel processing may be advantageous. Other variations are within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
4947321 | Spence et al. | Aug 1990 | A |
5361198 | Harmon et al. | Nov 1994 | A |
5550734 | Tarter et al. | Aug 1996 | A |
5560005 | Hoover et al. | Sep 1996 | A |
5566097 | Myers et al. | Oct 1996 | A |
5586312 | Johnson et al. | Dec 1996 | A |
5590277 | Fuchs et al. | Dec 1996 | A |
5632022 | Warren et al. | May 1997 | A |
5634127 | Cloud et al. | May 1997 | A |
5680619 | Gudmundson et al. | Oct 1997 | A |
5704044 | Tarter et al. | Dec 1997 | A |
5710917 | Musa et al. | Jan 1998 | A |
5768119 | Havekost et al. | Jun 1998 | A |
5822585 | Noble et al. | Oct 1998 | A |
5832218 | Gibbs et al. | Nov 1998 | A |
5848291 | Milne et al. | Dec 1998 | A |
5867495 | Elliott et al. | Feb 1999 | A |
5870588 | Rompaey et al. | Feb 1999 | A |
5881230 | Christensen et al. | Mar 1999 | A |
5893106 | Brobst et al. | Apr 1999 | A |
5898872 | Richley | Apr 1999 | A |
5918219 | Isherwood | Jun 1999 | A |
5987247 | Lau | Nov 1999 | A |
5991536 | Brodsky et al. | Nov 1999 | A |
H1830 | Petrimoulx et al. | Jan 2000 | H |
6028997 | Leymann et al. | Feb 2000 | A |
6038393 | Iyengar et al. | Mar 2000 | A |
6049838 | Miller et al. | Apr 2000 | A |
6067559 | Allard et al. | May 2000 | A |
6070197 | Cobb et al. | May 2000 | A |
6112024 | Almond et al. | Aug 2000 | A |
6151582 | Huang et al. | Nov 2000 | A |
6167563 | Fontana et al. | Dec 2000 | A |
6167564 | Fontana et al. | Dec 2000 | A |
6177932 | Galdes et al. | Jan 2001 | B1 |
6182133 | Horvitz | Jan 2001 | B1 |
6192390 | Berger et al. | Feb 2001 | B1 |
6208345 | Sheard et al. | Mar 2001 | B1 |
6237136 | Sadahiro | May 2001 | B1 |
6272672 | Conway | Aug 2001 | B1 |
6311170 | Embrey | Oct 2001 | B1 |
6338097 | Krenzke et al. | Jan 2002 | B1 |
6424991 | Gish | Jul 2002 | B1 |
6434740 | Monday et al. | Aug 2002 | B1 |
6442748 | Bowman-Amuah | Aug 2002 | B1 |
6445782 | Elfe et al. | Sep 2002 | B1 |
6446045 | Stone et al. | Sep 2002 | B1 |
6446092 | Sutter | Sep 2002 | B1 |
6473794 | Guheen et al. | Oct 2002 | B1 |
6493716 | Azagury et al. | Dec 2002 | B1 |
6571220 | Ogino et al. | May 2003 | B1 |
6594535 | Constanza | Jul 2003 | B1 |
6601233 | Underwood | Jul 2003 | B1 |
6601234 | Bowman-Amuah | Jul 2003 | B1 |
6606744 | Mikurak | Aug 2003 | B1 |
6609100 | Smith et al. | Aug 2003 | B2 |
6640238 | Bowman-Amuah | Oct 2003 | B1 |
6671673 | Baseman et al. | Dec 2003 | B1 |
6678882 | Hurley et al. | Jan 2004 | B1 |
6687734 | Sellink et al. | Feb 2004 | B1 |
6691151 | Cheyer et al. | Feb 2004 | B1 |
6721783 | Blossman et al. | Apr 2004 | B1 |
6738964 | Zink et al. | May 2004 | B1 |
6747679 | Finch et al. | Jun 2004 | B1 |
6750885 | Finch et al. | Jun 2004 | B1 |
6757837 | Platt et al. | Jun 2004 | B1 |
6764009 | Melick et al. | Jul 2004 | B2 |
6772216 | Ankireddipally et al. | Aug 2004 | B1 |
6782536 | Moore et al. | Aug 2004 | B2 |
6789252 | Burke et al. | Sep 2004 | B1 |
6845499 | Srivastava et al. | Jan 2005 | B2 |
6847854 | Discenzo | Jan 2005 | B2 |
6859931 | Cheyer et al. | Feb 2005 | B1 |
6889197 | Lidow | May 2005 | B2 |
6889375 | Chan et al. | May 2005 | B1 |
6895438 | Ulrich | May 2005 | B1 |
6898783 | Gupta et al. | May 2005 | B1 |
6904399 | Cooper et al. | Jun 2005 | B2 |
6907395 | Hunt et al. | Jun 2005 | B1 |
6954736 | Menninger et al. | Oct 2005 | B2 |
6985939 | Fletcher et al. | Jan 2006 | B2 |
6990466 | Hu | Jan 2006 | B1 |
7003474 | Lidow | Feb 2006 | B2 |
7031998 | Archbold | Apr 2006 | B2 |
7043448 | Campbell | May 2006 | B2 |
7047518 | Little et al. | May 2006 | B2 |
7050056 | Meyringer | May 2006 | B2 |
7050873 | Discenzo | May 2006 | B1 |
7055136 | Dzoba et al. | May 2006 | B2 |
7058587 | Horne | Jun 2006 | B1 |
7069536 | Yaung | Jun 2006 | B2 |
7072855 | Godlewski et al. | Jul 2006 | B1 |
7076766 | Wirts et al. | Jul 2006 | B2 |
7100195 | Underwood | Aug 2006 | B1 |
7103873 | Tanner et al. | Sep 2006 | B2 |
7117447 | Cobb et al. | Oct 2006 | B2 |
7120597 | Knudtzon et al. | Oct 2006 | B1 |
7120896 | Budhiraja et al. | Oct 2006 | B2 |
7131069 | Rush et al. | Oct 2006 | B1 |
7149887 | Morrison et al. | Dec 2006 | B2 |
7155403 | Cirulli et al. | Dec 2006 | B2 |
7155409 | Stroh | Dec 2006 | B1 |
7181694 | Reiss et al. | Feb 2007 | B2 |
7184964 | Wang | Feb 2007 | B2 |
7194431 | Land et al. | Mar 2007 | B1 |
7197740 | Beringer et al. | Mar 2007 | B2 |
7200569 | Gallagher et al. | Apr 2007 | B2 |
7206768 | deGroeve et al. | Apr 2007 | B1 |
7213232 | Knowles | May 2007 | B1 |
7216091 | Blandina et al. | May 2007 | B1 |
7219107 | Beringer | May 2007 | B2 |
7222786 | Renz et al. | May 2007 | B2 |
7225240 | Fox et al. | May 2007 | B1 |
7249044 | Kumar et al. | Jul 2007 | B2 |
7257254 | Tunney | Aug 2007 | B2 |
7283973 | Loghmani et al. | Oct 2007 | B1 |
7293254 | Bloesch et al. | Nov 2007 | B2 |
7299970 | Ching | Nov 2007 | B1 |
7315830 | Wirtz et al. | Jan 2008 | B1 |
7322024 | Carlson et al. | Jan 2008 | B2 |
7324966 | Scheer | Jan 2008 | B2 |
7353180 | Silverstone et al. | Apr 2008 | B1 |
7356492 | Hazi et al. | Apr 2008 | B2 |
7367011 | Ramsey et al. | Apr 2008 | B2 |
7370315 | Lovell et al. | May 2008 | B1 |
7376601 | Aldridge | May 2008 | B1 |
7376604 | Butcher | May 2008 | B1 |
7376632 | Sadek et al. | May 2008 | B1 |
7383201 | Matsuzaki et al. | Jun 2008 | B2 |
7386833 | Granny et al. | Jun 2008 | B2 |
7406716 | Kanamori et al. | Jul 2008 | B2 |
7415697 | Houlding | Aug 2008 | B1 |
7418409 | Goel | Aug 2008 | B1 |
7418424 | Martin et al. | Aug 2008 | B2 |
7424701 | Kendall et al. | Sep 2008 | B2 |
7433979 | Need | Oct 2008 | B2 |
7448022 | Ram et al. | Nov 2008 | B1 |
7451432 | Shukla et al. | Nov 2008 | B2 |
7460654 | Jenkins et al. | Dec 2008 | B1 |
7461030 | Hibler et al. | Dec 2008 | B2 |
7469233 | Shooks et al. | Dec 2008 | B2 |
7516088 | Johnson et al. | Apr 2009 | B2 |
7523054 | Tyson-Quah | Apr 2009 | B2 |
7529699 | Fuse et al. | May 2009 | B2 |
7536325 | Randell et al. | May 2009 | B2 |
7536354 | deGroeve et al. | May 2009 | B1 |
7546520 | Davidson et al. | Jun 2009 | B2 |
7546575 | Dillman et al. | Jun 2009 | B1 |
7565640 | Shukla et al. | Jul 2009 | B2 |
7574694 | Mangan et al. | Aug 2009 | B2 |
7624371 | Kulkarni et al. | Nov 2009 | B2 |
7631291 | Shukla et al. | Dec 2009 | B2 |
7640195 | Von Zimmermann et al. | Dec 2009 | B2 |
7640291 | Maturana et al. | Dec 2009 | B2 |
7644390 | Khodabandehloo et al. | Jan 2010 | B2 |
7657406 | Tolone et al. | Feb 2010 | B2 |
7657445 | Goux | Feb 2010 | B1 |
7665083 | Demant et al. | Feb 2010 | B2 |
7668761 | Jenkins et al. | Feb 2010 | B2 |
7672888 | Allin et al. | Mar 2010 | B2 |
7681176 | Wills et al. | Mar 2010 | B2 |
7693586 | Dumas et al. | Apr 2010 | B2 |
7703073 | Illowsky et al. | Apr 2010 | B2 |
7739160 | Ryan et al. | Jun 2010 | B1 |
7742985 | Digrigoli et al. | Jun 2010 | B1 |
7747980 | Illowsky et al. | Jun 2010 | B2 |
7765156 | Staniar et al. | Jul 2010 | B2 |
7765521 | Bryant | Jul 2010 | B2 |
7788145 | Wadawadigi et al. | Aug 2010 | B2 |
7788319 | Schmidt | Aug 2010 | B2 |
7793256 | Charisius et al. | Sep 2010 | B2 |
7793258 | Sundararajan et al. | Sep 2010 | B2 |
7797698 | Diament et al. | Sep 2010 | B2 |
7814142 | Mamou et al. | Oct 2010 | B2 |
7822682 | Arnold et al. | Oct 2010 | B2 |
7835971 | Stockton et al. | Nov 2010 | B2 |
7886041 | Outhred et al. | Feb 2011 | B2 |
7895568 | Goodwin et al. | Feb 2011 | B1 |
7904350 | Ayala et al. | Mar 2011 | B2 |
7912755 | Perry et al. | Mar 2011 | B2 |
7917889 | Devarakonda et al. | Mar 2011 | B2 |
7925985 | Moore | Apr 2011 | B2 |
8001519 | Conallen et al. | Aug 2011 | B2 |
8010938 | Elaasar | Aug 2011 | B2 |
8051332 | Zakonov et al. | Nov 2011 | B2 |
8091065 | Mir et al. | Jan 2012 | B2 |
8112738 | Pohl et al. | Feb 2012 | B2 |
20010052108 | Bowman-Amuah | Dec 2001 | A1 |
20020026394 | Savage et al. | Feb 2002 | A1 |
20020042756 | Kumar et al. | Apr 2002 | A1 |
20020049622 | Lettich et al. | Apr 2002 | A1 |
20020073114 | Nicastro et al. | Jun 2002 | A1 |
20020078046 | Uluakar et al. | Jun 2002 | A1 |
20020082892 | Raffel et al. | Jun 2002 | A1 |
20020103660 | Cramon et al. | Aug 2002 | A1 |
20020104071 | Charisius et al. | Aug 2002 | A1 |
20020107826 | Ramachandran et al. | Aug 2002 | A1 |
20020120553 | Bowman-Amuah | Aug 2002 | A1 |
20020133368 | Strutt et al. | Sep 2002 | A1 |
20020138281 | Cirulli et al. | Sep 2002 | A1 |
20020138358 | Scheer | Sep 2002 | A1 |
20020143598 | Scheer | Oct 2002 | A1 |
20020156695 | Edwards | Oct 2002 | A1 |
20020161907 | Moon | Oct 2002 | A1 |
20020184111 | Swanson | Dec 2002 | A1 |
20020188486 | Gil et al. | Dec 2002 | A1 |
20020198798 | Ludwig et al. | Dec 2002 | A1 |
20020198828 | Ludwig et al. | Dec 2002 | A1 |
20030009754 | Rowley et al. | Jan 2003 | A1 |
20030058277 | Bowman-Amuah | Mar 2003 | A1 |
20030069774 | Hoffman et al. | Apr 2003 | A1 |
20030074271 | Viswanath et al. | Apr 2003 | A1 |
20030074360 | Chen et al. | Apr 2003 | A1 |
20030083762 | Farrah et al. | May 2003 | A1 |
20030084127 | Budhiraja et al. | May 2003 | A1 |
20030130860 | Datta et al. | Jul 2003 | A1 |
20030182206 | Hendrix et al. | Sep 2003 | A1 |
20030212602 | Schaller | Nov 2003 | A1 |
20030233290 | Yang et al. | Dec 2003 | A1 |
20040015367 | Nicastro et al. | Jan 2004 | A1 |
20040034578 | Oney et al. | Feb 2004 | A1 |
20040054564 | Fonseca et al. | Mar 2004 | A1 |
20040093268 | Ramchandani et al. | May 2004 | A1 |
20040093381 | Hodges et al. | May 2004 | A1 |
20040111304 | Meka et al. | Jun 2004 | A1 |
20040111639 | Schwartz et al. | Jun 2004 | A1 |
20040128180 | Abel et al. | Jul 2004 | A1 |
20040133481 | Schwarze et al. | Jul 2004 | A1 |
20040153359 | Ho et al. | Aug 2004 | A1 |
20040158506 | Wille | Aug 2004 | A1 |
20040172510 | Nagashima et al. | Sep 2004 | A1 |
20040181470 | Grounds | Sep 2004 | A1 |
20040181538 | Lo et al. | Sep 2004 | A1 |
20040205011 | Northington et al. | Oct 2004 | A1 |
20040236639 | Candadai et al. | Nov 2004 | A1 |
20040236687 | Tyson-Quah | Nov 2004 | A1 |
20040243489 | Mitchell et al. | Dec 2004 | A1 |
20040254866 | Crumbach et al. | Dec 2004 | A1 |
20040255152 | Kanamori et al. | Dec 2004 | A1 |
20050010501 | Ward, Jr. | Jan 2005 | A1 |
20050033588 | Ruiz et al. | Feb 2005 | A1 |
20050044015 | Bracken et al. | Feb 2005 | A1 |
20050060235 | Byrne | Mar 2005 | A2 |
20050060408 | McIntyre et al. | Mar 2005 | A1 |
20050065828 | Kroswek et al. | Mar 2005 | A1 |
20050108680 | Cheng et al. | May 2005 | A1 |
20050113092 | Coppinger et al. | May 2005 | A1 |
20050114829 | Robin et al. | May 2005 | A1 |
20050125310 | Hazi et al. | Jun 2005 | A1 |
20050144125 | Erbey et al. | Jun 2005 | A1 |
20050144226 | Purewal | Jun 2005 | A1 |
20050156500 | Birecki et al. | Jul 2005 | A1 |
20050160104 | Meera et al. | Jul 2005 | A1 |
20050165784 | Gomez et al. | Jul 2005 | A1 |
20050177435 | Lidow | Aug 2005 | A1 |
20050203760 | Gottumukkala et al. | Sep 2005 | A1 |
20050203813 | Welter et al. | Sep 2005 | A1 |
20050209732 | Audimoolam et al. | Sep 2005 | A1 |
20050209943 | Ballow et al. | Sep 2005 | A1 |
20050216325 | Ziad et al. | Sep 2005 | A1 |
20050216507 | Wright | Sep 2005 | A1 |
20050222896 | Rhyne et al. | Oct 2005 | A1 |
20050234787 | Wallmeier et al. | Oct 2005 | A1 |
20050235020 | Gabelmann et al. | Oct 2005 | A1 |
20050240592 | Mamou et al. | Oct 2005 | A1 |
20050246250 | Murray | Nov 2005 | A1 |
20050246482 | Gabelmann et al. | Nov 2005 | A1 |
20050256775 | Schapler et al. | Nov 2005 | A1 |
20050256882 | Able et al. | Nov 2005 | A1 |
20050257125 | Roesner et al. | Nov 2005 | A1 |
20050257197 | Herter et al. | Nov 2005 | A1 |
20050262192 | Mamou et al. | Nov 2005 | A1 |
20050262453 | Massasso | Nov 2005 | A1 |
20050284934 | Ernesti et al. | Dec 2005 | A1 |
20050288987 | Sattler et al. | Dec 2005 | A1 |
20050289020 | Bruns et al. | Dec 2005 | A1 |
20050289079 | Krishan et al. | Dec 2005 | A1 |
20060004802 | Phillips et al. | Jan 2006 | A1 |
20060053063 | Nagar | Mar 2006 | A1 |
20060064344 | Lidow | Mar 2006 | A1 |
20060074704 | Shukla et al. | Apr 2006 | A1 |
20060074731 | Green et al. | Apr 2006 | A1 |
20060080338 | Seubert et al. | Apr 2006 | A1 |
20060085243 | Cooper et al. | Apr 2006 | A1 |
20060085294 | Boerner et al. | Apr 2006 | A1 |
20060085336 | Seubert et al. | Apr 2006 | A1 |
20060089886 | Wong | Apr 2006 | A1 |
20060095439 | Buchmann et al. | May 2006 | A1 |
20060129978 | Abrari et al. | Jun 2006 | A1 |
20060143029 | Akbay et al. | Jun 2006 | A1 |
20060149574 | Bradley et al. | Jul 2006 | A1 |
20060206352 | Pulianda | Sep 2006 | A1 |
20060248504 | Hughes | Nov 2006 | A1 |
20060274720 | Adams et al. | Dec 2006 | A1 |
20060287939 | Harel et al. | Dec 2006 | A1 |
20060288350 | Grigorovitch et al. | Dec 2006 | A1 |
20070011650 | Hage et al. | Jan 2007 | A1 |
20070022410 | Ban et al. | Jan 2007 | A1 |
20070050308 | Latvala et al. | Mar 2007 | A1 |
20070075916 | Bump et al. | Apr 2007 | A1 |
20070094098 | Mayer et al. | Apr 2007 | A1 |
20070094261 | Phelan et al. | Apr 2007 | A1 |
20070129964 | Helmolt et al. | Jun 2007 | A1 |
20070129984 | von Helmolt et al. | Jun 2007 | A1 |
20070129985 | Helmolt et al. | Jun 2007 | A1 |
20070143164 | Kaila et al. | Jun 2007 | A1 |
20070150332 | Grichnik et al. | Jun 2007 | A1 |
20070150387 | Seubert et al. | Jun 2007 | A1 |
20070150855 | Jeong | Jun 2007 | A1 |
20070156428 | Brecht-Tillinger et al. | Jul 2007 | A1 |
20070156430 | Kaetker et al. | Jul 2007 | A1 |
20070156474 | Scherberger et al. | Jul 2007 | A1 |
20070156475 | Berger et al. | Jul 2007 | A1 |
20070156476 | Koegler et al. | Jul 2007 | A1 |
20070156482 | Bagheri | Jul 2007 | A1 |
20070156489 | Berger et al. | Jul 2007 | A1 |
20070156493 | Tebbe et al. | Jul 2007 | A1 |
20070156499 | Berger et al. | Jul 2007 | A1 |
20070156500 | Merkel et al. | Jul 2007 | A1 |
20070156538 | Peter et al. | Jul 2007 | A1 |
20070156550 | Der Emde et al. | Jul 2007 | A1 |
20070156731 | Ben-Zeev | Jul 2007 | A1 |
20070162893 | Moosmann et al. | Jul 2007 | A1 |
20070164849 | Haeberle et al. | Jul 2007 | A1 |
20070168303 | Moosmann et al. | Jul 2007 | A1 |
20070174068 | Alfandary et al. | Jul 2007 | A1 |
20070174145 | Hetzer et al. | Jul 2007 | A1 |
20070174811 | Kaetker et al. | Jul 2007 | A1 |
20070186209 | Kaetker et al. | Aug 2007 | A1 |
20070197877 | Decorte et al. | Aug 2007 | A1 |
20070198391 | Dreyer et al. | Aug 2007 | A1 |
20070214065 | Kahlon et al. | Sep 2007 | A1 |
20070220046 | Moosmann et al. | Sep 2007 | A1 |
20070220143 | Lund et al. | Sep 2007 | A1 |
20070233539 | Suenderhauf et al. | Oct 2007 | A1 |
20070233541 | Schorr et al. | Oct 2007 | A1 |
20070233545 | Cala et al. | Oct 2007 | A1 |
20070233574 | Koegler et al. | Oct 2007 | A1 |
20070233575 | Berger et al. | Oct 2007 | A1 |
20070233581 | Peter | Oct 2007 | A1 |
20070233598 | Der Emde et al. | Oct 2007 | A1 |
20070234282 | Prigge et al. | Oct 2007 | A1 |
20070239508 | Fazal et al. | Oct 2007 | A1 |
20070239569 | Lucas et al. | Oct 2007 | A1 |
20070265860 | Herrmann et al. | Nov 2007 | A1 |
20070265862 | Freund et al. | Nov 2007 | A1 |
20080004929 | Raffel et al. | Jan 2008 | A9 |
20080017722 | Snyder et al. | Jan 2008 | A1 |
20080027831 | Gerhardt | Jan 2008 | A1 |
20080065437 | Dybvig | Mar 2008 | A1 |
20080120129 | Seubert et al. | May 2008 | A1 |
20080147507 | Langhammer | Jun 2008 | A1 |
20080162382 | Clayton et al. | Jul 2008 | A1 |
20080208707 | Erbey et al. | Aug 2008 | A1 |
20080215354 | Halverson et al. | Sep 2008 | A1 |
20080263152 | Daniels et al. | Oct 2008 | A1 |
20080300959 | Sinha et al. | Dec 2008 | A1 |
20090037287 | Baitalmal et al. | Feb 2009 | A1 |
20090037492 | Baitalmal et al. | Feb 2009 | A1 |
20090063112 | Hader et al. | Mar 2009 | A1 |
20090171716 | Suenderhauf et al. | Jul 2009 | A1 |
20090171818 | Penning et al. | Jul 2009 | A1 |
20090172699 | Jungkind et al. | Jul 2009 | A1 |
20090189743 | Abraham et al. | Jul 2009 | A1 |
20090192858 | Johnson | Jul 2009 | A1 |
20100070324 | Bock et al. | Mar 2010 | A1 |
20100070331 | Koegler et al. | Mar 2010 | A1 |
20100070336 | Koegler et al. | Mar 2010 | A1 |
20100070395 | Elkeles et al. | Mar 2010 | A1 |
20100070555 | Duparc et al. | Mar 2010 | A1 |
20100100464 | Ellis et al. | Apr 2010 | A1 |
20100138269 | Cirpus et al. | Jun 2010 | A1 |
20110252395 | Charisius et al. | Oct 2011 | A1 |
Number | Date | Country |
---|---|---|
2000023874 | Apr 2000 | WO |
WO 2004083984 | Sep 2004 | WO |
WO 2005114381 | Dec 2005 | WO |
Entry |
---|
He, J. et al., “Component-Based Software Engineering: The Need to Link Methods and Their Theories”, Theoretical Aspects of Computer ICTAC 2005. Second International Colloquium. Proceedings (Lecture notes in Computer Science vol. 3722) Springer-Verlag Berlin, Germany, (Oct. 2005), pp. 70-95. |
Aleksy, M. et al.; “Interoperability of Java-Based Applications and SAP's Business Framework State of the Art and Desirable Developments”; Proceedings of the International Symposium on Edinburgh, UK; Sep. 1999; IEEE Computer Soc.; pp. 190-200. |
Arch-int, S. et al.; “Development of Industrial Information Systems on the Web Using Busienss Components”; Computers in Industry; vol. 60; 2003; pp. 231-250. |
Astudillo, H.; “How Conceptual System Architecture Leads to Business Process”; ACM; 2000; pp. 35-36. |
Beisiegel, M. et al.; “Service Component Architecture: Building Systems Using a Service Oriented Architecture”; Whitepaper [online]; Nov. 2005; pp. 1-31; http://download.boulder.ibm.com/ibmdl/pub/software/dw/specs/ws-sca/SCA—White—Paper1—09.pdf. |
Deimel, A.; “The SAP R/3 Business Framework”; Software—Concepts & Tools; vol. 19, No. 1; 1998; pp. 29-36. |
Fellner, K.J., et al.; “Classification Framework for Business Components”; System Sciences; Proceedings of the 33rd Annual Hawaii International Conference; Jan. 2000; pp. 3239-3248. |
Ferguson D.F. et al.; “Service-Oriented Architecture: Programming Model and Product Architecture”; IBM Systems Journal [online]; vol. 44, No. 4; Dec. 1, 2005; pp. 753-780; http://researchweb.watson.ibm.com/journal/sj/444/ferguson.pdf. |
Gauthier, P. and OSS-J Architecture Board; “OSS through Java (TM) J2EE Design Guidelines”; [online]; Oct. 31, 2001; http://www.ossj.org/downloads/design—guidelines.shtml. |
Gessford, J.E.; “Object-Oriented System Design”; Emerging Information Technologies for Competitive Advantage and Economic Development; Proceedings of the 1992 Information Resources Management Association International Conference; 1992; pp. 110-118. |
Kozacynski, W.; “Architecture Framework for Business Components”; Software Reuse 1998 Proceedings; Fifth International Conferences on Victoria, BC, Canada; Jun. 1998; IEEE Comput. Soc; pp. 300-307. |
Kythe, D.K.; “The Promise of Distributed Business Components”; Bell Labs Technical Journal; vol. 75, No. 2; Mar./Apr. 1999; pp. 20-28. |
Linthicum, D.S.; “Chapter 9: RPCs, Messaging, and B2B Application Integration”; B2B Application Integration: E-Business Enable Your Enterprise; 2001; pp. 167-181. |
Ravichandran, T.; “Special Issue on Component-Based Software Development”; The Data Base for Advances in Information Systems; 2003; pp. 45-46. |
Schmid, H.A.; “Business Entity Components and Buisness Process Components”; Joop; vol. 12, No. 6; Oct. 1999; pp. 6-10, 12-15. |
Singh, I. et al.; “Designing Enterprise Applications with the J2EE Platform, Second Edition”; Jun. 15, 2002. |
Stojanovic, Z. et al.; “Modeling and Design of Service-Oriented Architecture”; Systems, Man and Cybernetics; 2004 IEEE International Conference on the Hague, The Netherlands; Oct. 2004; IEEE, vol. 5; pp. 4147-4152. |
Thomas, A.; “Enterprise JavaBeans Server Component Model for Java”; [online]; Dec. 1997; http://www.cs.indiana.edu/classes/b649-gann/ejb-white-paper.pdf. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012625; Apr. 3, 2007; 8 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012625; Jul. 1, 2008; 7 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012614; Mar. 16, 2007; 7 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/US2006/012614; Jul. 1, 2008; 6 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012618; Apr. 3, 2007; 8 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012618; Jul. 1, 2008; 7 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012613; May 3, 2007; 6 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012613; Jul. 1, 2008; 6 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012624; Mar. 30, 2007; 9 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012624; Jul. 1, 2008; 8 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012623; May 7, 2007; 8 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012623; Jul. 1, 2008; 7 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012620; Jul. 1, 2008; 6 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012619; Apr. 19, 2007; 8 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012619; Jul. 1, 2008; 7 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2006/012621; Apr. 19, 2007; 8 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2006/012621; Jul. 1, 2008; 7 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2007/002835; Aug. 9, 2007; 12 pages. |
International Preliminary Report on Patentability issued in International Application No. PCT/EP2007/002835; Sep. 30, 2008; 8 pages. |
Communication Pursuant to Article 94(3) EPC issued in European Application No. 06841224.6; May 15, 2009; 8 pages. |
Communication Pursuant to Article 94(3) EPC issued in European Application No. 06847009.5; May 15, 2009; 10 pages. |
Communication Pursuant to Article 94(3) EPC issued in European Application No. 07007130.3; Dec. 5, 2008; 6 pages. |
Extended European Search Report issued in European Application No. 07007130.3; Oct. 5, 2007; 6 pages. |
Office Action issued in U.S. Appl. No. 11/323,041; Apr. 30, 2009; 25 pages. |
Office Action issued in U.S. Appl. No. 11/322,612; May 11, 2009; 23 pages. |
Office Action issued in U.S. Appl. No. 11/322,772; Mar. 25, 2009; 12 pages. |
Office Action issued in U.S. Appl. No. 11/323,590; Jan. 9, 2009; 23 pages. |
Office Action issued in U.S. Appl. No. 11/396,288; Jan. 2, 2009; 26 pages. |
Office Action issued in U.S. Appl. No. 11/396,288; Apr. 15, 2008; 26 pages. |
Cowan, D.D. et al.: “Application Integration: Constructing Composite Applications from Interactive Components”, Software Practice & Experience, Wiley & Sons, Bognor Regis, GB, vol. 23, No. 3 (Mar. 1993), pp. 255-275. |
Nori A. K. et al.: “Composite Applications: Process Based Application Development”, Lecture Notes in Computer Science, Springer Verlag, Berlin, DE, vol. 2444 (Aug. 2003), pp. 48-53. |
SAP AG: “Designing Cross Solutions” SAP XAPPS, [online], Sep. 2003, pp. 1-2 [retrieved on Jul. 7, 2007]. Retrieved from the Internet: <URL: http://www.sap.com/beluxiplatform/netweaver/pdf/BWP—CAF.pdf>. |
Vergil Technology Ltd. “Vergil Composite Application Builder Suite” Product Datasheet, [online] 2003, pp. 1-5 [retrieved on Jul. 23, 2007]. Retrieved from the Internet: <URL: http://www.webservicesmall.com/docs/VCAB—datasheet.pdf>. |
Woods, D., “Packaged Composite Applications: A Liberating Force for the User Interface”, Internet Citation, [online], Oct. 2003, 4 pages [retrieved on Oct. 17, 2005]. Retrieved from the Internet: <URL:http://www.sapdesignguild.org/editions/edition7/print—composite—applications.asp>. |
Pilhofer, F., “Writing and Using CORBA Components”, 17 pages [online] Apr. 2002 [retrieved on Feb. 28, 2007]. Retrieved from the Internet: <URL:http://www.fpx.de/MicoCCM/download/mico-ccm.pdf>. |
SAP AG, International Search Report of PCT/EP2006/012620 filed Dec. 29, 2006. |
Sharifi, M. et al., “CORBA Components Collocation Optimization Enhanced with Local ORB- Like Services Support”, On the Move to Meaningful Internet Systems, (2004): COOPIS, ODA and ODBASE. OTM Confederated Conferences COOPIS, DOA and ODBASE 2004. Proceedings Part II (Lecture Notes in Computer Science vol. 3291), Springer-Verlag, Berlin, Germany (2004), pp. 1143-1154. |
“American Software Announces ASP Pricing Model for It's a-Applications Expense Business Solution”; PR Newswire; Mar. 6, 2000; 2 pages. |
Anon.; “Sequent Corp Bell Atlantic: Bell Atlantic Selects Sequent for Video-on-Demand Program; Sequent Moves to Sieze Opportunity in New Market”; Business Wire; Dec. 6, 1994. |
Anon.; “State of the Art Reports 13,000 MAS 90 for Windows Shipments in First Nine Months of Availability”; PR Newswire; Apr. 28, 1997. |
Avanquest's Bookkeeper 2007 Provides All-in-One Solution for Small Business Accounting and Financial Management; New Version of Popular Software Enables Detailed Report Creation and In-House Payroll Processing; PR Newswire; New York; Oct. 3, 2006. |
Avery, S.; “Buyers' Guide to Software for Purchasing 2000.(Directory)”; Purchasing, vol. 129, No. 1; p. 179; Jul. 13, 2000. |
Bastani et al.; “Complex Open System Design by Quasi Agents: Process Oriented Modeling in Agent Based Systems”; ACM SIGSOFT; vol. 34, No. 4; 2009; pp. 1-14. |
Bastani et al.; “Process Oriented Abstraction of the Complex Evolvable Systems: Problem Model Construction”; ACM SIGSOFT; vol. 33, No. 3; 2008; pp. 1-13. |
“Cendant Announces Comprehensive Online Travel Booking to Meet President Bush's eTravel Initiative”; PR Newswire; Jul. 9, 2002; 3 pages. |
Chen, M. and Meixell, M.; “Web Services Enabled Procurement in the Extended Enterprise: An Architectural Design and Implementation”; Journal of Electronic Commerce Research, vol. 4, No. 4; 2003; pp. 140-155. |
Duc et al.; “Uniform Object Modeling Methodology and Reuse of Real Time System Using UML”; EMSOFT '05; Sep. 19-22, 2005; pp. 44-47. |
Gomaa et al.; “Model Based Software Design and Adaption”; International Workshop on Software Engineering for Adaptive and Self-Managing Systems (SEAMS '07); IEEE; 2007; 10 pages. |
Huang, S. et al.; “Computer-Assisted Supply Chain Configuration Based on Supply Chain Operations Reference (SCOR) Model”; Computers & Industrial Engineering 48; 2005; pp. 377-394. |
“Hudson's Bay Company Realizes Fast ROI with the Oracle E-Business Suite”; PR Newswire; New York; Jan. 15, 2002; p. 1. |
Intuit Canada Ltd.; “Startup Guide—QuickBooks Basic for Windows, QuickBooks Pro for Windows, QuickBooks Premier for Windows”; 2002; 230 pages. |
Lambert et al.; “Supply Chain Metrics”; International Journal of Logistics Management; vol. 12, No. 1; 2001; pp. 1-19. |
Lockamy III, et al.; “Linking SCOR Planning Practices to Supply Chain Performance”; International Journal of Operationgs & Production Management; vol. 24, No. 12; pp. 1192-1218. |
mySAP™ ERP 2005; Downloaded Mar. 24, 2010 from <http://web.archive.org/web/20061104021205/www.sap.com/solutions/business-suite/erp/pdf/BWP—mySAP—ERP—2005.pdf>; 60 pages. |
“Oracle Expands E-Commerce Offerings with the Acquisition of E-Travel, Inc.”; PR Newswire; Mar. 9, 1999; 3 pages. |
Ouyang et al.; “From Business Process Models to Process Oriented Software Systems”; ACM Transactions on Software Engineering and Methodology; vol. 19, No. 1, Article 2; Aug. 2009; pp. 1-37. |
Rossi et al.; “Designing and Architecturing Process-aware Web Applications with EPML”; SAC '08; Mar. 16-20, 2008; pp. 2409-2414. |
“SAP Delivers Next-generation ERP to Customers”; PR Newswire; New York; Mar. 10, 2005; 7 pages. |
Schultz: G.J.; “Keeping SCOR on Your Supply Chain: Basic Operations Reference Model Updates with the Times”; Information Strategy: The Executive's Journal; Summer 2003; pp. 12-20. |
Stephens, S.; “Supply Chain Council & Supply Chain Operations Reference (SCOR) Model Overview”; <http://www.supply-chain.org>; Version 5.0a; Aug. 2001; 29 pages. |
Stephens, S.; “Supply Chain Operatives Reference Model Version 5.0: A New Tool to Improve Supply Chain Efficiency and Achieve Best Practice”; Information Systems Frontiers 3:4, 2001; pp. 471-476. |
“Time Management with mySAP™ ERP Human Capital Management”; Downloaded Mar. 24, 2010 from <http://web.archive.org/web/20060105084834/www.sap.com/solutions/business-suite/erp/hcm/pdf/HCM—Time—Management.pdf>; 4 pages. |
Vogel et al.; “mySAP ERP for Dummies”; Published on Sep. 30, 2005; Downloaded on Mar. 23, 2001 from <http://proquest.safaribooksonline.com/9780764599958> 41 pages. |
International Search Report and Written Opinion of the International Searching Authority issued in International Application No. PCT/EP2007/002841; Aug. 16, 2007; 12 pages. |
International Preliminary Report on Patentability under Chapter I issued in International Application No. PCT/EP2007/002841; Sep. 30, 2008; 8 pages. |
Office Action issued in U.S. Appl. No. 11/396,312 on Mar. 30, 2010; 23 pages. |
Office Action issued in U.S. Appl. No. 11/322,611 on Mar. 31, 2010; 17 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,610 on Mar. 1, 2010; 12 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,610 on Jun. 14, 2010; 6 pages. |
Office Action issued in U.S. Appl. No. 11/322,772; Dec. 9, 2009; 14 pages. |
Office Action issued in U.S. Appl. No. 11/322,772; Jul. 12, 2010; 18 pages. |
Office Action issued in U.S. Appl. No. 11/322,398 on Apr. 2, 2010; 39 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,398 on Jul. 23, 2010; 38 pages. |
Office Action issued in U.S. Appl. No. 11/322,383; Nov. 12, 2009; 29 pages. |
Office Action issued in U.S. Appl. No. 11/322,383; May 12, 2010; 23 pages. |
Office Action issued in U.S. Appl. No. 11/322,382 on Mar. 29, 2010; 28 pages. |
Office Action issued in U.S. Appl. No. 11/323,041 on Mar. 19, 2010; 26 pages. |
Advisory Action issued in U.S. Appl. No. 11/323,041 on Jun. 7, 2010; 3 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Mar. 29, 2010; 19 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Jul. 6, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,288; May 20, 2010; 15 pages. |
Office Action issued in U.S. Appl. No. 11/396,288; Aug. 19, 2009; 20 pages. |
Office Action issued in U.S. Appl. No. 11/396,258; Nov. 25, 2009; 9 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,258 on Mar. 31, 2010; 9 pages. |
Supplemental Notice of Allowance issued in U.S. Appl. No. 11/396,258 on May 19, 2010; 8 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,258 on Jul. 28, 2010; 9 pages. |
Office Action issued in U.S. Appl. No. 11/396,236 on Mar. 31, 2010; 20 pages. |
Office Action issued in U.S. Appl. No. 11/323,039; Sep. 4, 2009; 36 pages. |
Office Action issued in U.S. Appl. No. 11/323,039; Apr. 14, 2010; 15 pages. |
Office Action issued in U.S. Appl. No. 11/322,845; Jul. 15, 2010; 16 pages. |
Office Action issued in U.S. Appl. No. 11/323,040; Jul. 24, 2009; 35 pages. |
Office Action issued in U.S. Appl. No. 11/323,040; Apr. 29, 2010; 17 pages. |
Office Action issued in U.S. Appl. No. 11/322,612; Apr. 1, 2010; 23 pages. |
Advisory Action issued in U.S. Appl. No. 11/322,612; Jun. 24, 2010; 3 pages. |
Office Action issued in U.S. Appl. No. 11/397,026; Jul. 21, 2009; 28 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Mar. 29, 2010; 17 pages. |
Supplemental Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Jul. 9, 2010; 4 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Jul. 26, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,554 on May 14, 2010; 11 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,534 on Jun. 24, 2010; 15 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,354 on Jun. 25, 2010; 16 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/967,865 on Mar. 31, 2010; 16 pages. |
Office Action issued in U.S. Appl. No. 11/322,482; Jan. 7, 2010; 19 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,482; Jul. 13, 2010; 5 pages |
Office Action issued in U.S. Appl. No. 11/323,590; Jul. 10, 2009; 32 pages. |
Office Action issued in U.S. Appl. No. 11/323,590; Dec. 30, 2009; 31 pages. |
Office Action issued in U.S. Appl. No. 11/323,590; Jun. 21, 2010; 25 pages. |
Office Action issued in U.S. Appl. No. 11/323,634; Sep. 10, 2009; 15 pages. |
Office Action issued in U.S. Appl. No. 11/323,634; Apr. 2, 2010; 9 pages. |
Office Action issued in U.S. Appl. No. 11/322,816; Jul. 23, 2009; 41 pages. |
Office Action issued in U.S. Appl. No. 11/322,816; Apr. 15, 2010; 27 pages. |
Office Action issued in U.S. Appl. No. 11/396,327 on Apr. 1, 2010; 26 pages. |
Office Action issued in U.S. Appl. No. 12/333,085; Jun. 25, 2009; 9 pages. |
Office Action issued in U.S. Appl. No. 12/333,085; Mar. 23, 2010; 5 pages. |
Bin et al.; “Component Model Optimization for Distributed Real-Time Embedded Software”; IEEE International Conference on Systems, Man and Cybernetics; Oct. 13, 2004; 6 pages. |
Cascallar, Eduardo et al.; “Assessment in the Evaluation of Self-Regulation as a Process”; Educational Psychology Review; vol. 18, No. 3; Sep. 2006; pp. 297-306. |
Cohen; “Optimizer: IBM's Multi-Echelon Inventory System for Managing Service Logistics Interfaces”; vol. 20, No. 1; 1990; pp. 65-82. |
Cohen et al.; “Saturn's Supply-Chain Innovation: High Value in After Sales Service”; Sloan Management Review; vol. 41, No. 4; 2000; pp. 93-101. |
Cool, David W.; “Activity Fund Accounting”; School Business Affairs; vol. 49, No. 6; Jun. 1983; pp. 50-52. |
Cox et al.; “A Formal Model for Component Based Software”; IEEE; Aug. 7, 2002; 8 pages. |
Ferscha et al.; “A Light-Weight Component Model for Peer-to-Peer Applications”; IEEE; Mar. 23, 2004. |
Finin et al.; “KQML as an Agent Communication Language”; retrieved on Jul. 26, 2011; pp. 456-463. <http://portal.acm.org/citation.cfm?id=191322>. |
Flissi et al.; “A Component-based Software Infrastructure for Ubiquitous Computing”; IEEE; Jul. 4, 2005. |
Gould; “Integrating the Manufacturing Enterprise”; Automative Design & Production; 119, 1; ABI/INFORM Global; Jan. 2007; 3 pages. |
Jennings et al.; “Autonomous Agents for Business Process Management”; 2000 Applied Artificial Intelligence; retrieved on Jul. 25, 2011; pp. 145-189. <http:.//citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.58.624&rep=repl<ype=pdf>. |
Kalakota et al.; “Readings in Electronic Commerce”; Addison-Wesley Longman, Inc.; 1995; ISBN: 0-201-88060-1. |
Orsburn; “Spares Management Handbook”; McGrawHill; 1991; ISBN: 0/8306-7626-0. |
Papazoglou et al; “Service-Oriented Computing Research Road Map”; http://infolab.uvt.nl/pub/papazogloump-2006-96.pdf; Mar. 1, 2006; 29 pages. |
SAP AG; “SAP NetWeaver Visual Composer: User Guide (SAP NetWeaver Visual Composer release 6.0)”; Document version 1.1; 2004; pp. 1-208. |
SAP AG; “Powered by SAP NetWeaver Partner Program—Frequently Asked Questions”; May 2005; 10 pages [online] http://www.lionbridge.com/NR/rdonlyres/4940BE1F/DA46/412E/AB16/F049BD865CA1/0/PBMW FAQ—50070686—en.pdf. |
Strelich, Thomas P. et al.; “Simulation-Based Transformation with the Service Integration/Interoperation Infrastructure”; Technology Review Journal; Fall/Winter 2005; pp. 99-115. |
Notice of Allowance issued in U.S. Appl. No. 12/233,554 on Sep. 17, 2010; 10 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,554 on Feb. 22, 2011; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,554 on Jun. 27, 2011; 7 pages. |
Office Action issued in U.S. Appl. No. 12/233,550 on Jan. 12, 2011; 29 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,550 on May 11, 2011; 20 pages. |
Office Action issued in U.S. Appl. No. 12/333,146 on Sep. 6, 2011; 21 pages. |
Office Action issued in U.S. Appl. No. 11/323,634 on Apr. 29, 2011; 8 pages. |
Office Action issued in U.S. Appl. No. 11/322,973 on Dec. 7, 2010; 13 pages. |
Office Action issued in U.S. Appl. No. 11/322,973 on May 27, 2011; 15 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,327 on Nov. 30, 2010; 28 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,327 on Sep. 28, 2011; 31 pages. |
Office Action issued in U.S. Appl. No. 11/404,147 on Nov. 24, 2010; 27 pages. |
Office Action issued in U.S. Appl. No. 11/404,147 on Aug. 4, 2011; 26 pages. |
Office Action issued in U.S. Appl. No. 12/233,479 on Oct. 27, 2011; 24 pages. |
Office Action issued in U.S. Appl. No. 12/332,965 on Oct. 11, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,462 on Feb. 2, 2011; 11 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,462 on May 18, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,462 on Sep. 2, 2011; 7 pages. |
Office Action issued in U.S. Appl. No. 12/233,289 on Oct. 27, 2011; 15 pages. |
Office Action issued in U.S. Appl. No. 12/233,457 on May 26, 2011; 19 pages. |
Office Action issued in U.S. Appl. No. 11/967,483 on Aug. 20, 2010; 10 pages. |
Office Action issued in U.S. Appl. No. 11/967, 483 on Mar. 4, 2011; 6 pages. |
Office Action issued in U.S. Appl. No. 12/327,232 on May 26, 2011; 20 pages. |
Office Action issued in U.S. Appl. No. 12/327,590 on Jun. 23, 2011; 16 pages. |
Office Action issued in U.S. Appl. No. 12/327,701 on Nov. 8, 2011; 20 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/333,085; Sep. 13, 2010; 8 pages. |
Office Action issued in U.S. Appl. No. 12/233,087 on Aug. 18, 2011; 42 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,534 on Oct. 20, 2010; 15 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,534 on Jan. 31, 2011; 15 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,534 on May 16, 2011; 12 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,382 on Sep. 20, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,382 on Jan. 6, 2011; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,382 on Jul. 25, 2011; 5 pages. |
Office Action issued in U.S. Appl. No. 11/396,312 on Sep. 10, 2010; 23 pages. |
Office Action issued in U.S. Appl. No. 11/322,611 on Sep. 16, 2010; 21 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,610 on Sep. 23, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,610 on Dec. 22, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,610 on Mar. 31, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,398 on Oct. 29, 2010; 18 pages. |
Notice of Allowanced issued in U.S. Appl. No. 11/322,398 on Nov. 15, 2010; 20 pages. |
Notice of Allowanced issued in U.S. Appl. No. 11/322,398 on May 27, 2011; 21 pages. |
Office Action issued in U.S. Appl. No. 11/322,383 on May 12, 2010; 23 pages. |
Office Action issued in U.S. Appl. No. 11/322,383 on Nov. 12, 2009; 23 pages. |
Office Action issued in U.S. Appl. No. 11/396,236 on Oct. 28, 2010; 19 pages. |
Examiner's Answer to Appeal Brief issued in U.S. Appl. No. 11/396,236 on Nov. 10, 2011; 19 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Oct. 15, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Jan. 20, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Aug. 5, 2011; 7 pages. |
Office Action issued in U.S. Appl. No. 11/396,288 on Oct. 17, 2011; 38 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,288; Dec. 28, 2010; 4 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,288; Sep. 24, 2010; 4 pages. |
Office Action issued in U.S. Appl. No. 11/396,250 on Oct. 18, 2010; 15 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,250 on Mar. 2, 2011; 13 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,250 on Jun. 24, 2011; 5 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,258 on Nov. 16, 2010; 8 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,258 on Jun. 28, 2011; 9 pages. |
Office Action issued in U.S. Appl. No. 11/396,252 on Nov. 10, 2011; 18 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,845; Dec. 27, 2010; 16 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,845; Apr. 8, 2011; 8 pages. |
Office Action issued in U.S. Appl. No. 11/323,040 on Nov. 5, 2010; 33 pages. |
Office Action issued in U.S. Appl. No. 11/323,040 on Jul. 26, 2011; 34 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Nov. 15, 2010; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Mar. 3, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Jul. 20, 2011; 8 pages. |
Office Action issued in U.S. Appl. No. 12/233,417 on Apr. 7, 2011; 32 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,417 on Sep. 14, 2011; 11 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/968,054 on Sep. 7, 2010; 11 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/968,054 on Aug. 2, 2011; 5 pages. |
Office Action issued in U.S. Appl. No. 12/233,530 on Apr. 29, 2011; 11 pages. |
Office Action issued in U.S. Appl. No. 11/967,405 on Apr. 27, 2011; 15 pages. |
Office Action issued in U.S. Appl. No. 12/233,458 on Oct. 12, 2011; 19 pages. |
Office Action issued in U.S. Appl. No. 12/233,557 on Sep. 16, 2010; 16 pages. |
Office Action issued in U.S. Appl. No. 11/967,489 on Sep. 28, 2011; 7 pages. |
Office Action issued in U.S. Appl. No. 12/233,557 on Mar. 4, 2011; 19 pages. |
Office Action issued in U.S. Appl. No. 12/233,489 on May 13, 2011; 15 pages. |
Office Action issued in U.S. Appl. No. 11/967,393 on Apr. 15, 2011; 12 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,354 on Oct. 18, 2010; 16 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,354 on Feb. 1, 2011; 16 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,354 on Aug. 9, 2011; 13 pages. |
Office Action issued in U.S. Appl. No. 11/967,387 on Sep. 8, 2011; 14 pages. |
Office Action issued in U.S. Appl. No. 12/233,075 on Aug. 4, 2011; 45 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/967,865 on Oct. 6, 2010; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/967,865 on Jun. 24, 2011; 8 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/967,890 on Jul. 15, 2011; 7 pages. |
Anonymous; “Mastering Management”; Motor Age, vol. 25, No. 10; Oct. 2006; pp. 1-3. |
Gerin et al.; “Flexible and Executable Hardware/Software Interface Modeling for Multiprocessor SOC Design Using SystemC”; IEEE; 2007; pp. 390-395. |
Hahn; “A Domain Specific Modeling Language for Multi-Agent Systems”; ACM AAMAS; 2008; pp. 233-240. |
Hu; “A Co-Design Modeling Approach for Computer Network Systems”; IEEE; 2007; pp. 685-693. |
“IDe Partners with Journyx to Offer Customers Best-in-Class Time Management Solution”; PR Newswire; Mar. 8, 2005; Business Dateline. |
Kremic, Tibor; “Outsourcing Decision Support: A Survey of Benefits, Risks, and Decision Factor”; Supply Chain Management; V. 11; 2006; pp. 467-482. |
Meseroll, Robert; “Data Mining Navy Flight”; IEEE Autotestcom 2007; Sep. 2007; pp. 476-481. |
Sarjoughian et al.; “CoSMOs: A Visual Environment for Component Based Modeling, Experimental Design and Simulation”; ACM; 2009; pp. 1-9. |
“Trakware Systems Inc. Expands Management Team: Leading To-Order Software Provider Adds Experienced Global VP Sales and Marketing to its World-Class Team”; Canada NewsWire; Apr. 9, 2008. |
Trappey, Amy; “Design and Analysis of a Rule Based Knowledge”; International Journal of Manufacturing Tech; Dec. 2007; 35,3-4:385-93. |
Notice of Allowance issued in U.S. Appl. No. 12/233,550 on Jan. 9, 2012; 11 pages. |
Office Action issued in U.S. Appl. No. 12/333,146 on Feb. 2, 2012; 21 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/323,634 on Jan. 25, 2012; 5 pages. |
Notice of Allowance in U.S. Appl. No. 12/233,462 on Dec. 12, 2011; 6 pages. |
Notice of Allowance in U.S. Appl. No. 12/233,462 on Apr. 5, 2012; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,289 on Feb. 15, 2012; 11 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,457 on Nov. 3, 2011; 12 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,232 on Nov. 2, 2011; 16 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,590 on Dec. 28, 2011; 10 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/327,701 on Apr. 6, 2012; 9 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,087 on Mar. 30, 2012; 30 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,534 won Dec. 28, 2011; 7 pages. |
Notice of Allowanced issued in U.S. Appl. No. 11/322,398 on Oct. 18, 2011; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,259 on Mar. 15, 2012; 7 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,250 on Dec. 7, 2011; 6 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/396,258 on Feb. 3, 2012; 12 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/322,845; Nov. 13, 2011; 9 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Nov. 4, 2011; 8 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/397,026 on Feb. 23, 2012; 8 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,520 on Nov. 10, 2011; 22 pages. |
Office Action issued in U.S. Appl. No. 11/967,489 on Feb. 6, 2012; 9 pages. |
Notice of Allowance issued in U.S. Appl. No. 11/967,393 on Nov. 9, 2011; 9 pages. |
Office Action issued in U.S. Appl. No. 11/967,387 on Apr. 12, 2012; 13 pages. |
Office Action issued in U.S. Appl. No. 12/327,737 on Mar. 26, 2012; 14 pages. |
Notice of Allowance issued in U.S. Appl. No. 12/233,075 on Mar. 22, 2012; 25 pages. |
Number | Date | Country | |
---|---|---|---|
20070162893 A1 | Jul 2007 | US |