This application is a National Stage of International Application No. PCT/JP2013/075716 filed Sep. 24, 2013, the contents of which are incorporated herein by reference in their entirety.
The present invention relates to a programmable controller and a control method of the programmable controller that enables easy construction and management of an automatic machine by automatically providing a device driver required for operation to a device connected to a network.
To construct automatic machines in general as listed below, controllers such as a PLC (Programmable Logic Controller) or a motion controller are used.
In such controllers, various types of input devices such as sensors and switches for inputting signals to the controller are connected. Similarly, various types of output devices such as motors and displays controlled by the controller are connected. Further, a program that describes commands (instructions) to those input and output devices is installed in the controller. The automated machine operates as the commands (instructions) described in the program are transmitted to the input and output devices.
The above input and output devices are respectively connected to input and output connectors of the controller (that is, input and output ports). In a case of using a conventional controller, a program creator needed to accurately grasp which types of input and output devices are (were) connected to which of the input and output ports (order numbers thereof) of the controller. Settings of software modules and operation programs for the device to be used in the controller were accurately performed with such prerequisite. Without doing so, the controller cannot otherwise perform accurate control by sending appropriate commands (instructions) to the device. Notably, the software modules for the device include a device driver, for example.
Conventionally, to construct and manage a system for an automatic machine, a programmable controller and various types of devices (sensor, vision sensor, robot, servo motor, inverter, and the like) need to be connected to each other, and device drivers for controlling them needs to be provided in the programmable controller and the various types of devices. Due to this, work such as connection of the various types of devices, setting installation for the various types of devices and the programmable controller, and reactivation upon a trouble occurrence is performed by a worker at an operation site of the system of the automatic machine, however, with increased numbers of the various types of devices, work cost incurred for the setup and reactivation upon the trouble occurrence increases.
As a method to reduce the work cost upon constructing the system, an invention that utilizes a plug-and-play function, which is a mechanism that allows a connected device represented by a USB or IEEE1394 to be used without having a user perform any special setting, to the programmable controller has been devised. A GUID (Global Unique Identifier) is an identifier that is capable of uniquely identifying a device without any overlap worldwide, and Patent Literature 1 discloses a technique in which the GUID of the connected device is collected, and a device driver, which is a collection of software modules and setting information such as device parameters required for the device identified by the collected GUID, is automatically linked and made available.
Patent Literature 1: JP 2002-7299 A
However, the automatic link of the device driver in Patent Literature 1 as above cannot be said as automatically creating the link under a specific situation, but rather is on the premise that the user performs operation therefor.
For example, since some devices are capable of performing plurality of devices, a software module that is suitable for the execution within the programmable controller would be different depending on the function to be used; thus, a plurality of software modules needs to be provided.
In Patent Literature 1, a determination on the software module to be used upon when the aforementioned plurality of software modules is available to a specific device is performed manually by humans using a GUI. That is, in a case where a plurality of device drivers is available in the conventional programmable controller, the operation by the user was the prerequisite. Due to this, there has been a problem that cost for activation increases with larger-sized systems.
The present invention has been made in view of the above, and it is an object of the present invention to achieve a programmable controller that realizes plug-and-play of a connected device by enabling automatic link of a device driver, even in a case where there is a plurality of software module candidates for identifying the device driver to be linked.
To solve the above problem and achieve the object a programmable controller according to the present invention is connected to a device as a controlled object via a network, the programmable controller includes: a control unit that requests the device to notify an identifier of the device and mode information via the network, the mode information defining a function to be utilized by the device and an operation method of the device; and a storage unit that stores the identifier and the mode information that the device notified via the network in response to the request.
The programmable controller according to the present invention achieves the effects that devices become available simply by connecting them by a plug-and-play function, system construction by the user becomes easy, and cost incurred for the system activation is reduced.
Hereinbelow, an embodiment of a programmable controller and a control method of the programmable controller according to the present invention will be described in detail with reference to the drawings. Notably, the invention is not to be limited by the embodiment.
In
Next, with what sort of process a plug-and-play function is realized in the programmable controller 10 according to the present embodiment will be described.
Firstly, the devices 21, 22, and 23 connected to the network 30 notify the programmable controller 10 of their GUIDs being the identifiers and mode information. Then, the programmable controller 10 stores the notified GUIDs being the identifiers and the mode information in the storage unit 71 in
Next, the programmable controller 10 uniquely acquires the device driver from the database server 40 based on the GUIDs being the identifiers and the mode information that were notified and stored in the storage unit 71 (step S2). The database server 40 retains data of device drivers corresponding to various devices, and each device driver includes one or more software modules that control the connected device. The programmable controller 10 can uniquely identify the software module based on the mode information that defines the function and operation method utilized by the device connected to the network 30 from among the software modules included in each device driver. Thus, the operation by humans, which had conventionally been necessary, can be eliminated from the connection of the device until when the device is brought to be available.
The software modules included in the acquired device driver and selected based on the mode information are stored in the program memory 51. Further, an I/O memory area for a control purpose is allotted in the link memory 50 in the programmable controller 10 for each of the software modules stored in the program memory 51. Due to this, the software modules corresponding respectively to the devices 21, 22, and 23 are set in an executable state in the programmable controller 10 (step S3). Notably, since plural functions can be executed depending on the device, the suitable software module for execution in the programmable controller 10 may differ depending on the function to be used; thus, a plurality of software modules needs to be provided. That is, a plurality of software modules stored in the program memory 51 may exist for one device. Even in such a case, the I/O memory area is allotted in the link memory 50 for each of the software modules.
Further, in a case where setting information such as device parameters necessary for the devices 21, 22, and 23 exists in the device driver, such is transmitted to the devices 21, 22, and 23 via the network 30, and the connected devices 21, 22, and 23 become available (step S4). That is, the plug-and-play of the devices 21, 22, and 23 is realized.
Timing and method of notification from the devices 21, 22, and 23 to the programmable controller 10 in step S1 of
The devices 21, 22, and 23 have a link-completed state as a state in which the device driver has been linked. If the devices 21, 22, and 23 are not in the link-completed state, a notification of their GUID and mode information is performed in a case where a connection to the network 30 is detected, or in a case where a notification request from the programmable controller 10 is received.
Further, the devices 21, 22, and 23 stop the notification of their GUID and mode information via the network 30 at a time point when they are in the link-completed state, and do not perform the notification even when the notification request from the programmable controller 10 is received.
In a case of having detected its connection to the network 30, the programmable controller 10 sends the notification request to all of the devices connected to the control unit 70 via the network 30, which are in the example of
Then, a determination is made on whether or not a notification from one or more devices has been received (step S12). In a case of having received the notification from one or more devices (step S12: Yes), the series of process illustrated in the flow chart of
Further, in a case where the notification from the devices cannot be received (step S12: No), a standby state is commenced and thus no action is taken, and the process returns to step S12.
After the step S13, a determination is made on whether or not all of the notified devices have been made available (step S14). The step S13 (procedures in
In a case where all of the notified devices become available (step S14: Yes), that is, after when the programmable controller 10 has performed the plug-and-play process to all of the notified devices, the process returns to step S11, and the control unit 70 of the programmable controller 10 restarts to send notification requests to the devices via the network 30 by controlling the communication controller 60.
In the present embodiment, after all of the notified devices become available (step S14: Yes), the programmable controller 10 once again sends the notification requests to the devices via the network 30 (step S11). Thus, the device connections can be detected even with frequent situations where a large number of devices is to be connected, and in cases where the notification receipt from other devices has failed.
By the above detection method, as compared to a method that repeats the notification requests periodically to an entirety of the network 30 so as to confirm whether a newly connected device exists or not, a load on the network 30 in connection to device detection can be reduced.
Further, the notification timings of the GUID being the identifier and the mode information from devices may be staggered so as to disperse the load on the network 30.
The allotment of the I/O memory areas for linking purposes in the step S3 of
In the allotment of the I/O memory areas in the step S3, an I/O memory file having a file content of I/O information for controlling a device is allotted to the link memory 50 being the memory area dedicated to each device. However, the link memory 50 is managed by a generally available file system, and the I/O memory files are managed in file units via the file system controller 61.
As an operation during the plug-and-play execution, firstly, the I/O memory file having the file content of I/O memory is created in the link memory 50 in the programmable controller 10 (
Subsequently, the software modules that operate on the programmable controller 10 and included in the device driver acquired from the database server 40 in the step S2 in
As illustrated in
A file name of the I/O memory file created in the step S3 of
The memory to be allotted to the device to be connected to the automatic machine system would have increased management cost with increased system size, so the link-purposed I/O memory can easily be managed by managing the I/O memory as a file, as in the present embodiment.
In addition, effects of improved convenience to utilize functions such as monitoring and logging in device units can be expected.
With the allotment of the I/O memory areas and the linking of the software modules of the device drivers corresponding to the devices 21, 22, and 23 in the step S3, for example, when a control-purposed software module (device 21) for the device 21 is to be executed, the program execution unit 62 refers to data in the I/O memory file (device 21) allotted via the file system controller 61. In a case where a modification request to the I/O memory file (device 21) is occurring after the execution of the control-purposed software module (device 21) for the device 21 is completed, the content thereof is written back via the file system controller 61. Notably, the program execution unit 62 may for example execute a device control-purposed software module with a communication from this device as a trigger.
As described above, in the programmable controller and the control method of the programmable controller according to the present embodiment, the mode information for identifying the utilized function and operation method of a device is provided among the information to be collected from the device, and is collected together with the GUID. Thus, the software module can uniquely be identified even in cases where there is a plurality of software module candidates for identifying the device driver to be linked, based on the mode information that defines the utilized function and operation method of the device. Thus, the plug-and-play function can be provided without needing any manual operation by humans, aside from the physical connection of the device to the network.
Moreover, the invention of the present application is not limited to the above embodiment, and in carrying out the invention, various modifications may be made within the scope that does not go beyond the essence thereof. Further, the above embodiment includes inventions of various levels, and numbers of inventions may be extracted therefrom by suitable combinations of the disclosed plurality of constituent features. For example, even if some of the constituent features are omitted from the entire set of constituent features shown in the embodiment, the configuration with said constituent features omitted may be extracted as an invention, if the problem described in the section of the technical problem can be solved, and the effect described in the section of the advantageous effects of the invention can be achieved. Furthermore, constituent features among different embodiments may suitably be combined.
As above, the programmable controller according to the present invention is useful in a programmable controller installed with the plug-and-play function suitable for system construction, and especially is suitable for the construction of automatic machines.
10 PROGRAMMABLE CONTROLLER
21, 22, 23 DEVICE
30 NETWORK
40 DATABASE SERVER
50 LINK MEMORY
51 PROGRAM MEMORY
60 COMMUNICATION CONTROLLER
61 FILE SYSTEM CONTROLLER
62 PROGRAM EXECUTION UNIT
70 CONTROL UNIT
71 STORAGE UNIT
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2013/075716 | 9/24/2013 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2015/045004 | 4/2/2015 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4138718 | Toke et al. | Feb 1979 | A |
5675830 | Satula | Oct 1997 | A |
6148349 | Chow | Nov 2000 | A |
7130701 | Wischinski | Oct 2006 | B1 |
7945340 | Ueno et al. | May 2011 | B2 |
8165699 | Ueno et al. | Apr 2012 | B2 |
8307093 | Klemets | Nov 2012 | B2 |
20010056306 | Nakai et al. | Dec 2001 | A1 |
20020133240 | Nagao et al. | Sep 2002 | A1 |
20030144997 | Hugley | Jul 2003 | A1 |
20060064385 | Susnjara | Mar 2006 | A1 |
20060253626 | Ueno et al. | Nov 2006 | A1 |
20090147309 | Nagashima | Jun 2009 | A1 |
20090327496 | Klemets | Dec 2009 | A1 |
20110004685 | De Groot et al. | Jan 2011 | A1 |
20110007906 | Konchitsky et al. | Jan 2011 | A1 |
20110245936 | Hermann et al. | Oct 2011 | A1 |
20130218302 | Leinen et al. | Aug 2013 | A1 |
Number | Date | Country |
---|---|---|
1834833 | Sep 2006 | CN |
1920712 | Feb 2007 | CN |
103081412 | May 2013 | CN |
11-265280 | Sep 1999 | JP |
2000-163259 | Jun 2000 | JP |
2002-7299 | Jan 2002 | JP |
2002-269024 | Sep 2002 | JP |
2005-158026 | Jun 2005 | JP |
2007-536648 | Dec 2007 | JP |
2009-93258 | Apr 2009 | JP |
2009-145970 | Jul 2009 | JP |
2011-198237 | Oct 2011 | JP |
2012-519338 | Aug 2012 | JP |
2005109131 | Nov 2005 | WO |
Entry |
---|
Communication dated Oct. 9, 2017, from the European Patent Office in counterpart European Application No. 13894543.1. |
Communication dated Nov. 9, 2016 from the European Patent Office in counterpart application No. 13894543.1. |
Communication dated Oct. 31, 2016 from the State Intellectual Property Office of the P.R.C. in counterpart application No. 201380079753.X. |
Communication dated Dec. 3, 2015, issued by the Taiwan Patent Office in corresponding Taiwanese Application No. 103101563. |
Communication dated Aug. 2, 2017 from the State Intellectual Property Office of the P.R.C. in counterpart application No. 201380079753.X. |
Taiwanese Search Report for TW 103101563 dated Apr. 15, 2015. |
International Search Report for PCT/JP2013/075716 dated Oct. 22, 2013. |
Number | Date | Country | |
---|---|---|---|
20160209823 A1 | Jul 2016 | US |