This application is based on and claims the benefit of priority from Japanese Patent Application No. 2019-128347, filed on 10 Jul. 2019, the content of which is incorporated herein by reference.
The present invention relates to a controller, a method, and a program that diagnoses communication conditions.
Conventionally, a machining system is known in which a machine tool and an auxiliary device for assisting the machine tool establish a machining cell and in which they cooperate to perform machining (see, for example, Patent Document 1). In such a machining system, for example, a controller for a machining center and a controller for a robot are connected so as to be able to communicate with each other, various types of information are directly communicated between the controllers, and thus a cooperation operation between the machining center and the robot is realized.
Patent Document 1: Japanese Unexamined Patent Application, Publication No. 2010-64158
However, since there is a tendency for a communication protocol between the controllers to be complicated and the number of communication setting parameters and amount of device information to be increased, when the establishment of communication fails or a communication error occurs, it is difficult to identify the cause thereof. Hence, it is desired to be able to easily identify a cause of a communication abnormality.
A controller according to an aspect of the present disclosure is a controller of an industrial machine that communicates with an external device through a network and includes: a plurality of communication units which respectively correspond to a plurality of communication protocols; and a diagnosis unit which starts up the communication units in a predetermined order and attempts communication using the communication protocols corresponding to each communication unit that is started up so as to diagnose the conditions of the communication step by step.
In a diagnosis method according to an aspect of the present disclosure, a controller of an industrial machine that communicates with an external device through a network starts up, in a predetermined order, a plurality of communication units which respectively correspond to a plurality of communication protocols and attempts communication using the communication protocols corresponding to the communication units which are started up so as to diagnose the conditions of communication step by step.
A diagnosis program according to an aspect of the present disclosure is a diagnosis program for making a computer function as the controller.
According to the present invention, it is possible to easily identify a cause of a communication abnormality in a controller of an industrial machine.
An example of the embodiment of the present invention will be described below. A controller 1 in the present embodiment is an information processing device for controlling an industrial machine such as a machine tool or a robot and is connected to an external device through a network so as to communicate therewith, with the result that a manufacturing system is configured. The external device is an industrial machine, an information device, or the like, and examples thereof include a production management system, a line controller, a robot controller, a controller of a machine tool, and a remote I/O device. The controller 1 may be incorporated into the industrial machine or may be provided in a separate housing and connected so as to be able to communicate therewith.
The control unit 10 includes a plurality of communication units 11, a diagnosis unit 12 which diagnoses the conditions of communication using the communication units 11, a diagnosis recording unit 13, an error recording unit 14, and a communication recording unit 15.
The plurality of communication units 11 are provided so as to respectively correspond to a plurality of communication protocols which are supported by communication paths with the external device. The control unit 10 uses any one of these communication units 11 so as to communicate, by use of the corresponding communication protocol, with the external device through the network.
In the present embodiment, for example, communication protocols as described below are assumed. In Ethernet, for example, TCP/IP, UDP/IP, PING, ARP, or the like is used. In serial communication, for example, RS-232C, RS-485, or the like is used. In Fieldbus, DeviceNet, Profibus, CC-Link, or the like is used. In industrial Ethernet, EtherNet/IP, ProfiNet, CC-Link IE, or the like is used. In object communication, CIP, OPC/UA, or the like is used. In communication dedicated to a machine tool, a communication protocol with the unique specifications of a machine tool maker is used.
The diagnosis unit 12 starts up the communication units 11 in a predetermined order and attempts communication using the communication protocols corresponding to each communication unit 11 which is started up so as to diagnose the conditions of communication step by step. Here, the diagnosis unit 12 sequentially executes diagnosis processing corresponding to the individual communication protocols.
The diagnosis unit 12 can change various types of communication parameters in the communication protocol, and when the diagnosis unit 12 has unsuccessful communication using any one of the communication protocols, the diagnosis unit 12 changes the communication parameters so as to attempt communication again. For example, the diagnosis unit 12 changes a communication profile so as to attempt communication again. When the diagnosis unit 12 transmits and receives a control signal at a predetermined communication period, if the communication unit 11 cannot obtain a reception signal and has unsuccessful communication due to a timeout, the diagnosis unit 12 extends a time until the timeout with a predetermined threshold value set to an upper limit so as to attempt communication again.
In the protocol 1 of address confirmation, a node address, an IP address, a hostname, and the like are set as communication parameters. In the protocol 1, a response for existence confirmation is requested, and there is no limitation to communication timing, but a timeout occurs in the reception of a response signal in about one to several tens of seconds.
In the protocol 2 of message communication, in addition to the case of the protocol 1, a port number, a command, and the like are set as communication parameters. In the protocol 2, a response for data level is requested, and there is no limitation to communication timing, but a timeout occurs in the reception of the response signal in about one to several tens of seconds.
In the protocol 3 of connection, in addition to the case of the protocol 2, a connection parameter to a predetermined communication access point is set. In the protocol 3, a previously defined processing procedure is requested, and a predetermined constraint is imposed on communication timing and the like.
In the protocol 4 of I/O communication, in addition to the case of the protocol 3, a connection parameter to a predetermined input/output logic module and parameters for the communication period and the like are set. In the protocol 4, communication processing on the control signal is requested in real time, and a predetermined constraint is imposed on communication timing and the like. Specifically, it is necessary to transmit and receive data at the communication period corresponding to a control cycle, and a timeout occurs due to, for example, noise in a short period of about several to 100 milliseconds.
In the protocol 5 of communication dedicated to a machine tool, in addition to the case of the protocol 4, for example, in order to confirm a connection to the machine tool, device information, a device version, and the like are set as communication parameters. In the protocol 5, functions necessary for the application of the machine tool are realized by communication. In order to ensure normal operation, it is necessary to confirm the configurations of the devices and the supported version.
In this example, the communication units 11 of the protocols 1 and 2 may be started up at the time of diagnosis and may be stopped during the normal operation of the controller 1. Since the protocol 4 can be used in place of a heartbeat function which is realized with the protocol 3 during the normal operation, the communication unit 11 of the protocol 3 may likewise be stopped. On the other hand, since the protocols 4 and 5 are needed in a cooperative operation with the external device, the corresponding communication units 11 are constantly operated.
In the protocols 1 to 5, communication parameters, constraints on the communication and the like are increased in this order, and the complexity thereof is increased. Hence, while the protocol 1 or 2 can be said to be a robust communication protocol, in the protocol 3 and the subsequent protocols, a parameter setting error or a communication error easily occurs.
The diagnosis unit 12 sequentially starts up the communication units 11 corresponding to the protocols 1 to 5 when the controller 1 is started up, and when communication succeeds in each protocol, the diagnosis unit 12 proceeds to the subsequent protocol step by step. Here, when an error occurs in any one of the communication protocols, the diagnosis unit 12 executes a diagnosis routine for communication conditions that corresponds to the stage and thereby collects various types of information for identifying a cause thereof so as to output them.
In the diagnosis routine for the protocol 1 of address confirmation, whether or not a node is present is diagnosed by a search for a network address with PING, ARP, or the like. Here, the diagnosis unit 12 produces a list of network addresses.
In the diagnosis routine for the protocol 2 of message communication, whether or not response data for a request for the transmission of a numerical value, a character string, a file, or the like can be received within a certain time is diagnosed. Here, the diagnosis unit 12 reads the version of the software which is operated in the external device, a setting file that is referenced in the protocols 3 to 5 in the subsequent stages, and the like. The diagnosis unit 12 adds, to the list of network addresses, the name of the external device and the like that are read.
In the diagnosis routine for the protocol 3 of connection, whether or not the communication profile is matched and a connection destination is correct is diagnosed based on a response from the external device within a certain time to a request for the start of communication with the communication access point. Here, the diagnosis unit 12 acquires an error code which is defined in the communication protocol and outputs the details of the error. The diagnosis unit 12 may present the reason for a connection failure, a method of dealing therewith, and the like, which are previously associated with the error code. Furthermore, in order to confirm an error in the input of the communication profile, the diagnosis unit 12 changes the communication profile so as to attempt connection again. Consequently, when the diagnosis unit 12 succeeds in the connection, the diagnosis unit 12 may present the specific part of a setting error. The diagnosis unit 12 adds, to the list of network addresses, whether or not the connection is established.
In the diagnosis routine for the protocol 4 of I/O communication, whether or not the communication profile is matched and a connection destination is correct is diagnosed based on a response from the external device within a certain time to a request for the start of communication with a transmission/reception data logic module which belongs to the communication access point. The communication period of the control signal, a communication delay, and variations therein are evaluated. Here, as in the case of the protocol 3, the diagnosis unit 12 acquires an error code which is defined in the communication protocol, and outputs the details of the error. The diagnosis unit 12 may present the reason for a connection failure, a method of dealing therewith, and the like which are previously associated with the error code. Furthermore, in order to confirm an error in the input of the communication profile, the diagnosis unit 12 changes the communication profile so as to attempt communication again. Consequently, when the diagnosis unit 12 succeeds in communication, the diagnosis unit 12 may present the specific part of a setting error.
The diagnosis unit 12 evaluates stability relating to the communication period which is the communication parameter, for example, the rate of occurrence of an error, compares it with past log information, and thereby determines the possibility that an abnormality in communication quality, that is, noise, is present. Furthermore, the diagnosis unit 12 may repeat the adjustment of the communication period and a timeout time so as to determine the recommended values of the communication period and a delay margin in which the rate of occurrence of an error is lowered. Since the communication period and the timeout time affect a machining time, a production amount, and the like, they are preferably set to be low. Since an upper limit is provided for the protocol 5 of communication dedicated to a machine tool in the subsequent stage, the communication period and the timeout time are set to large values within a range up to the upper limit in a step-by-step manner. The diagnosis unit 12 may add to the list of network addresses an indicator for the evaluated communication state, and may display it, for example, in a different color or with an icon.
In the diagnosis routine for the protocol 5 of communication dedicated to a machine tool, whether or not the types of machine tool serving as the external device in the setting and in actuality agree with each other is confirmed. Since an interface, a data structure, or the like differs depending on the version of the application, whether or not the versions of the application in the controller 1 and in the machine tool agree with each other is confirmed. Here, the diagnosis unit 12 acquires the error code from the machine tool and outputs the details of the error.
These diagnosis routines are sequentially executed immediately after the controller 1 is started up, at regular intervals in the normal operation of the controller 1, and when an error occurs.
The diagnosis recording unit 13 records the result of the diagnosis by the diagnosis unit 12 in the storage unit 20 together with time information. The error recording unit 14 records, in the storage unit 20, together with the time information, the information of the communication protocol used when the diagnosis unit 12 has unsuccessful communication with the external device. The communication recording unit 15 records, when the diagnosis unit 12 has successful communication with the external device, parameters set in the communication protocols in the storage unit 20 together with the time information.
In step S1, the diagnosis unit 12 starts up the communication unit 11 corresponding to the protocol 1 so as to attempt the communication of the address confirmation with the external device. In step S2, the diagnosis unit 12 determines whether or not the communication using the protocol 1 succeeds. When the determination is yes, the processing is transferred to step S4, whereas when the determination is no, the processing is transferred to step S3. In step S3, the diagnosis unit 12 executes the diagnosis routine for the protocol 1 and completes the processing.
In step S4, the diagnosis unit 12 starts up the communication unit 11 corresponding to the protocol 2 so as to attempt the message communication with the external device. In step S5, the diagnosis unit 12 determines whether or not the communication using the protocol 2 succeeds. When the determination is yes, the processing is transferred to step S7, whereas when the determination is no, the processing is transferred to step S6. In step S6, the diagnosis unit 12 executes the diagnosis routine for the protocol 2 and completes the processing.
In step S7, the diagnosis unit 12 starts up the communication unit 11 corresponding to the protocol 3 so as to attempt the communication of the connection with the external device. In step S8, the diagnosis unit 12 determines whether or not the communication using the protocol 3 succeeds. When the determination is yes, the processing is transferred to step S10, whereas when the determination is no, the processing is transferred to step S9. In step S9, the diagnosis unit 12 executes the diagnosis routine for the protocol 3 and completes the processing.
In step S10, the diagnosis unit 12 starts up the communication unit 11 corresponding to the protocol 4 so as to attempt the I/O communication with the external device. In step S11, the diagnosis unit 12 determines whether or not the communication using the protocol 4 succeeds. When the determination is yes, the processing is transferred to step S13, whereas when the determination is no, the processing is transferred to step S12. In step S12, the diagnosis unit 12 executes the diagnosis routine for the protocol 4 and completes the processing.
In step S13, the diagnosis unit 12 starts up the communication unit 11 corresponding to the protocol 5 so as to attempt the communication dedicated to a machine tool with the external device. In step S14, the diagnosis unit 12 determines whether or not the communication using the protocol 5 succeeds. When the determination is yes, the processing is transferred to step S16, whereas when the determination is no, the processing is transferred to step S15. In step S15, the diagnosis unit 12 executes the diagnosis routine for the protocol 5 and completes the processing.
In step S16, the diagnosis unit 12 periodically executes a communication state monitoring routine with predetermined timing. In step S17, the diagnosis unit 12 determines whether or not the communication state is normal. When the determination is yes, the processing is returned to step S16, and the communication state monitoring routine is continued. On the other hand, when the determination is no, the processing is returned to step S1, and the restarting of communication is attempted from the protocol 1.
When in step S17, it is determined that the communication state is not normal, the step to which the processing is transferred does not need to be fixed to step S1. For example, the diagnosis unit 12 may determine, according to the error that occurs, a return position, that is, from which one of the communication protocols the processing is to be started. Although when communication fails in any one of the communication protocols, the diagnosis processing is completed immediately after the diagnosis routine is executed, there is no limitation to this configuration. For example, when a predetermined number of attempts are performed while the parameters are being changed but communication fails, the processing may be completed.
Although the controller of the machine tool with which the controller 1 communicates and which serves as the external device has been illustrated, as described above, the present embodiment can be applied to systems that are connected to various devices so as to communicate therewith, and a diagnosis program corresponding to the external device serving as the connection destination is provided. For example, the protocols 1 to 5 described above are changed as follows according to the external device.
When the external device is a production management system, the protocol 3 of connection and the protocol 4 of I/O communication are not necessary, and the protocol 5 of communication dedicated to a production management system is provided. When the external device is a line controller, the protocol 5 of communication dedicated to a line controller is provided. When the communication target is only the I/O of the control signal, the protocol 5 is not necessary. When the external device is a robot controller, the protocol 5 of communication dedicated to a robot controller is provided. When the external device is a remote I/O device, the protocol 5 of communication dedicated to a remote I/O device is provided. When the communication target is only the I/O of the control signal, the protocol 5 is not necessary.
According to the present embodiment, it is possible to obtain, for example, the operational effects below.
(1) A controller 1 of an industrial machine which communicates with an external device through a network includes: a plurality of communication units 11 which respectively correspond to a plurality of communication protocols; and a diagnosis unit 12 which starts up the communication units 11 in a predetermined order and attempts communication using the communication protocols corresponding to the communication units 11 that are started up so as to diagnose the conditions of communication step by step.
In this way, in the controller 1, when a plurality of communication protocols can coexist, the communication protocols are shifted step by step from a simple and robust communication protocol which is technically simple and has a long timeout time to a communication protocol which is complicated and prone to communication errors, and in each of the stages, the conditions of communication are diagnosed. Hence, the controller 1 can easily identify the cause of a communication abnormality in a step-by-step manner. Consequently, a burden and time for a manual inspection and a recovery operation are reduced. Since it is possible to collect information with communication protocols that are normally operated, for example, when data communication succeeds but a failure occurs in the subsequent stage, the controller 1 acquires parameters for the external device by data communication so as to be able to efficiently inspect a cause thereof.
(2) In the controller 1 described in (1), when the diagnosis unit 12 has unsuccessful communication using any one of the communication protocols, the diagnosis unit 12 may change the communication parameter so as to attempt communication again.
In this way, the controller 1 changes the communication parameter so as to attempt communication again, and thereby can estimate an appropriate communication parameter. The controller 1 can also correct an error in the communication parameter so as to be able to automatically recover from a communication abnormality.
(3) In the controller 1 described in (2), when the diagnosis unit 12 cannot obtain a reception signal and has unsuccessful communication due to a timeout, the diagnosis unit 12 may extend a time until the timeout with a predetermined threshold value set to an upper limit so as to attempt communication again.
In this way, the controller 1 gradually extends the time until the timeout so as to be able to normally perform communication and set an appropriate time in which the efficiency of communication is high. The controller 1 sets an upper limit for the time capable of being set so as to be able to diagnose whether or not communication can be performed under realistic conditions such as a machining time.
(4) The controller 1 described in any one of (1) to (3) may include a diagnosis recording unit 13 which records the result of the diagnosis by the diagnosis unit 12 together with time information.
In this way, the controller 1 records the result of the diagnosis of a communication abnormality as a log so as to be able to provide information for an inspection to a user and to reduce a burden and time on the identification of a cause thereof and on recovery.
(5) The controller 1 described in any one of (1) to (4) may include an error recording unit 14 which records, together with the time information, the information of the communication protocol used when the diagnosis unit 12 has unsuccessful communication with the external device.
In this way, the controller 1 records, as a log, the information of the communication protocol used when the diagnosis unit 12 has unsuccessful communication so as to be able to provide the rate of occurrence of an error in each of the communication protocols and the like, and thus it can be made useful for diagnosis when an error occurs in the future.
(6) The controller 1 described in any one of (1) to (5) may include a communication recording unit 15 which records, when the diagnosis unit 12 has successful communication with the external device, parameters set in the communication protocols together with the time information.
In this way, the controller 1 records, as a log, the communication parameter used when the diagnosis unit 12 has successful communication so as to be able to provide parameters at which normal communication can be performed and the change history thereof, and thus it can be made useful for diagnosis when an error occurs in the future.
Although an embodiment of the present invention has been described above, the present invention is not limited to the embodiment described above. The effects described in the present embodiment are simply a list of the most preferred effects produced from the present invention, and the effects in the present invention are not limited to those in the present embodiment.
A diagnosis method performed with the controller 1 is realized by software. When the diagnosis method is realized by software, the programs of the software are installed into a computer. These programs may be recorded in removable media so as to be distributed to users or may be distributed by being downloaded into the computers of users through a network.
1 controller
10 control unit
11 communication unit
12 diagnosis unit
13 diagnosis recording unit
14 error recording unit
15 communication recording unit
20 storage unit
Number | Date | Country | Kind |
---|---|---|---|
2019-128347 | Jul 2019 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5839534 | Chakraborty | Nov 1998 | A |
5898828 | Pignolet | Apr 1999 | A |
6108300 | Coile | Aug 2000 | A |
6173422 | Kimura | Jan 2001 | B1 |
6504851 | Abler | Jan 2003 | B1 |
6535855 | Cahill | Mar 2003 | B1 |
6615383 | Talluri | Sep 2003 | B1 |
6622013 | Miyoshi | Sep 2003 | B1 |
7111204 | Couturier | Sep 2006 | B1 |
7206970 | Lauterbach | Apr 2007 | B1 |
7363129 | Barnicle | Apr 2008 | B1 |
7401162 | Baker | Jul 2008 | B2 |
7479714 | Rogers | Jan 2009 | B1 |
7573845 | Harnisch | Aug 2009 | B2 |
7814354 | Tran | Oct 2010 | B2 |
7821930 | Massa | Oct 2010 | B2 |
7864687 | Qian | Jan 2011 | B2 |
7965696 | Takayanagi | Jun 2011 | B2 |
8014378 | Yoon | Sep 2011 | B1 |
8065048 | Bertosa | Nov 2011 | B2 |
8175099 | Hodges | May 2012 | B2 |
8504123 | Choi | Aug 2013 | B1 |
8566630 | Westerfield | Oct 2013 | B2 |
8694829 | Tanaka | Apr 2014 | B2 |
9544754 | Lambert | Jan 2017 | B1 |
9639553 | Hall | May 2017 | B2 |
9712688 | Pawlowski | Jul 2017 | B2 |
9734119 | Chetverikov | Aug 2017 | B1 |
10085161 | Oroskar | Sep 2018 | B1 |
10118421 | Teets | Nov 2018 | B2 |
10263869 | Dzierwinski | Apr 2019 | B1 |
10306490 | Ratakonda | May 2019 | B2 |
20020091815 | Anderson | Jul 2002 | A1 |
20020105972 | Richter | Aug 2002 | A1 |
20020107971 | Bailey | Aug 2002 | A1 |
20020194547 | Christensen | Dec 2002 | A1 |
20030167238 | Zeif | Sep 2003 | A1 |
20030236837 | Johnson | Dec 2003 | A1 |
20050188260 | First | Aug 2005 | A1 |
20060146826 | Namihira | Jul 2006 | A1 |
20060168467 | Couturier | Jul 2006 | A1 |
20070011326 | Ohara | Jan 2007 | A1 |
20070076625 | Tahara | Apr 2007 | A1 |
20080013475 | Bandou | Jan 2008 | A1 |
20080070569 | Shelley | Mar 2008 | A1 |
20080170569 | Garg | Jul 2008 | A1 |
20090016720 | Lu | Jan 2009 | A1 |
20090024757 | Proctor | Jan 2009 | A1 |
20090046723 | Rahman | Feb 2009 | A1 |
20090112398 | Wempen | Apr 2009 | A1 |
20090170461 | Kwon | Jul 2009 | A1 |
20100070661 | Cherry | Mar 2010 | A1 |
20100080219 | Watanabe | Apr 2010 | A1 |
20100125749 | Tanaka | May 2010 | A1 |
20100169717 | Sonoda | Jul 2010 | A1 |
20100191992 | Shen | Jul 2010 | A1 |
20100305723 | Koyama | Dec 2010 | A1 |
20110084815 | Fitzek | Apr 2011 | A1 |
20110164595 | So | Jul 2011 | A1 |
20110172842 | Makhota | Jul 2011 | A1 |
20110302350 | Hsu | Dec 2011 | A1 |
20110320015 | Yun | Dec 2011 | A1 |
20120017105 | Thyni | Jan 2012 | A1 |
20120062356 | Mann | Mar 2012 | A1 |
20120079302 | Ise | Mar 2012 | A1 |
20130013966 | Nakamoto | Jan 2013 | A1 |
20140101747 | Lu | Apr 2014 | A1 |
20140115210 | Chirca | Apr 2014 | A1 |
20140275861 | Kroh | Sep 2014 | A1 |
20150067434 | Kamijyo | Mar 2015 | A1 |
20150171642 | Kato | Jun 2015 | A1 |
20150200825 | Jang | Jul 2015 | A1 |
20150254909 | Harata | Sep 2015 | A1 |
20160127308 | Yu | May 2016 | A1 |
20160171791 | Cervantes | Jun 2016 | A1 |
20160357626 | Kim | Dec 2016 | A1 |
20170017587 | West | Jan 2017 | A1 |
20170136992 | Hamada | May 2017 | A1 |
20170180486 | Mehta | Jun 2017 | A1 |
20170214567 | Salkintzis | Jul 2017 | A1 |
20170318184 | Suzuki | Nov 2017 | A1 |
20170332327 | Fang | Nov 2017 | A1 |
20180047013 | Hayek | Feb 2018 | A1 |
20180109982 | Zheng | Apr 2018 | A1 |
20180179021 | Uchida | Jun 2018 | A1 |
20180213475 | Zhang | Jul 2018 | A1 |
20180242249 | Yang | Aug 2018 | A1 |
20180309590 | Beckmann | Oct 2018 | A1 |
20190097428 | Goi | Mar 2019 | A1 |
20190171187 | Cella | Jun 2019 | A1 |
20190182698 | Park | Jun 2019 | A1 |
20210362194 | Lundahl | Nov 2021 | A1 |
20220022009 | Toillon | Jan 2022 | A1 |
20220046677 | Talarico | Feb 2022 | A1 |
20220078879 | Nimbalker | Mar 2022 | A1 |
Number | Date | Country |
---|---|---|
106681945 | May 2017 | CN |
2002-324014 | Nov 2002 | JP |
2006-277733 | Oct 2006 | JP |
2010-064158 | Mar 2010 | JP |
6481248 | Mar 2019 | JP |
Number | Date | Country | |
---|---|---|---|
20210011792 A1 | Jan 2021 | US |