Apparatus and method for third party creation of control logic

Information

  • Patent Grant
  • 10216166
  • Patent Number
    10,216,166
  • Date Filed
    Friday, June 29, 2012
    12 years ago
  • Date Issued
    Tuesday, February 26, 2019
    5 years ago
Abstract
Third party developed control logic for automation controllers is provided to customers using a communication network. At least one tool is provided for a third party to develop control logic for an automation controller. The automation controller is remotely located from the communication network. A hardware platform on which to operate the control logic is selected. Once built, the control logic is linked to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform.
Description
CROSS REFERENCES TO RELATED APPLICATIONS

This application claims priority to U.S. Provisional Application Ser. No. 61/583,956, filed on Jan. 6, 2012, the contents of which are incorporated herein by reference in its entirety.


PCT International application no. PCT/US2012/044766, entitled “Method and Apparatus for Network Based Testing”;


PCT International application no. PCT/US2012/044759, entitled “Apparatus and Method for Synchronization of Control Logic”; and,


PCT International application no. PCT/US2012/044767, entitled “Apparatus and Method for Creating and Presenting Control Logic”;


are being filed on the same date as the present application, the contents of which are incorporated herein by reference in their entireties.


BACKGROUND OF THE INVENTION

1. Field of the Invention


The subject matter disclosed herein relates to the creation of control logic by third parties.


2. Brief Description of the Related Art


Automated devices perform various functions and these devices typically include a controller or control device that controls or manages the execution of these functions. For example, robotic controllers (e.g., those that utilize microprocessors) often control the functions of a robot and the robot can perform various manufacturing tasks. Assembly line controllers are used to control the various functions performed on or at an assembly line. A consumer device controller may be used to control the operation and functioning of any type of consumer device (e.g., a washer, dryer, dishwasher, building security system, building lighting system, building heating system, or microwave oven). Together, these types of controllers provide automated functions and are generally referred to as automation controllers.


An automation controller typically includes and utilizes control logic to perform its functions. Control logic may include computer software and/or computer hardware that performs various predetermined functions. For example, an assembly line controller (e.g., for a bottling plant) may include a microprocessor that operates programmed computer software to regulate the speed and other functions associated with operating an assembly line that fills and caps the bottles. In another example, a controller may also include a microprocessor running programmed computer software that regulates various device parameters (e.g., temperature, pressure, or operating speed). In yet another example, a water system controller may include control logic that controls pumps and sprinklers.


Conventionally, when a customer such as a factory owner wishes to have control logic built or changed they generally approach a known control logic provider. Moreover, the customer may have to approach multiple control logic providers if they want to obtain multiple quotes for the control logic they desire to obtain. This process proves time-consuming, tedious, and burdensome for customers. Additionally, third party providers generally have no easy way of knowing whether their solution is the type of solution desired by a larger group of customers. Consequently, features that may have been of interest to multiple consumers are not evaluated or included in the control logic, thereby further increasing the cost of the finished product.


BRIEF DESCRIPTION OF THE INVENTION

Embodiments of the present invention provide third party developed control logic for automation controllers that is accessible to customers using a communication network. At least one tool is provided for a third party to develop control logic for an automation controller. The automation controller is remotely located from the communication network. A hardware platform on which to operate the control logic is selected. Once built, the control logic is linked to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform.


In some aspects, the control logic developed by the third party is not limited to integration on a single type of hardware platform. In other aspects, the linking is performed at or shortly before the integration of the control logic to the selected hardware platform.


In other examples, testing and validating of the control logic is performed at the communication network. In still other examples, at the communication network, results of the testing and the validating of the control logic are analyzed according to a predetermined criteria. In some approaches, when the predetermined criteria is satisfied, the control logic is released to a network-based web store at the communication network. The control logic may then be selectively released for sale or use to one or more potential customers. Alternatively, not all control logic may be released for sale and some control logic may be given for free to some customers. In other aspects, a purchase order for the control logic is received from the potential customer. In other aspects, a third party could monitor control logic sales forums and notice a need for control logic having certain features. In this case, the third party could decide to develop the control logic themselves.


