The present disclosure relates to a data collection apparatus, a data collection method, and a program.
Production, inspection, and various other processes performed at facilities, typically factories, commonly involve processing of data collected in real time from the facilities (see, for example, Patent Literature 1).
Patent Literature 1 describes a data collection apparatus that collects data from programmable logic controllers (PLCs) through a control network and transmits the collected data to a host computer through an information network. This apparatus allows data collected from the PLCs to be processed at the host computer.
Patent Literature 1: Unexamined Japanese Patent Application Publication No. 2007-80286
When collecting data output from devices through different networks, the apparatus may use different collection processes designed specifically for different networks or devices as data collection targets. The collection processes are defined using different types of parameters with different allowable ranges depending on types of the networks or devices as collection targets. The data collection apparatus may include an interface for receiving such parameters to avoid any complicated workload for the user referring to the specifications of each collection target for setting parameters with the apparatus in designing a collection process for each collection target.
For user convenience, the apparatus may have a common setting tool as a user interface for setting parameters for multiple collection targets. A common setting tool may have predefined parameter configurations for collection targets and may have an interface prepared for receiving input of parameters for each data collection target.
As described above, the types of parameters to be set and the conditions to be satisfied by the parameters are different for different collection targets. A parameter input as a setting value for a collection target is to be determined as to whether the parameter satisfies the condition for the collection target. However, the condition to be satisfied by the parameter may include a logic specific to the collection target. For example, for a new collection target to be added, the setting tool cannot preinstall an interface that can determine whether the parameter satisfies the condition. Thus, the data collection apparatus cannot easily incorporate the function of collecting data from a new collection target.
In response to the above issue, an objective of the present disclosure is to enable an apparatus for data collection to easily incorporate a function of collecting data from a new collection target.
To achieve the above objective, a data collection apparatus according to an aspect of the present disclosure is connectable to a device. The data collection apparatus includes setting means for receiving and setting a parameter for data collection, collection means for collecting data from the device in accordance with the parameter set by the setting means, and control means for outputting the data collected by the collection means to processing means to cause the processing means to process the data. The collection means determines whether the parameter received by the setting means satisfies a predetermined condition and provides a determination result to the setting means. The setting means outputs result information corresponding to the determination result provided by the collection means.
In the data collection apparatus according to the above aspect of the present disclosure, the collection means for collecting data determines whether a parameter satisfies a predetermined condition and provides the determination result to the setting means. The setting means outputs result information corresponding to the determination result. Thus, the setting means receiving the parameter outputs result information based on the determination result without determining whether the parameter satisfies the condition. When any new data collection target is added, the collection means is changed or added for the new collection target without the setting means being changed. Thus, the data collection apparatus can easily incorporate a function of collecting data from a new collection target.
A data collection apparatus 10 according to embodiments of the present disclosure will now be described in detail with reference to the drawings.
The data collection apparatus 10 according to the present embodiment is, for example, an industrial personal computer (IPC) installed at a factory. As shown in
As shown in
The processor 11 includes a central processing unit (CPU). The processor 11 executes a program P1 stored in the auxiliary memory 13 to implement the various functions of the data collection apparatus 10 and perform the processing described later.
The main memory 12 includes a random-access memory (RAM). The main memory 12 stores the program P1 loaded from the auxiliary memory 13. The main memory 12 is used as a work area by the processor 11.
The auxiliary memory 13 includes a non-volatile memory, typically an electrically erasable programmable read-only memory (EEPROM) and a hard disk drive (HDD). The auxiliary memory 13 stores, in addition to the program P1, various data items used in the processing performed by the processor 11. The auxiliary memory 13 provides data usable by the processor 11 to the processor 11 as instructed by the processor 11, and stores data provided by the processor 11. Although
The input unit 14 includes input devices, typically input keys and a pointing device. The input unit 14 acquires information input by the user of the data collection apparatus 10 and provides the acquired information to the processor 11.
The output unit 15 includes output devices, typically a liquid crystal display (LCD) and a speaker. The output unit 15 presents various items of information to the user as instructed by the processor 11.
The communicator 16 includes a network interface circuit for communicating with external devices. The communicator 16 receives a signal from an external device and outputs data carried by the signal to the processor 11. The communicator 16 also transmits a signal carrying data output from the processor 11 to an external device.
With the hardware components shown in
The process sequence 300 includes subprocesses that are sequentially performed on data output from the device 21. In detail, the process sequence 300 includes the subprocess 30 for collecting data to undergo the process sequence 300, the subprocesses 31 to 33, and the subprocess 34 for outputting data indicating the result of the process sequence 300 that are performed in this order. The arrows in
The subprocess 30 corresponds to a process for receiving a signal from the device 21 through the network 20 shown in
The subprocesses 31 to 33 are performed repeatedly as the subprocess 30 is performed. For example, the subprocess 31 calculates a moving average, the subprocess 32 determines whether the value to be processed exceeds a predetermined threshold, and the subprocess 33 determines the details of a control instruction for the device 22 in
The subprocesses 31 to 33 are not limited to the above processes. For example, the subprocesses 31 to 33 may be rounding or normalization for converting a value to fall within a predetermined range, scaling for multiplying an input value by a predetermined constant, shifting for adding a predetermined offset value to an input value, filtering or statistical processing other than calculating a moving average, or transformation, typically a fast Fourier transform (FFT). The subprocesses 31 to 33 may be any other manipulation or diagnosis, or any other processes.
The subprocess 34 corresponds to transmission of the processing result of the subprocess 33 to the device 22 through the network 20 shown in
The subprocesses 30 to 34 are performed in series on repeatedly input data. For example, the subprocesses 30 to 34 are sequentially performed on first data collected from the device 21, and are sequentially performed on second data collected next. The subprocesses 30 to 34 are performed on the first data and the second data in parallel. In other words, a process sequence on the second data starts before the completion of the process sequence on the first data. However, the process sequences may be performed in series rather than in parallel. Although
The data collection apparatus 10 includes the functional components as shown in
The processing units 131 to 133 are implemented mainly by the processor 11 and the main memory 12 operating in cooperation, and perform the subprocesses 31 to 33. In detail, each of the processing units 131 to 133 is implemented by the processor 11 running a software module stored in the auxiliary memory 13. The software module may be plug-in software stored in the auxiliary memory 13 by the user. The plug-in software may be designed, purchased, or acquired as open-source software by the user. The processing units 131 to 133 are hereafter collectively referred to as processing units 130. The processing units 130 are examples of processing means for processing data in the data collection apparatus 10.
The processing units 130 may not correspond one-to-one to the subprocesses included in the process sequence 300 shown in
The implementation controller 140 is implemented mainly by the processor 11, the main memory 12, and the communicator 16 operating in cooperation. The implementation controller 140 receives the setting of a process sequence from the input device 101. The implementation controller 140 relays data between a processing unit 130 and another processing unit 130 and between a processing unit 130 and the collector 160. The implementation controller 140 thus causes the processing units 130 and the collector 160 to perform subprocesses in the order corresponding to the set process sequence. The implementation controller 140 includes a process setting unit 141 for receiving, from the input device 101, a parameter that defines a process sequence to set the received parameter, a storage 142 for storing various items of information including the setting of a process sequence, and a process controller 143 for determining a subprocess to be performed on data based on the setting of the process sequence to control the data sequence.
The process setting unit 141 exchanges information with the input device 101 to allow the input device 101 to serve as a graphical user interface (GUI). In detail, the process setting unit 141 provides data to the input device 101 to display an input screen for receiving input of the setting of a process sequence. The process setting unit 141 thus acquires from the input device 101 a setting input into the input screen. In more detail, the process setting unit 141 acquires configuration information for creating an input screen from the collector 160 and provides the configuration information to the input device 101. The configuration information includes, for example, the types and sizes of objects to appear on an input screen, character strings to appear on an input screen, and information defining the transition of an input screen. The input device 101 creates an input screen for display based on the configuration information. The process setting unit 141 also receives from the input device 101 a parameter input into the input device 101 by the user. The parameter includes values for data collection defining, for example, the types, the implementation order, and the details of subprocesses included in a process sequence. The input device 101 corresponds to an example of input means for receiving input of the setting about data collection.
The process setting unit 141 also inquires of the collector 160 whether the received parameter satisfies a predetermined condition, and acquires the determination result from the collector 160. When the received parameter does not satisfy the condition, the process setting unit 141 outputs, to the input device 101, information for prompting the user to re-input a parameter as result information indicating the determination result. The process setting unit 141 receives from the input device 101 a parameter re-input by the user.
The process setting unit 141 sets the received parameter. In detail, the process setting unit 141 writes setting information indicating the parameter onto the storage 142. The storage 142 stores setting information 41 including a parameter 411 as shown in
The parameter is defined in various formats.
The communication parameter 51 is associated with one or more instance parameters 52. The instance parameter 52 is used to identify the method for data collection from the device 21 identified by the communication parameter 51. The instance parameter 52 includes a collection interval 521. The instance parameter 52 may include the collection interval 521 and another information item to be used in combination to identify the collection method, or may include an information item other than the collection interval 521 to be used to identify the collection method. Data from the device 21 may be collected at different intervals in parallel. In this case, multiple instance parameters 52 are specified for one communication parameter 51.
The instance parameter 52 is associated with one or more data parameters 53. The data parameter 53 is used to identify data to be collected from the device 21 identified by the communication parameter 51 and to be collected with the collection method identified by the instance parameter 52. The data parameter 53 includes a data name 531 for collection target data, a location parameter 532 indicating the location of the data in the device 21, and a data type 533 indicating the type of the data. Multiple datasets may be collected from the device 21 with the same collection method. In this case, multiple data parameters 53 are specified for one instance parameter 52. The data name 531 is any user-specified name. The location parameter 532 indicates, for example, the address of a memory in the device 21. The data type 533 is, for example, int or double.
Referring back to
When acquiring data indicating the result of a subprocess from the processing unit 133, the process controller 143 outputs the data to the collector 160 as a control instruction to be transmitted to the device 22. The process controller 143 then specifies parameters for the collector 160 to cause the collector 160 to output a control instruction for the device 22. In some embodiments, the output set as an output of the process sequence is different from transmission of the control instruction. The process controller 143 then performs a process for implementing the defined output. For example, the process sequence may be defined to display its result on the screen. The process controller 143 may then output data through the process setting unit 141 for causing the input device 101 to display the result.
When an event occurs during implementation of the process sequence, typically an error, a communication failure, or missing values in data regularly collected, the process controller 143 writes identification information for identifying the event onto the storage 142. The identification information is an ID or a code corresponding to the type of the event. For example, when a failure occurs in communication with the device 21, the process controller 143 acquires the identification information 0001 from the implementer 164 and writes the information together with the time of the failure onto the storage 142. As shown in
The collector 160 is implemented mainly by the processor 11, the main memory 12, and the communicator 16 operating in cooperation, and performs the subprocesses 30 and 34. In detail, the collector 160 is implemented by the processor 11 running a software module stored in the auxiliary memory 13 in the same manner as the processing units 130. The software module may be plug-in software stored in the auxiliary memory 13 by the user. The plug-in software may be designed, purchased, or acquired as open-source software by the user. In
The collector 160 includes a configuration information provider 161 for providing configuration information for creating a parameter input screen to the process setting unit 141, a specific information provider 162 for providing information specific to the collector 160 to the process setting unit 141, a determiner 163 for determining whether a parameter received by the process setting unit 141 satisfies a predetermined condition, the implementer 164 for performing a subprocess, an event information provider 165 for providing, to the process setting unit 141, event information about an event occurring during implementation of the subprocess performed by the implementer 164, and a storage 166 for storing various items of data.
The configuration information provider 161 outputs configuration information to the process setting unit 141 upon receiving a request from the process setting unit 141. The specific information provider 162 outputs specific information to the process setting unit 141 upon receiving a request from the process setting unit 141. The specific information indicates, for example, the developer of the collector 160 and the version of the software module for implementing the collector 160.
The determiner 163 acquires a parameter received by the process setting unit 141 and determines whether the parameter satisfies a condition. For example, the determiner 163 determines whether an IP address as a parameter indicating the data collection target conforms to the IP address rule. In detail, the determiner 163 may receive a 33-bit IP address as a parameter from the process setting unit 141, although Internet Protocol version 4 (IPv4) uses a 32-bit IP address. The determiner 163 then provides, to the process setting unit 141, a determination result indicating that the parameter does not satisfy the condition. The determiner 163 may receive a 32-bit IP address as a parameter from the process setting unit 141. The determiner 163 then provides, to the process setting unit 141, a determination result indicating that the parameter satisfies the condition.
The determination as to whether the parameter satisfies a condition may be performed for multiple parameters, instead of a single parameter. In detail, the determiner 163 may determine whether a condition among multiple parameters is satisfied. For example, when a first parameter has a value less than a predetermined threshold, the determiner 163 may determine whether a second parameter has a value within a first range. When the first parameter has a value equal to or greater than the threshold, the determiner 163 may determine whether the second parameter has a value within a second range other than the first range.
The implementer 164 performs the subprocesses 30 and 34 as instructed by the process controller 143. In detail, the implementer 164 outputs information repeatedly acquired from the device 21 to the implementation controller 140 as controlled by the process controller 143. The implementer 164 then receives a control instruction output from the implementation controller 140 and transmits the control instruction to the device 22.
Upon receiving a request from the process setting unit 141, the event information provider 165 provides, to the process setting unit 141, event information corresponding to identification information included in the request. The event information includes, for example, the name and the details of an event. The user refers to the event information using the input device 101 to know the status of a process sequence during or after implementation of the process sequence.
As shown in
The process to be performed by the data collection apparatus 10 will now be described with reference to
The collector 160 then provides specific information to the process setting unit 141 (step S12). More specifically, the specific information provider 162 reads, upon receiving a request from the process setting unit 141, specific information from the storage 166 and provides the specific information to the process setting unit 141.
The input device 101 then displays an input screen using the configuration information provided in step S11 and the specific information provided in step S12 (step S13). For example, the input device 101 displays an input screen shown in
The input device 101 may display an input screen shown in
In some embodiments, the input device 101 may display an input screen for receiving communication parameters as shown in
When the user touches the OK button at the bottom of the input screens illustrated in
Referring back to
The process setting unit 141 then inquires of the collector 160 whether the parameter acquired in step S13 satisfies a predetermined condition (step S15). For example, the process setting unit 141 outputs the input value of the collection interval on the input screen shown in
The collector 160 then determines whether the parameter inquired in step S15 satisfies a condition and provides the determination result to the process setting unit 141 (step S16). For example, the collector 160 determines whether the input value of the collection interval shown in
The process setting unit 141 then outputs result information corresponding to the determination result provided in step S16 (step S17). More specifically, when the parameter does not satisfy the condition, the process setting unit 141 transmits result information indicating an error in the input value to the input device 101. This causes a message to appear for prompting the user to re-input a parameter as illustrated in
Referring back to
When determining that the setting operation is not complete (No in step S18), the data collection apparatus 10 repeats the processing in step S11 and subsequent steps. When determining that the setting operation is complete (Yes in step S18), the data collection apparatus 10 sets the parameters (step S19). More specifically, the process setting unit 141 writes setting information including the received parameters onto the storage 142. The setting then ends.
The process implementation will now be described with reference to
When the validity of the setting information is not verified (No in step S22), the process implementation ends without performing a process sequence. When the validity of the setting information is verified (Yes in step S22), the process controller 143 activates the collector 160 and the processing units 130 (step S23). More specifically, the process controller 143 runs the software module for implementing the collector 160 and the processing units 130 that perform the subprocesses included in the set process sequence. This causes the process sequence to start.
When the process sequence starts, the implementer 164 in the collector 160 collects data from the device 21 as a collection target in accordance with the parameters included in the setting information (step S24). The implementer 164 also determines whether a predetermined event, typically an error, has occurred (step S25).
When the implementer 164 determines that an event has not occurred (No in step S25), the data collection apparatus 10 advances to step S27. When determining that the event has occurred (Yes in step S25), the implementer 164 provides the identification information of the event to the process controller 143. The process controller 143 then adds the identification information and the current time to the history to record the event (step S26).
The data collection apparatus 10 then determines whether an instruction has been input for stopping the process sequence (step S27). More specifically, the process controller 143 determines whether a user instruction for stopping the process sequence has been input through the input device 101 and the process setting unit 141.
When determining that an instruction has not been input (No in step S27), the data collection apparatus 10 repeats the processing in step S24 and subsequent steps. When determining that the instruction has been input (Yes in step S27), the data collection apparatus 10 stops data collection (step S28). More specifically, the process controller 143 stops the operation of the processing units 130 and the collector 160 to stop the process sequence. The process implementation then ends.
The event information display will now be described with reference to
The process setting unit 141 then requests the collector 160 to provide event information corresponding to identification information stored in the storage 142 (step S32). Upon receiving the request, the collector 160 provides event information about the event indicated by the identification information to the process setting unit 141 (step S33). The event information includes the name and the details of an event, and optionally a message for handling an error.
The process setting unit 141 outputs, to the input device 101, the event information provided in step S33 together with the identification information and the event time. The input device 101 then displays the event information (step S34). The event information display then ends.
As described above, the collector 160 for collecting data from a network determines whether a parameter satisfies a predetermined condition and provides the determination result to the process setting unit 141. The process setting unit 141 then outputs result information corresponding to the determination result. Thus, the process setting unit 141 receiving the parameter outputs result information based on the determination result without determining whether the parameter satisfies the condition. When any new network is added as a data collection target, the collector 160 is changed or added for the new network without the process setting unit 141 being changed. This reduces the workload for incorporating a parameter setting function into the data collection apparatus 10. In other words, the data collection apparatus 10 can easily incorporate the function of collecting data from a new collection target.
When a parameter does not satisfy a condition, the collector 160 provides the determination result to the process setting unit 141. The process setting unit 141 then outputs, to the input device 101, result information corresponding to the determination result indicating that the parameter does not satisfy the condition. Thus, the input device 101 can notify, to the user, that the parameter does not satisfy the condition to allow the user to re-input a parameter that satisfies the condition.
The process setting unit 141 outputs, to the input device 101, condition information indicating the condition to be satisfied by the parameter together with result information. Thus, the input device 101 can present the condition to the user to allow the user to correctly input a parameter that satisfies the condition. The process setting unit 141 may acquire the condition information from the collector 160 or from a device external to the data collection apparatus 10. The condition information may be included in the result information.
The storage 142 stores identification information for identifying an event occurring in data collection. The collector 160 provides event information about the event indicated by the identification information to the process setting unit 141. The process setting unit 141 outputs the provided event information. The process setting unit 141 thus avoids accessing event information indicating the details of an event during implementation of a process sequence. The process setting unit 141 also avoids preparing event information about an event occurring in data collection with the collector 160, because such event information is provided by the collector 160.
Although the embodiments of the present disclosure have been described above, the present disclosure is not limited to the above embodiments.
In the above embodiments, the process setting unit 141 outputs, to the input device 101, result information prompting re-input of a parameter when the received parameter does not satisfy the condition. However, any other result information may be output. In some embodiments, upon receiving a determination result indicating that the received parameter does not satisfy the condition, the process setting unit 141 may change the parameter to a value satisfying the condition, incorporate the resultant value into setting information to generate result information, and write the result information onto the storage 142. Changing the parameter to satisfy the condition saves time and the effort of the user for re-inputting a parameter.
In the above embodiments, the data collection apparatus 10 is connected to the devices 21 and 22 through the industrial network 20. However, these components may have any other form of connection. In some embodiments, the network 20 may be an information network, and the data collection apparatus 10 may be connected to the devices 21 and 22 with a dedicated line. In the above embodiments, the data collection apparatus 10 is connected to the input device 101. The connection may use a network cable, a dedicated line, or the network 20. Instead of being connected to the input device 101, the data collection apparatus 10 may include an input unit 110 for receiving input of information from the user, as shown in
In the above embodiments, the process sequence is relatively simple as shown in
The functions of the data collection apparatus 10 can be implementable by dedicated hardware or a common computer system.
For example, the program P1 executable by the processor 11 may be stored in a non-transitory computer-readable recording medium for distribution. The program P1 is installed in a computer to provide a device that performs the above processing. Examples of such non-transitory recording media include a flexible disk, a compact disc read-only memory (CD-ROM), a digital versatile disc (DVD), and a magneto-optical (MO) disk.
The program P1 may be stored in a disk unit included in a server on a communication network, typically the Internet, and may be, for example, superimposed on a carrier wave to be downloaded to a computer.
The processing described above may also be performed by the program P1 being activated and executed while being transferred through a communication network.
The processing described above may also be performed by the program P1 being entirely or partially executed on a server with a computer transmitting and receiving information about the processing through a communication network and executing a program.
In the system with the above functions implementable partly by the operating system (OS) or through cooperation between the OS and applications, portions executable by applications other than the OS may be stored in a non-transitory recording medium that may be distributed or may be downloaded to a computer.
Means for implementing the functions of the data collection apparatus 10 is not limited to software. The functions may be partly or entirely implemented by dedicated hardware including circuits.
The foregoing describes some example embodiments for explanatory purposes. Although the foregoing discussion has presented specific embodiments, persons skilled in the art will recognize that changes may be made in form and detail without departing from the broader spirit and scope of the invention. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense. This detailed description, therefore, is not to be taken in a limiting sense, and the scope of the invention is defined only by the included claims, along with the full range of equivalents to which such claims are entitled.
The technique according to the present disclosure is suitable for data collection.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2019/017810 | 4/25/2019 | WO | 00 |