This application claims priority to European patent application 07102279.2 filed 13 Feb. 2007.
The present invention relates to a system of monitoring a plurality of robots spread at different locations at a remote service center by means of information exchange between individual robots and the remote service center.
Common diagnostic systems for robot controllers consist of either a computational unit in the robot controller or diagnostics computations performed in a PC connected to the robot controller. Common to these existing solutions is the use of a high bandwidth of data signals that flow from the controller at the diagnostics computations. Diagnostics has conventionally been performed locally at the controller or at a device which has a high bandwidth connection to the controller.
US published application 2006/0206289 discloses a system of monitoring a plurality of robots from a remote location. The nature of the communication links used in said publication is not discussed.
If, in a robot monitoring system, a remote service center is established to perform the monitoring of a high number of robots spread at a plurality of plants at different geographic locations, an optimization of communication traffic between each individual robot of the system and the remote service center plays a major role to enable delivery of cost effective services (diagnostics) to a customer. One object of the present invention is to present a solution of a remote diagnostic system for delivery of remote diagnostics for robots with minimal communications costs. Another object of the invention is to present a solution of a remote diagnostic system for delivery of remote diagnostics for robots with a safe and high security of the communications between the individual robots and the remote service center.
The present invention addresses problems in connection with communications and the localization of the computations in a remote diagnostic system for industrial robots. The present invention further addresses the issues directed to safety and security of the communications between a remote service center and industrial robots included in the system. One aspect of the invention is to provide each robot of the system with a service unit connected to the robot controller, wherein the service unit performs local diagnostic calculations and performs data compression. Said service unit is in turn connected to a remote connector server at a remote service center over a potentially low-bandwidth line or a line with high communication costs. The final or remaining diagnostics is performed at full computational power at said remote service center. Said remote service center further acts as a distribution point for information via a web browser and notification service, which allows e-mails and SMS-messages to be sent to the appropriate personnel at the robot site.
Two key features of the invention are adaptiveness and flexibility in the system. To achieve this, the service units are, e.g., reprogrammable. Another important demand on the system is security.
Locally in the system there is always at least one controller involved, normally close to an individual robot included in the system.
The service unit is a communication and logging unit, which has different degrees of processing power depending upon the design. The service unit is connected to the controller of the individual robot. The term “service unit” is herein only used as a term of identification. The functions included in the so called “service unit” can be implemented as a logic unit connected to and integrated with the robot controller. Said functions can as well be implemented as logics included in the controller or as a mix of logics internally and externally of the robot controller locally at the robot.
A first task for the service unit is to verify the product (the industrial robot) that is connected and explicate its version. A second task for the service unit is to request and/or receive commands from the connector server at the remote service center with respect to what to do. A third task for the service box is to executes scripts and/or codes provided by the connector server. The service box will react on events, condition changes from the robot or on specific requests from a user of the remote service center.
The connector server at the remote service center is provided with a code library storing codes for each specific service unit distributed across the remote diagnostic system. The connector server provides to the service unit codes/scripts on request from the service box or on demand from application performed at the connector server or from an end user.
The communications infrastructure is responsible for transferring packets of information, in both directions, between the locally disposed robot, here called the local site, and the remote service center, here sometimes referred to as the remote site.
An event scheme, wherein a service unit automatically requests diagnostic information from the remote service center, can be described as:
As communication between the local site and the remote site must be secure, there is presupposed that some form of an access point must be provided at both the local and the remotes sites. This access point can take the form of e.g. a VPN router or other piece of equipment allowing secure access to the remote service center.
The solution according to the invention solves a problem with diagnostic activities at a remote site. Controller data is very awkward, as it is very processor intensive. Such data would be difficult to transfer in a cheap way to a remote site. One purpose with the service unit is to provide compression of controller data. Another purpose would be to perform packing of data. Other aspects regarding the service unit is that it should be non-intrusive, generic and reprogrammable. These aspects are important to achieve the adaptiveness and the flexibility of the remote diagnostic system, which provides services and diagnostics to a large and non homogeneous robot population (i.e. a large installed base of different products and versions of robots).
As the controller data is compressed, possibly packaged and possibly pre-processed, cheap communication lines, such as internet or GPRS, can be used to arrive at a cost-effective system and thus enable the realization of the remote service center.
The remote service center could be viewed as a Global service center and is a central hub for the system. This hub clearly comprises a web site and servers for the web site, as well as a database for customer information. Depending upon the local site communicating with the remote service center, the hub may have diagnostic tools for performing diagnostics of a robot at said local site and other tools for remotely connecting to a robot controller via the service unit at a local site.
One object of the invention is to make it possible to provide robots without logics for monitoring purposes and in this way perform robots of a cheaper design. As the robot can communicate with the remote service center, monitoring tools, such as diagnostic units can be reached for performing said monitoring of the robot. In this way, the robot can get access to all monitoring and diagnostic tools available at the remote service center, wherein these tools are updated and of the latest design, which in turn make it unnecessary to provide the local robot controller with costly local diagnostic tools and a need of frequent robot software updates.
Below the invention will be explained in greater detail by description of embodiments with reference to the accompanying drawings.
The general architecture of the remote service center is structured to function as, among others, a central data storage with a web interface. A device logic layer will make the interface with customer equipment and will handle the communication between the servers and databases at the remote service center and the local site at the customer.
In the system there is a robot services. Said robot services provide all the interfaces between the local site 2 and the remote service center 3. The robot services hide all the complexity and specificity of the communication and transform robot specific data to generic data for a transfer of information between the local 2 and remote sites 3.
At the remote service center site 3 the robot services is represented by a box denoted 4, which can be realized as a client server, here represented as a connector server 4. The robot services, further, have one part at the local site (robot services client), herein referred to as a service unit and denoted 11, representing logics installed for the purpose, to handle the local process and events associated to the robot 1. The service unit 11 is connected to or integrated with the robot controller 1a, to which the service unit 11 is assigned. The connector server 4 performs scheduled services, such as requesting data from a local site 2 and reception of service data from a local site 2. Crypting and encrypting data on communication with a local site 2 is also implemented at the connector server 4. The connector server 4 can be implemented on one or more connector servers at the remote server center 3. In the robot services, including the service unit 11 and the connector server 4, the connector server 4 checks the authority of the service unit 11 its access to the remote service center 3. Said access could, as an example, be implemented as a digital signature for the service unit 11.
The connector server 4 further stores a code archive/library, which is provided with the codes applicable for all the service units 11 being authorized to access the connector server 4 for exchange of data via the communication line 14a. This is arranged, such that when a specific service unit 11 requests diagnostic information from the remote service center 3, the connector server 4 identifies said service unit 11 and retrieves from the code library the code for use at the specific service unit 11 and the connector server 4, whereupon said retrieved code is downloaded to the service unit 11. The connector server 4 can further be provided with software for pre-processing of data from the service unit 11 and software for management of said data. If data from the service unit is delivered to the connector server 4, the connector server 4 will be provided with software for de-packing data packets. The code is secured from tampering during the transmission and to prevent unauthorized code from being executed on the service unit 11. This can be accomplished by using a number of hash and encryption techniques, one common technique is to hash the code in the code library and then digitally sign the hash with a private key. A public key, using private/public key pairs, is in the service unit. When the code is downloaded, the service unit 11 checks the signature and the hash with the actual code, and refuses to run code that does not pass.
In a database layer 10 the remote service center 3 is further provided with a current history database 12, which contains all the information needed with respect to the requests of diagnostic information. The main information stored and managed are client user information (profile, site, robot type, robot variant, diagnostic date, contracts, mail etc.), communication information (local equipment, communication parameters, contracts, etc.) and administration information (security, rights, scripts, etc.).
The main purpose with the configuration database 12 is to have it provided with all information needed to have monitoring and diagnostics working, excluding all information coming from the robot 1 itself or from a support engineer, when there is a contract between a supplier of the remote service center and a client (customer) using the robot 1. An administrator user has to be defined to manage and set up this client user information.
Further, a historical database 13 is provided in the database layer 10 at the remote service center 3. The historical database 13 gathers all the information coming from the robot 1 system and other associated information from other actors and which needs to be kept for history or processing. The historical database can store customer related information, such as robot type, robot version, service performed, who the customer is, where the robot is situated, service program, etc.
The remote service center 3 is provided with a diagnostics engine 6 equipped with processors and software for performing qualitative diagnostic analysis. The diagnostics engine 6 has scheduled processes attached for generating diagnostics information based on raw material stored for the specific robot 1 and on information sent from the service unit 11 via the communication line 14a. Alarms may be generated based on the result of said scheduled diagnostic processes performed for said specific robot included in the system. An alarm depending on diagnostics can be sent to the current history database 12 for storing and/or sent as an alert denoted by arrow 21. The diagnostics engine 6 performs analyses, trendings and predictions regarding each robot of the system and stores knowledge and history regarding the robot.
A unit, herein called a business logic layer 7, contains business related logics for the company managing the remote service center 2. The purpose of the business logic is to separate the database access and presentation logic from the user interface. The purpose is further to manage, for example, which services to be delivered, how the services is delivered to a customer (alarm, send or not by email/SMS, and to which person or addressee to send).
A presentation layer (web site) 8 is provided for allowing end users (service technicians at a remote service center console 24) at the remote service center 3 to access, via a user interface on a network 14b at the remote service center 3, all information regarding the robot systems included in the remote service system as data per individual robot or per population of robots. Available robot system information includes data from the business logic layer 7, results achieved from raw data in the diagnostics engine 6, data from the databases 12 and 13 at the remote service center 3 and direct data from the service unit 11 or robot controller 1a.
A device layer 5 provides logic for the remote service center 3. This device logic layer 5 is the link between the connector server 4, the current history database 13, the history database 12, the diagnostics engine 6, the business logic layer 7 and presentation layer 8 and comprises routines for data presentation and commands. This device logic layer 5 has knowledge implemented to it about the robots 1 of the system and a complete behavior of the remote service center 3. The device logic layer 5 will also manage the scheduled operations of the service center 3.
Still further, the historical database 13 contains short term and long term information for current display, temporary processing or long term statistical information and reports. The historical database is scalable and managed professionally at the remote service center 3.
A more detailed description of an embodiment of the remote service center is illustrated in
The communication line 14a provides information in a dynamic way or through scheduled reports. The communication line 14a is also used for all the configuration and administrative functions. The communication line 14c is a communication channel for the end customer 16. By means of the communication line 14a it is also provided for access to the robots 1 in a secure way for the remote service center 3 to request information during events or on demand. Through the communication line 14a, the service unit 11 can e.g. be re-programmed.
The remote service center 3 is further provided with a web portal 14c making it possible for service technicians 17 at the local site 2 to access the remote service center 3 and thus the databases 12 and 13 via a user interface.
The user interface is managed by the web portal 14c which is effected through a web client or a smart client. The same web portal 14c provides and manages information for different groups of users and must be secured.
In
Some tools are attached to the web portal 14c to enhance the information displayed. These tools will be connected to raw data like logs or backups.
The device logic layer 5 is the link between the historical database 13, the current history database 12, the web site presentation layer 8 comprising routines for data presentation and commands, and the connector server 4. This device logic layer 5 has knowledge implemented to it about the robots 1 of the system and a complete behavior of the remote service center 3. The device logic layer 5 will also manage the scheduled operations of the service center 3.
The connector server 4 further handles events and data to interface these data with the data of the historical database 13 and the presentation layer 16 through the device logic layer 5.
Different alarms can be generated either by logics installed locally at the robot 1 at the local site 2 or originating from diagnostics performed at the remote service center 3. These alarms are centrally managed in the device logic layer 5 for sending alarm on events, track the alarm states, etc., in dependence of the instructions implemented in the monitoring service set up for the specific robot 1 installation. The alarm management service is implemented at the device logic layer 5, which can handle the alarm according to predetermined instructions. A direct line 23 for an alert to the remote service technician at remote service center console 24 is also implemented. The diagnostics performed at the diagnostics engine 6 can also be arranged, in dependence on results of the performed diagnostics, to release an alarm 23.
Diagnostic and service functions provided by diagnostics engine 6 are implemented as tools available for processing at the remote service center 3, e.g. from the historical database 13 to supply the service center 3 with qualitative diagnostic information and for performing advanced diagnostics and modeling.
Interactions performed at the remote diagnostic system for robots are illustrated in
In a first usage mode services are performed by the system when the robot 1 is working and running normally at the local site 2 without any report of an error. In this mode, at least one of the following monitoring actions are performed in the system, wherein the system:
In a second usage mode services, the robot 1 has had a failure and the service supplier center 30 as well as the customer has been informed. In this mode the system performs at least one of the actions:
In a third usage mode services, the robot 1 has experienced a major failure and cannot be recovered at the local site 2. In this third mode the system performs at least one of the actions:
These modes are only examples and other modes of use of the system can be implemented.
The signal possibilities for a technician at the suppliers service center 30 are illustrated in the figure as:
Signal options between the local site 2 equipment and the remote service center equipment 40 via the communication network 41 are:
A local service technician 17 sends or receives data via internet on line 50 of the figure.
A customer 16 receives data via internet on line 51 of the figure. The data contains local site information (current or historic).
The illustrated embodiment should only be referred to as an example. Thus, while there have been shown and described and pointed out fundamental novel features of the invention as applied to a preferred embodiment thereof, it will be understood that various omissions and substitutions and changes in the form and details of the devices illustrated, and in their operation, may be made by those skilled in the art without departing from the spirit of the invention. For example, it is expressly stated here, that the servers and databases included in the remote service center 3 can be structured in other ways. As examples, the current history database 12 and the historical database 13 may, of course be housed in one unit only, or divided into more than two units. The servers included in the remote service center 3 may, in the same way, be integrated into one unit or distributed into several separate units.
Number | Date | Country | Kind |
---|---|---|---|
07102279 | Feb 2007 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
6058307 | Garner | May 2000 | A |
6317788 | Richardson | Nov 2001 | B1 |
6438454 | Kuroki | Aug 2002 | B1 |
6446192 | Narasimhan et al. | Sep 2002 | B1 |
6518980 | DeMotte et al. | Feb 2003 | B1 |
6532401 | Tackett et al. | Mar 2003 | B2 |
6732191 | Baker et al. | May 2004 | B1 |
6785590 | Kasuga et al. | Aug 2004 | B2 |
6795778 | Dodge et al. | Sep 2004 | B2 |
6882962 | Aoyama | Apr 2005 | B2 |
7130769 | Allen et al. | Oct 2006 | B1 |
7853645 | Brown et al. | Dec 2010 | B2 |
20020163427 | Eryurek et al. | Nov 2002 | A1 |
20030023333 | Birkle | Jan 2003 | A1 |
20030163217 | Nakamoto et al. | Aug 2003 | A1 |
20040083010 | Nagata et al. | Apr 2004 | A1 |
20050010311 | Barbazette et al. | Jan 2005 | A1 |
20060206289 | Stake et al. | Sep 2006 | A1 |
20080247549 | Blanc et al. | Oct 2008 | A1 |
Number | Date | Country | |
---|---|---|---|
20080247549 A1 | Oct 2008 | US |