Testing may be accomplished in different ways. For instance, the testing may be automatically accomplished without manual intervention. Alternatively, the testing may be at least partially manually accomplished. In yet another aspect, the testing and validating of the control logic may be performed at a third party testing platform.


In other aspects, an apparatus for providing third party developed control logic for automation controllers to customers using a communication network includes an interface and a processor. The interface has an input and an output.


The processor is coupled to the interface and is configured to provide at least one tool for a third party to develop control logic for an automation controller at the output of the interface. The automation controller is remotely located from the communication network. The processor is further configured to select a hardware platform on which to operate the control logic. The processor is still further configured to link the control logic to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform.





BRIEF DESCRIPTION OF THE DRAWINGS

For a more complete understanding of the disclosure, reference should be made to the following detailed description and accompanying drawings wherein:



FIG. 1 comprises a block diagram of a communication network that facilitates the third party provision of control logic according to various embodiments of the present invention;



FIG. 2 comprises a flow chart showing an approach for the provision of control logic using a third party according to various embodiments of the present invention;



FIG. 3 comprises a block diagram of a tool kit according to various embodiments of the present invention;



FIG. 4 comprises a block diagram of a network controller that is used to build control logic according to various embodiments of the present invention; and



FIG. 5 comprises a block diagram of an automation controller according to various embodiments of the present invention.





Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity. It will further be appreciated that certain actions and/or steps may be described or depicted in a particular order of occurrence while those skilled in the art will understand that such specificity with respect to sequence is not actually required. It will also be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein.


DETAILED DESCRIPTION OF THE INVENTION

In the approaches described herein, third parties create control logic that is made available to one or more customers. Third parties include, for example, entities or developers that do not directly deploy the logic in their business, i.e., the third party develops the control logic for the use of another individual or entity. In one instance, a third party is a software developer that develops software for factory owners, i.e., the third party is not the factory owner. A customer may also transmit an order to a communication platform at a communication network where the order is presented to third party providers. Interested third party providers bid for the opportunity to create the control logic and one of the bidders is selected. After the control logic is built, it may be presented to other customers for purchase.


Additionally, third party providers may view or examine the configuration or design of already released control logic that is presented to others who may be interested in obtaining the control logic. In so doing, one technical effect is that these third party providers may consider actual marketplace factors used in control logic design and tailor the production of their own control logic in consideration of these factors, thereby reducing the cost of control logic and better fitting the needs of more consumers.


There are various advantages to the approaches described herein. For example, one technical effect is that customers can also order control logic with a minimum amount of effort using the approaches described herein. In addition, another technical effect is that various control logic solutions can be displayed to large groups of potential consumers thereby increasing the purchasing options available to these consumers.


Referring now to FIG. 1, a system for the creation and presentation of control logic is described. The system includes a communication network 102. The communication network 102 is coupled to a customer site 120. The coupling provides a communication link and may be accomplished using any approach, e.g., wired or wireless connections. The customer site 120 includes an automation controller 122 and a customer interface 124 (e.g., a personal computer). The customer site 120 may be any factory, office, home, consumer device, power plant, communication facility (e.g., a base station) or any other location that may advantageously use an automation controller.


The communication network 102 is any type of communication network such as the Internet, a computer network, a cellular telephone network or any combination of these or other networks. In this respect, the communication network 102 may include any number of devices such as computers, access points, routers, and servers, to mention a few examples.


The communication network 102 includes a memory 104, an access interface 106, and a web store 108. The access interface 106 is any combination of hardware and/or software that receives commands from the interface 124. The web store 108 is any combination of hardware and/or software that provides an accessible platform for control logic to be displayed and purchased. For example, the web site 108 may be implemented on a server and present/receive information in any form of known web sites that operate on the Internet.


The memory 104 (which can be any type of memory device or combination of memory devices) includes a control logic (representation) 112 and a library 114 with modules 116 and 118. The memory 104 as well as the other element of the communication network 102 may physically reside on any type of device or devices such as servers, access points, computers, or routers. It will be appreciated that control logic 112 may be eventually downloaded to particular automation controllers. Thus, the copy of the control logic copy stored at the network 102 can be considered a representation of the control logic at the automation controllers.


