US 6895572 B2
A sensor system is formed with sensors and a controller which are detachably attached to a network to be connected together. Each sensor stores an interface program for its own and the controller serves to upload these interface programs from the individual sensors and use the uploaded interface programs to access these sensors under optimum conditions.
1. A sensor, which is connectable to a network, said sensor comprising:
a sensor head;
a signal processing part that processes signals inputted from said sensor head;
a communication control part that is used by a controller for communicating with said sensor by a general-purpose access;
an interface memory area that stores an interface program used by said controller when accessing by an access routine particular to said sensor;
a load controller that uploads said interface program to said controller in response to a request from said controller; and
a configuration manager that carries out initialization of said signal processing part according to said interface program in response to an initialization request from said controller.
2. The sensor of
3. The sensor of
4. The sensor of
5. The sensor of
6. The sensor of
7. The sensor of
8. The sensor of
This invention relates to sensors, as well as controllers and sensor systems including such sensors and controllers.
For effecting controls of different kinds, say, in an FA system, it has been known to connect sensors to a PLC, to transmit control commands to a target apparatus intended to be controlled by the PLC and to thereby effect controls such as coordination and synchronization. More recently, sensors with signal processing functions are being developed. Such a sensor is connected downstream to a controller through a device net and this controller is connected to the target apparatus through a network such as Ethernet such that control commands are given to the target apparatus through the network on the basis of information from the sensor.
When an application program of a controller thus structured accesses sensor data or a set parameter, it is necessary for the application program to recognize the physical address (such as the address of a data port) of the sensor. A driver for making such an access, however, must be set according to the access model routine, the register model of the sensor and the contents of the functions. As multi-functional sensors are developed, it becomes necessary as a practical matter to provide a driver intrinsic to each sensor. Thus, the common practice has been to provide and incorporate drivers (intrinsic device information) in the application program for each of the sensors connected.
There are countless combinations of sensors and controllers, however, and it is difficult to preliminarily incorporate drivers for all sensors in a controller. When an external device is connected to a personal computer and a driver for this external device is required, on the other hand, it is possible to attach a recording medium such as an FD storing such a driver and install this FD in the personal computer. Since most controllers which are connected to a PLC or a sensor of another kind through a network, are not provided with a driving device for reading from a recording medium, they cannot be directly made use of.
It may also be attempted to connect onto the network a host computer with a driver device capable of reading from a recording medium, to temporarily store the driver intrinsic to the sensor through a recording medium storing the aforementioned driver on the host computer and to download this driver to the controller through the network. It is very cumbersome, however, to go through these steps every time a sensor is replaced. Since the sensor, the controller and the host are often set mutually far apart, furthermore, it makes it even more troublesome to move to each of the localities to carry out these required steps.
It is therefore an object of this invention in view of the above to provide sensors, controllers and sensor systems such that data which are intrinsic to a sensor for carrying out communications between the sensor and a controller can be set to the controller by connecting the sensor and the controller through a network.
A sensor embodying this invention is disconnectably connectable to a network and is characterized as comprising memory means for storing an interface program for its own use and means for outputting the interface program stored in the memory means to the network.
A controller embodying this invention is disconnectably connectable to a network and is characterized as comprising uploading means for uploading an interface program for a sensor transmitted from the sensor through the network and accessing means for accessing the sensor by executing the uploaded interface program.
A sensor system embodying this invention is characterized as comprising a sensor and a controller as described above and connected together through a network and wherein the controller uploads from the sensor an interface program for that sensor and accesses the sensor by using the acquired interface program.
Interface programs are different for different sensors. According to this invention, each of these different interface programs are stored in corresponding one of these different sensors and the controller obtains these interface programs by its uploading capability. Thereafter, the controller accesses the sensors by using the uploaded interface programs. In other words, the controller is not required to be preliminarily provided with interface programs of many sensors because, when a new sensor system is formed, the interface programs for the sensors which are to be included in the sensor system can be obtained from these sensors, and the controller can thus access these sensors under optimum environmental conditions.
Throughout herein, like components are indicated by the same numeral even if they are components of different devices and may not necessarily be explained repetitiously.
Explained briefly, each sensor 10 includes a network interface (communication control part) 16 for a general-purpose access by the controller 20 and is provided with a program (interface program) which can execute an intrinsic access routine on the controller 20. Before an actual operation is started with each sensor 10 connected to the controller 20 through the network 30, each sensor 10 receives a request from the controller 20 and uploads to the controller 20 the interface program stored therein. This enables the controller 20 to use these uploaded interface programs to transmit and receive necessary data for carrying out ordinary sensing processes to and from the sensors 10.
As shown in
Outputted signals from the signal input part 12 (the A/D converter 12 a) are received by a signal processing part 14 adapted to carry out a specified signal processing (sensing signal processing) process on the data digitized through the signal input part 12. This is carried out while a signal processing circuit 14 a uses a work memory area 14 b (RAM) and the program for carrying out this process is stored in a program memory area 14 c. The signal processing part 14 may comprise a 16-bit microcomputer, depending on the purpose of use. Different signal processing programs including conventionally known programs may be used, and hence no detailed explanation will be presented.
Data outputted from the signal processing part 14 are transmitted to a data transmission circuit 16 a of a communication control part 16 and then through the network 30 to an upper device (controller 20). The communication control part 16 includes a data receiving circuit 16 b for receiving data of all sorts transmitted from the controller 20. This communication control part 16 has the functions of a network interface.
The sensor 10 further includes an interface memory area 17 for storing an interface program of its own, that is, an intrinsic program for carrying out on the controller an intrinsic access routine. This interface memory area 17 is connected to the communication control part 16 such that the interface program stored in the memory area 17 can be transmitted to the network 30 and further to the controller 20.
The controller 20 is provided with a runtime environment for plotform-independent programs such as Java and includes, as shown in
The controller 20 also has a memory area 22 for storing physical addresses of sensors which may become necessary when accessing data in these sensors as well as set parameters while the program running part 21 is executing an application program (such as the address of a data port) or interface programs describing the sequence of execution. Interface programs intrinsic to the sensors under its control are stored in this memory area 22.
Between the interface programs stored in the memory area 22 and the application program is a common application interface (common API) 23. Since this common application interface 23 serves to absorb the differences in the handling of the interface programs for the sensors, the interface programs of all these sensors will appear alike when seen therethrough from the side of the application program. In other words, the function of the common application interface 23 is to allow the application program to access the sensors by a common routine. Accordingly, the application program accesses the interface programs of the sensors by using a common application program defined by interface class. Thus, the application program can access all of the sensors 10 through the common application interface 23 without regard to the kinds of the sensors 10. Uploading and downloading of the interface program to and from this memory area 22 are carried out by a load controller 25 under the control of a system configuration manager 26.
Next, a request for initialization is issued to the sensor 10 according to the uploaded interface program for that sensor (Step ST5) and, if a signal is received from the sensor to the effect that the initialization has been completed, an operation based on the ordinary routine is started (Step ST6). If it is determined in Step ST2 that the sensor is not one according to this invention, the sensor's intrinsic information is manually registered (Step ST4) and a request for sensor initialization is made thereafter according to the registered data (ST5). Step ST2 is included because there are all sorts of sensors and it cannot be expected that only sensors provided with an interface program according to this invention are connected. Step ST2 makes it possible for the system to operate even if sensors not according to this invention are connected.
Operations on the side of the sensor 10 are explained next with reference to the flowchart of FIG. 5. When a read access to the sensor ID is received from the controller 20, the sensor 10 responds to it by transmitting its own ID to the controller 20 (Step ST11). It then waits for a request from the controller 20 and uploads the interface program for itself stored in the interface program memory area 17 to the controller 20 through the network 30 (Step ST12). When the uploading has been completed and there is a request for initialization from the controller, this request is complied with and the sensor is initialized (Step ST13), that is, the parameters for configuration data are adjusted and set at optimum values. Explained more in detail, this may include the adjustment of the sensitivity of the A/D converter 12 a and signal processing carried out by the signal processing circuit 14 a such as the adjustment of tuning parameters including threshold values for judgments, statistical data such as data distribution for satisfactory and defective products and operational data such as input sampling periods and output format. When the sensor initialization has been completed, a signal indicative thereof is transmitted and actual operations (or the execution of signal processing under the initialized condition) are carried out (Step ST14).
With the system thus structured, as soon as the connection between a sensor 10 and the controller 20 is established, the controller 20 can upload from the connected sensor 10 its intrinsic interface program and start up by incorporating it into its own interface block (the memory area 22). Since the controller 20 is thus capable of obtaining the interface programs of target sensors 10 to communicate with, it can have, without regard to the kinds of the sensors 10 to be connected and without requiring any special database, an interface function which is optimum to sensors of all kinds. As for the sensors 10, they each have an interface program suited to itself and can transmit and receive data by using this interface program by uploading it to the controller 20. Thus, they can be accessed from controllers of all kinds through an optimum interface without requiring any special resources or agreements.
Constructor (or “Method #1”): To instantiate as a program and to initialize a sensor;
Destructor (or “Method #2”): To cancel instantiation of a program and to disable the access to a sensor by carrying out a post-treatment on the sensor;
Call General Purpose Routine (or “Method #3”): To specify detailed commands to a sensor and parameters and to receive the results of the process;
Processing intrinsic to sensor: (or Method #4): To store addresses and access routine for carrying out “Read Output Data” (or “Program READ”) and “Set Threshold Parameter” (or Program SET”) and to carry them out by receiving “Call General Purpose Routine”.
As described above, the controller 20 stores as a common application interface a general purpose format as an interface program and forms interface programs intrinsic to the individual sensors by overriding with data uploaded from the sensor 10 (“Read output data” and “Set threshold parameter”). Although not shown in the drawing, the controller 20 is also provided with a system configuration manager 26 and a load controller 25 (as shown in FIG. 3). Operations of the system configuration manager 26 are shown in FIG. 7. As can be understood by comparing it with the flowchart of
Another way to interpret may be that the interface program is wholly stored in the controller according to the first embodiment while a kind of template of the interface program is prepared in the controller 20 and an interface program for the sensor is generated by uploading a portion of its position from the sensor and overriding the corresponding position of this template (replacing by a function).
According to this embodiment, the interface programs and the conditions optimized by configuration (configuration data) are stored in the individual memory means such that the system can be set in the optimum condition as stored at the time of rebooting with the same system configuration without carrying out the sensor initialization (such as the tuning). Thus, it becomes easier to speed up the operations, to remove and exchange apparatus and to investigate the causes of an abnormal situation when it occurs.
As shown in
As shown in
Although an example with the interface program memory 27 formed inside the controller 20 has been shown, this is not intended to limit the scope of the invention. It goes without saying that an external memory device may be connected to the controller 20 and the interface program may be stored in such an external memory device. In either case, optimized configuration data may thus be stored in addition to the interface program.
The operations of the system configuration manager of the controller 20 is shown in
If it is determined that there has been a change in the system configuration, the program advances from Step ST22 to Step ST24 to issue a notice of configuration change to this sensor and waits for a response. When the receipt acknowledgment is received, it is determined whether the sensor is one according to this invention (ST25), as explained with reference to
As shown in
If it is acknowledged in Step ST 33 that there was no change in the system configuration, the configuration data stored in the configuration memory area 18 of the sensor 10 are loaded in a corresponding variable number area (Step ST34) and the operation is started (ST37). If there has been a change in the system configuration, on the other hand, there is a request for an upload from the controller 20 and the interface program stored in the interface program memory area 17 is uploaded in response (Step ST35). If this upload is successful, there is a request for sensor initialization and the sensor initialization such as tuning is carried out in response to the request. When this is completed, a signal to this effect is transmitted (Step ST36) and the operation is started thereafter (Step ST37).
As shown schematically in
As shown in
In this embodiment, too, as explained with reference to the third embodiment of the invention, a memory device may be provided either internally or externally and the externally provided memory device may be used only for the storage of the interface program instead of storing both the interface program and the configuration data.
Thus, unless the system configuration is changed, it is possible to set the system in the stored optimum condition at the time of a start-up without going through the sensor initialization process such as the tuning.
When the sensor is disconnected from the system, the interface program stored in the external memory device 27′ on the side of the controller is downloaded preliminarily back to the sensor, thereby returning to the sensor 10 disconnected from the network 30 the interface program for that sensor 10. If this were not done, the sensor 10 would no longer have its interface program.
In summary, this invention is characterized in that the interface program intrinsic to a sensor is stored in the sensor itself such that a controller, when it is connected to the sensor through a network, can access the sensor in an optimum environment by uploading this interface program from the sensor. Since this uploading operation has only to be carried out at the actual time of making the connection, there is no need to preliminarily provide the controller with data on the individual sensors to be connected. This improves the use efficiency of the memory areas, especially when sensors of new versions are introduced. Moreover, the interface programs can be downloaded easily through the network.