As mentioned, the library 114 includes modules 116 and 118. Alternatively, a third party can create the entire control logic 112 (without the modules 116 and 118). In other aspects, the third party can create pieces of different types of logic (e.g., the same type of control logic for different automation controllers or different types of control logic for the same automation controller).


The control logic 112 is a description or model (in one example, implemented as programmed computer software or code) that represents or mirrors the control logic at the automation controller 122. More specifically, the control logic 112 describes the functions, workings, operation, inputs, outputs, and other characteristics of the operation of the associated control logic of the automation controller 122. In other aspects, the control logic 112 may be hardware, software, or combinations of hardware and software elements. In one aspect, the control logic (representation) 112 is the same as the control logic at the automation controller. Consequently, changes can be made to the control logic 112 without halting the operation of the automation controller 122. These changes can be later downloaded to the automation controller 122.


The control logic 112 utilizes modules 116 and 118 from the library 114. In this example, the modules 116 and 118 are programmed software modules that perform specified functions. Although only two modules 116 and 118 are shown, it will be appreciated that any number of modules may be used. Further, it will be understood that different control logic representations may utilize (share) the same module or modules.


Automation controller 122 may be any device, combination of devices, or network of devices that are implemented in any combination of hardware or software. In one example, the automation controller 122 is an assembly line controller. In other examples, the automation controller 122 is a controller for a pumping network (e.g., pumps, valves, pipes, sprinklers, and their associated controllers). Other applications of automation controllers and systems that utilize automation controllers are possible.


The interface 124 is any type of interface device that interacts with a human such as a personal computer, a laptop, a cellular telephone, or a personal digital assistant. Other examples of interfaces are possible.


The communication network 102 also includes a test module 130, a validation module 132, and a release module 134. The test module 130 performs tests of the control logic 112 (e.g., to ensure that it operates properly). The validation module 132 performs validation procedures for the control logic 112 (e.g., to ensure the control logic meets customer or third party quality requirements). The release module 134 releases the control logic 112 for viewing and potential purchase by third parties and to the customer that ordered the control logic. A tool 136 includes information that allows a third party 138 to build control logic. A third party testing platform 140 may in some instances be used to test control logic instead of at the communication network 102. The third party issues build commands to build the control logic 112 that is stored at the memory 104. This control logic 112 if purchased by a customer may be downloaded to their automation controller 122 by any appropriate communication link (e.g., wired, wireless, or the Internet).


In one example of the operation of the system of FIG. 1, third party developed control logic for automation controllers is provided to customers utilizing a communication network. A tool 136 is provided for the third party 138 to develop control logic for the automation controller 122 when the owner of the automation controller 122 places an order for the control logic. The automation controller 122 is remotely located from the communication network 102. A hardware platform on which to operate the control logic 112 is selected. For instance, a particular microprocessor model or programmed logic controller (PLC) model is selected. Alternatively, not all logic may be for sale and some may be released for free to some customers. The control logic 112 is linked to at least one operational characteristic of the hardware platform (e.g., processor type, operational speed, input/output configuration) such that the control logic 112 is operable to perform at least one predetermined function of the automation controller using the hardware platform.


In some aspects, the control logic 112 developed by the third party 138 is not limited to integration on a single type of hardware platform. In other aspects, the linking is performed at or shortly before the integration of the control logic to the selected hardware platform (e.g., within hours or minutes before integration).


In other examples, testing and validating is performed of the control logic at the communication network 102, for instance by the modules 130 and 132. In still other examples, at the communication network 102, results of the testing and the validating of the control logic are analyzed according to a predetermined criteria. In some approaches, when the predetermined criteria is satisfied, the control logic 112 is released to a network-based web store 108 at the communication network 102. The control logic 112 may then be released to at least one potential customer. In other aspects, a purchase order for the control logic is received from the potential customer (e.g., via interface 124) and installation of the control logic 112 is facilitated at an automation controller 122 of the potential customer.


Testing may be accomplished in different ways. For instance, the testing is automatically accomplished without manual intervention. Alternatively, the testing may be at least partially manually accomplished. In another aspect, the testing and validating of the control logic may be performed at the third party testing platform 140.


Referring now to FIG. 2, one example of an approach for the provision of control logic using a third party is described. At step 202, a tool is received by a third party. In one example, the tool is downloaded from an application (or network) controller and/or website. The tool allows the third party to create control logic for a potential customer. The tool is described in greater detail with respect to FIG. 3. At step 204, the third party creates or builds the control logic using the information or other features provided by the tool. Third parties include, for example, entities or developers that do not directly deploy the logic in their business, i.e., the third party develops the control logic for the use of another individual or entity. In one instance, a third party is a software developer that develops software for factory owners, i.e., the third party is not the factory owner.


At step 206, the control logic is sent to the application controller at the communication network. At step 208, the application controller at the communication network receives the control logic. At step 210, the application controller tests and validates the control logic at the communication network. In other aspects, the testing and validation may be accomplished utilizing a third party testing platform. At step 212, the application controller analyzes the results of the testing and validation processes and if the results are satisfactory, at step 214 releases the control logic to the customer or for presentation and potential purchase or use by others. If the results are not satisfactory, the owner of the control logic may be informed.


At step 216, the control logic is sent from the application controller to a presentation apparatus (e.g., web-based store). At step 218, the control logic is made available for viewing by potential customers or by other third party providers, for example at a website. At step 220, the control logic is viewed and/or purchased by a customer and this is communicated to the controller.


At step 222, if the control logic is purchased, it is installed by the application controller at the automation controller of the customer. The control logic is linked to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform. In some aspects, the linking is performed at or shortly before the integration of the control logic to the selected hardware platform. In some other aspects, the control logic developed by the third party is not limited to integration on a single type of hardware platform. In other aspects, multiple versions of the control logic developed by the third party may be stored and maintained.


Referring now to FIG. 3, one example of a tool kit 300 is described. In this example, the tool kit 300 includes software 302, documentation 304, and access 306. The software 302 allows a third party to build the control logic. The software 302 may be accessed via web site and stored at a communication network. The software 302 may actually be part of the tool kit or the tool kit may provide access to the software 302, with the software 302 actually residing at the communication network. The documentation 304 may show the third party how to design the control logic, include customer specific requirements or specifications, or otherwise facilitate the creation of the control logic by the third party provider. In one aspect, the access 306 may be a password to the web site that allows the third party provider to create the control logic.


Referring now to FIG. 4, one example of a communication network (or application) controller 400 is described. The communication network controller 400 resides at a communication network and is remotely located from the automation controllers (i.e., it is separated physically from the automation controllers by a substantial distance).


The communication network controller 400 includes a processor 402 and interface 404. The processor 402 includes a receive module 405, a test and validate module 406, an analyze module 408, and a release module 409. The interface 404 is coupled to communication medium 407. Communication medium 407 (e.g., any wired or wireless connection) is coupled to a library 410 that includes library routines, a third party 412, and a customer 414.


The receive module 405 receives a representation of the control logic for testing purposes. The test and validate module 406 performs various tests on the control logic. For example, various industry or user specific tests may be performed. The analyze module 408 analyzes the results of the testing, for example, whether the tests have been passed or failed. The release module 409 determines whether to release the control logic to the customer that ordered the control logic or other potential customers based upon the results of the testing.


The interface 404 provides formatting and control functions between the processor 402 and the communication medium 407. The processor 402 is any processing device such as a microprocessor or the like. The communication network controller 400 may be disposed or implemented in any device such as an access point, server, or base station, to mention a few examples.


Referring now to FIG. 5, one example of an automation controller 500 is described. The automation controller 500 includes an interface 502, one or more actuators 504, a processor 506, and a memory 508 (that includes control logic 510 and settings 512).


The interface 502 facilitates communications between the automation controller 500 and a communication network 514, and between the automation controller 500 and a local user interface 516. In this respect, the interface 502 includes hardware and/or software that interprets or translates commands and/or other information between the communication network 514 and the automation controller 500, and between the automation controller 500 and a local user interface 516.


The actuators 504 actuate physical or logical devices (e.g., the mechanical components of a valve or a sprinkler motor, to mention two examples). The function of the actuators 504 is to physically implement one or more of the functions associated with or provided by the controller 500.


The processor 506 is any programmed logic device such as a microprocessor or the like. Control logic 510 implements control functions that control actuators 504. Settings 512 are settings or other parameters (e.g., valve levels, pressures, temperatures, speeds) for the actuators 504.


Local user interface 516 may be a personal computer, cellular phone, or any other device that communicates with network 514 and/or controller 500. The communication network 514 is the location where the control logic 510 is built.


In one example of the operation of the system of FIG. 5, third parties develop control logic 510. The customer sends an order (via the local user interface 516) to the communication network 514. As described elsewhere herein, third parties are provided with tools to build the control logic 510 and this control logic 510 can be downloaded to the memory 508. The control logic 510 may also be featured at a web site at the communication network 514 where it may be made available for purchase, viewing, or use by other customers. Other third party providers may also view this control logic.


Preferred embodiments of this invention are described herein, including the best mode known to the inventors for carrying out the invention. It should be understood that the illustrated embodiments are exemplary only, and should not be taken as limiting the scope of the invention.


As used herein, an element or function recited in the singular and proceeded with the word “a” or “an” should be understood as not excluding plural said elements or functions, unless such exclusion is explicitly recited. Furthermore, references to “one embodiment” of the claimed invention should not be interpreted as excluding the existence of additional embodiments that also incorporate the recited features.


This written description uses examples to disclose the invention, including the best mode, and also to enable any person skilled in the art to make and use the invention. The patentable scope of the invention is defined by the claims, and may include other examples that occur to those skilled in the art. Such other examples are intended to be within the scope of the claims if they have structural elements that do not differ from the literal language of the claims, or if they include equivalent structural elements with insubstantial differences from the literal languages of the claims.


Although specific features of the invention are shown in some drawings and not in others, this is for convenience only as each feature may be combined with any or all of the other features in accordance with the invention. The words “including”, “comprising”, “having”, and “with” as used herein are to be interpreted broadly and comprehensively and are not limited to any physical interconnection. Moreover, any embodiments disclosed in the subject application are not to be taken as the only possible embodiments. Other embodiments will occur to those skilled in the art and are within the scope of the following claims.

Claims
  • 1. A method of providing control logic for automation controllers using a communication network, the method comprising: providing, by a first party that distributes control logic for an automation controller owned by a second party, at least one tool for a third party to develop control logic for the automation controller, the third party being an entity that does not directly deploy the control logic in its own business, the automation controller being remotely located from the communication network;receiving, by the first party at the communication network, the control logic from the third party;selecting a hardware platform on which to operate the control logic;linking the control logic to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform;testing and validating the control logic at the communication network;at the communication network, analyzing a result of the testing and the validating of the control logic according to a predetermined criteria; andwhen the predetermined criteria is satisfied, releasing the control logic to a network-based web store operated by the first party at the communication network and subsequently presenting the control logic to the second party.
  • 2. The method of claim 1, wherein the linking is performed at or before integrating the control logic to the selected hardware platform.
  • 3. The method of claim 1 further comprising: receiving a purchase order for the control logic from the second party.
  • 4. The method of claim 1, wherein the testing is automatically accomplished without manual intervention.
  • 5. The method of claim 4, wherein the testing is at least partially manually accomplished.
  • 6. The method of claim 1 further comprising: testing and validating the control logic at a third party testing platform.
  • 7. An apparatus for providing control logic for automation controllers using a communication network operated by a first party, the apparatus comprising: an interface having an input and an output;a processor, the processor coupled to the interface, the processor configured to: provide at least one tool for a third party to develop control logic for an automation controller owned by a second party at the output of the interface, the third party being an entity that does not directly deploy the control logic in its own business, the automation controller being remotely located from the communication network;receive the control logic from the third party;select a hardware platform on which to operate the control logic;link the control logic to at least one operational characteristic of the hardware platform such that the control logic is operable to perform at least one predetermined function of the automation controller using the hardware platform;test and validate the control logic at the communication network;analyze a result of the testing and the validation of the control logic according to a predetermined criteria; andwhen the predetermined criteria is satisfied, release the control logic to a network-based web store at the communication network.
  • 8. The apparatus of claim 7, wherein the processor creates the link at or before integrating the control logic to the selected hardware platform.
  • 9. The apparatus of claim 7, wherein the processor is further configured to receive a purchase order for the control logic from a potential customer at the input of the interface.
  • 10. The apparatus of claim 7, wherein the processor accomplishes the testing automatically without manual intervention.
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/US2012/044770 6/29/2012 WO 00 11/24/2014
Publishing Document Publishing Date Country Kind
WO2013/103383 7/11/2013 WO A
US Referenced Citations (129)
Number Name Date Kind
5530643 Hodorowski Jun 1996 A
5870537 Kern et al. Feb 1999 A
6353926 Parthesarathy et al. Mar 2002 B1
6445963 Blevins et al. Sep 2002 B1
6449624 Hammack et al. Sep 2002 B1
6567937 Flores et al. May 2003 B1
6704735 Salo et al. Mar 2004 B1
6799080 Hylden et al. Sep 2004 B1
6882890 Horn et al. Apr 2005 B2
6904449 Quinones Jun 2005 B1
7103647 Aziz Sep 2006 B2
7127330 Spool et al. Oct 2006 B2
7143186 Stewart et al. Nov 2006 B2
7246078 Vincent Jul 2007 B2
7257620 Lo Aug 2007 B2
7290244 Peck et al. Oct 2007 B2
7318044 Matsuoka et al. Jan 2008 B2
7330473 Baier et al. Feb 2008 B1
7392421 Bloomstein et al. Jun 2008 B1
7401059 Owen et al. Jul 2008 B1
7523045 Walker et al. Apr 2009 B1
7634757 De et al. Dec 2009 B2
7738975 Denison et al. Jun 2010 B2
7747404 Meckelburg et al. Jun 2010 B2
7778883 Albazz et al. Aug 2010 B2
7860609 Yanagita et al. Dec 2010 B2
7861223 Schmidt et al. Dec 2010 B1
7870223 Grgic et al. Jan 2011 B2
7908194 Hollas Mar 2011 B2
7912560 Hood et al. Mar 2011 B2
7958013 Porat et al. Jun 2011 B2
7970830 Staggs et al. Jun 2011 B2
8015373 Ballard et al. Sep 2011 B2
8015546 Jones et al. Sep 2011 B2
8024732 Sheehan et al. Sep 2011 B2
8121707 Karaffa et al. Feb 2012 B2
8468335 Lin et al. Jun 2013 B2
8584114 Rabinovich et al. Nov 2013 B2
20020004709 Peter et al. Jan 2002 A1
20020029377 Pavela Mar 2002 A1
20020049625 Kilambi et al. Apr 2002 A1
20030036876 Fuller et al. Feb 2003 A1
20030063013 Jin et al. Apr 2003 A1
20030076353 Blackstock et al. Apr 2003 A1
20030163212 Smith et al. Aug 2003 A1
20030204784 Jorapur Oct 2003 A1
20030216986 Hassan Nov 2003 A1
20050011967 Skelton-Becker et al. Jan 2005 A1
20050132055 Neogi Jun 2005 A1
20050132064 Lo Jun 2005 A1
20050138111 Aton et al. Jun 2005 A1
20050278577 Doong et al. Dec 2005 A1
20060036876 Kitada Feb 2006 A1
20060036907 Inscoe et al. Feb 2006 A1
20060064183 Chandhoke Mar 2006 A1
20060089886 Wong Apr 2006 A1
20060095855 Britt et al. May 2006 A1
20060235594 Knoefler et al. Oct 2006 A1
20060245564 Li et al. Nov 2006 A1
20070005266 Blevins et al. Jan 2007 A1
20070074280 Callaghan et al. Mar 2007 A1
20070094541 Kang Apr 2007 A1
20070118345 Olesen et al. May 2007 A1
20070208435 Schott Sep 2007 A1
20080141238 Balassanian Jun 2008 A1
20080154909 Dam et al. Jun 2008 A1
20080208380 Taylor Aug 2008 A1
20080222604 Murphy Sep 2008 A1
20080243311 Dahmer et al. Oct 2008 A1
20080244449 Morrison et al. Oct 2008 A1
20080250045 Balassanian et al. Oct 2008 A1
20090012631 Fuller Jan 2009 A1
20090037008 Moorer et al. Feb 2009 A1
20090063650 Anslow et al. Mar 2009 A1
20090144108 Cloud Jun 2009 A1
20090204458 Wiese et al. Aug 2009 A1
20090217163 Jaroker Aug 2009 A1
20090265694 Bakowski Oct 2009 A1
20090300149 Ferris et al. Dec 2009 A1
20090300423 Ferris Dec 2009 A1
20100023600 Hill et al. Jan 2010 A1
20100023918 Bernardini et al. Jan 2010 A1
20100082844 Stoupis et al. Apr 2010 A1
20100088150 Mazhar et al. Apr 2010 A1
20100131624 Ferris May 2010 A1
20100138017 Vrba et al. Jun 2010 A1
20100223157 Kalsi Sep 2010 A1
20100278336 Tahan et al. Nov 2010 A1
20100306379 Ferris Dec 2010 A1
20100318665 Demmer et al. Dec 2010 A1
20110022626 Plache Jan 2011 A1
20110022827 Plache Jan 2011 A1
20110117845 Kirsch et al. May 2011 A1
20110126168 Ilyayev May 2011 A1
20110145439 Chaturvedi et al. Jun 2011 A1
20110154092 Dash et al. Jun 2011 A1
20110154451 Thomas Jun 2011 A1
20110179154 Ravichandran et al. Jul 2011 A1
20110191181 Blackhurst et al. Aug 2011 A1
20110191500 Odayappan et al. Aug 2011 A1
20110197097 Beaty et al. Aug 2011 A1
20110202901 Givoni et al. Aug 2011 A1
20110208606 Hadar et al. Aug 2011 A1
20110208695 Anand et al. Aug 2011 A1
20110231670 Shevchenko et al. Sep 2011 A1
20110231818 Steden Sep 2011 A1
20110238458 Purcell et al. Sep 2011 A1
20110246721 Crisan Oct 2011 A1
20110264550 Fair Oct 2011 A1
20110271278 Dittrich Nov 2011 A1
20110282476 Hegemier et al. Nov 2011 A1
20110282940 Zhang et al. Nov 2011 A1
20110314168 Bathiche et al. Dec 2011 A1
20120010488 Henry et al. Jan 2012 A1
20120109384 Stepanian May 2012 A1
20120131176 Ferris et al. May 2012 A1
20120143767 Abadir et al. Jun 2012 A1
20120158972 Gammill et al. Jun 2012 A1
20120185821 Yaseen et al. Jul 2012 A1
20130024542 Keller et al. Jan 2013 A1
20130024572 Chen Jan 2013 A1
20130096727 Brandt et al. Apr 2013 A1
20130124465 Pingel et al. May 2013 A1
20130211559 Lawson et al. Aug 2013 A1
20130212420 Lawson et al. Aug 2013 A1
20130282180 Layton et al. Oct 2013 A1
20140047064 Maturana et al. Feb 2014 A1
20140047107 Maturana et al. Feb 2014 A1
20150066979 Zhang et al. Mar 2015 A1
Foreign Referenced Citations (16)
Number Date Country
1363072 Aug 2002 CN
1857877 Nov 2006 CN
1862477 Nov 2006 CN
101083657 Dec 2007 CN
101196740 Jun 2008 CN
101208674 Jun 2008 CN
101782893 Jul 2010 CN
101958805 Jan 2011 CN
102105861 Jun 2011 CN
1296232 Mar 2003 EP
1742125 Jan 2007 EP
1814036 Aug 2007 EP
2040135 Mar 2009 EP
2237120 Oct 2010 EP
0075826 Dec 2000 WO
0228125 Apr 2002 WO
Non-Patent Literature Citations (26)
Entry
Cunning et al., “Automatic Test Case Generation from Requirements Specifications for Real-time Embedded Systems”, vol. No. 5, pp. 784-789, 1999.
Husain et al., “Remote device management of WiMAX devices in multi-mode multi-access environment”, pp. 1-13, Mar. 31-Apr. 2, 2008.
“Knowledge as a Service (KaaS) Enables the Right Action, Right Now”, Cumulus IQ: Knowledge as a Service, 2009.
Altmann et al., “A Marketplace and its Market Mechanism for Trading Commoditized Computing Resources”, TEMEP Discussion Paper, Mar. 2010.
“Top ten advantages of Google's cloud”, Google Apps for Business, 2011.
Xianjin et al., “File Synchronization of Multi-Machine System Design and Implementation Based Cloud Storage”, pp. 1275-1278, 2011.
Salves, “Timeline Cloud Family Edition Reviewed”, Pudai LLC, Jul. 18, 2011.
Arefin et al., “CloudInsight: Shedding Light on the Cloud”, 30th IEEE International Symposium on Reliable Distributed Systems, pp. 219-228, Oct. 4-7, 2011.
International Search Report and Written Opinion issued in connection with related PCT Application No. PCT/US2012/044767 dated Sep. 19, 2012.
International Search Report and Written Opinion issued in connection with related PCT Application No. PCT/US2012/044759 dated Sep. 19, 2012.
International Search Report and Written Opinion issued in connection with related PCT Application No. PCT/US2012/044766 dated Oct. 17, 2012.
European Office Action issued in connection with related EP Application No. 12735995.8 dated May 28, 2015.
European Office Action issued in connection with related EP Application No. 12737949.3 dated May 28, 2015.
European Office Action issued in connection with related EP Application No. 12738292.7 dated May 28, 2015.
Unofficial English Translation of Chinese Office Action issued in related with related CN Application No. 201280071226.X dated Nov. 24, 2015.
Unofficial English Translation of Chinese Office Action issued in related with corresponding CN Application No. 201280071178.4 dated Dec. 21, 2015.
Unofficial English Translation of Chinese Office Action issued in connection with corresponding CN Application No. 201280071182.0 dated Dec. 31, 2015.
Ranchal, et al., “Protection of Identity Information in Cloud Computing without Trusted Third Party”, Reliable Distributed Systems, 2010 29th IEEE Symposium, on pp. 368-372, Issue Date: Oct. 31, 2010-Nov. 3, 2010.
Search Report issued in connection with corresponding PCT Application PCT/US2012/044770 dated Sep. 19, 2012.
Soon et al., Test Strategy and Automation for Complex Systems,dated Mar. 1, 2007, IP.com Prior Art Database Technical Disclosure,IP.com No. IPCOM000147528D, Mar. 1, 2007.
IBM,“Method of Creating a Componentized Architecture for Unifying Resource Sharing Scenarios in Cloud Computing Environment”, Prior Art Database Disclosure, pp. 1-13, Feb. 11, 2010.
Zexi et al., “An Optimal Hysteretic Control Policy for Energy Saving in Cloud Computing”, Global Telecommunications Conference, pp. 1-5, 2011.
International Search Report and Written Opinion issued in connection with related Application No. PCT/US2013/048529 dated Oct. 4, 2013.
GE Related Case Form.
U.S. Non-Final Office Action issued in connection with related U.S. Appl. No. 14/376,958 dated Jun. 2, 2017.
PCT International Preliminary Report on Patentability issued in connection with related PCT Application No. PCT/US2013/048529 dated Mar. 5, 2015.
Related Publications (1)
Number Date Country
20150112458 A1 Apr 2015 US