This invention relates to an information processing device and method, and particularly to an information processing device and method that enables output of an unlearned new pattern.
This application claims priority of Japanese Patent Application No.2002-135238, filed on May 10, 2002, the entirety of which is incorporated by reference herein.
Recently, various studies on human and animal brains have been made. It is known that a neural network can be used as a brain model.
In a neural network, as a predetermined pattern is learned, the learned pattern can be identified. However, there is a problem that the neural network cannot generate a new pattern.
In view of the foregoing status of the art, it is an object of the present invention to enable generation of an unlearned new pattern.
An information processing device according to the present invention includes: input means for inputting a time series pattern; model decision means for deciding a model based on a common nonlinear dynamic system having one or more feature parameters that can be operated from outside with respect to each of plural time series patterns inputted by the input means; arithmetic means for calculating a value of the feature parameter on the basis of the decided model; and output means for setting a value that is different from the value calculated by the arithmetic means, as the feature parameter, and performing inverse operation of the calculation of the value of the feature parameter, thereby outputting a new time series pattern.
The nonlinear dynamic system can be a recurrent neural network with an operating parameter.
The feature parameter can indicate a dynamic structure of the time series pattern in the nonlinear dynamic system.
The output means can output a new time series pattern having a dynamic structure that is shareable with plural inputted time series patterns.
An information processing method according to the present invention includes: an input step of inputting a time series pattern; a model decision step of deciding a model based on a common nonlinear dynamic system having one or more feature parameters that can be operated from outside with respect to each of plural time series patterns inputted by the processing of the input step; an arithmetic step of calculating a value of the feature parameter on the basis of the decided model; and an output step of setting a value that is different from the value calculated by the processing of the arithmetic step, as the feature parameter, and performing inverse operation of the calculation of the value of the feature parameter, thereby outputting a new time series pattern.
A program of a program storage medium according to the present invention includes: an input step of inputting a time series pattern; a model decision step of deciding a model based on a common nonlinear dynamic system having one or more feature parameters that can be operated from outside with respect to each of plural time series patterns inputted by the processing of the input step; an arithmetic step of calculating a value of the feature parameter on the basis of the decided model; and an output step of setting a value that is different from the value calculated by the processing of the arithmetic step, as the feature parameter, and performing inverse operation of the calculation of the value of the feature parameter, thereby outputting a new time series pattern.
A program according to the present invention includes: an input step of inputting a time series pattern; a model decision step of deciding a model based on a common nonlinear dynamic system having one or more feature parameters that can be operated from outside with respect to each of plural time series patterns inputted by the processing of the input step; an arithmetic step of calculating a value of the feature parameter on the basis of the decided model; and an output step of setting a value that is different from the value calculated by the processing of the arithmetic step, as the feature parameter, and performing inverse operation of the calculation of the value of the feature parameter, thereby outputting a new time series pattern.
In the information processing device and method, the program storage medium and the program according to the present invention, a new time series pattern corresponding to an inputted time series pattern is outputted.
Data xt related to a time series pattern is inputted to neurons 11-1, which constitute a part of the input layer 11. Specifically, for example, the data is related to a time series pattern such as a human physical movement pattern (for example, locus of movement of the hand position) acquired by image processing based on camera images. Pt is a vector and its dimension is arbitrary depending on the time series pattern. The parameter Pt is inputted to parametric bias nodes 11-2, which are neurons constituting a part of the input layer 11. The number of parametric bias nodes is one or more. It is desired that the number of parametric bias nodes is sufficiently small with respect to the total number of neuron that constitute the recurrent neural network and decide the number of weight matrixes, that is, a parameter of model decision means. In this embodiment, the number of parametric bias nodes is about one to two where the total number of such neurons is approximately 50. However, the invention of this application is not limited to this specific numbers. The parametric bias nodes are adapted for modulating a dynamic structure in a nonlinear dynamic system. In this embodiment, the parametric bias nodes are nodes that function to modulate a dynamic structure held by the recurrent neural network. However, this invention is not limited to the recurrent neural network. Moreover, data outputted from neurons 13-2, which constitute a part of the output layer 13, is fed back to neurons 11-3, which constitute a part of the input layer 11, as a context Ct expressing the internal state of the RNN 1. The context Ct is a common term related to the recurrent neural network and can be described in a reference literature (Elman, J. L. “Finding structure in time”, Cognitive Science, 14, (1990), pages 179-211) and the like.
The neurons of the intermediate layer 12 execute weighted addition processing to inputted data and processing to sequentially output the processed data to the subsequent stage. Specifically, after arithmetic processing (arithmetic processing based on a nonlinear function) with a predetermined weighting coefficient is performed to the data xt, Pt, and Ct, the processed data are outputted to the output layer 13. In this embodiment, for example, arithmetic processing based on a function having a nonlinear output characteristic such as a sigmoid function is performed to the input of a predetermined weighted sum of xt, Pt, and Ct, and then the processed data is outputted to the output layer 13.
Neurons 13-1, which constitute a part of the output layer 13, output data x*t+1 corresponding to input data.
The RNN 1 also has an arithmetic unit 21 for learning based on back propagation. An arithmetic section 22 performs processing to set a weighting coefficient for the RNN 1.
The learning processing of the RNN 1 will now be described with reference to flowchart of
The processing shown in the flowchart of
After the processing shown in the flowchart of
First, at step S11, the neurons 11-1 of the input layer 11 of the RNN 1 takes in an input xt at a predetermined time t. At step S12, the intermediate layer 12 of the RNN 1 performs arithmetic processing corresponding to a weighting coefficient to the input xt, and a prediction value x*t+1 of a time series t+1 in the inputted time series pattern is outputted from the neurons 13-1 of the output layer 13.
At step S13, the arithmetic unit 21 takes in an input xt+1 at the next time t+1, as teacher data. At step S14, the arithmetic unit 21 calculates the difference between the teacher input xt+1 taken in by the processing of step S13 and the prediction value x*t+1 calculated by the processing of step S12.
At step S15, the RNN 1 inputs the difference calculated by the processing of step S14 from the neurons 13-1 of the output layer 13 and propagates it to the intermediate layer 12 and then to the input layer 11, thus performing learning processing. The result of calculation dXbpt is thus acquired.
At step S16, the intermediate layer 12 acquires a modified value dXU of the internal state based on the following equation (1).
Moreover, the intermediate layer 12 modifies the modified value dXU on the basis of the following equations (2) to (4).
dlXUt=ε·dXUt+momentum·dlXUt (2)
XUt=XUt+dlXUt (3)
Xt=sigmoid(XUt) (4)
At step S17, the parametric nodes 11-2 execute processing to save the value of the internal state.
Next, at step S18, the RNN 1 judges whether to end the learning processing or not. If the learning processing is not to be ended, the RNN 1 returns to step S11 and repeats execution of the subsequent processing.
If it is judged at step S18 that the learning processing is to be ended, the RNN 1 ends the learning processing.
As the learning processing as described above is performed, one time series pattern is learned with respect to a virtual RNN.
After the learning processing as described above is performed for the virtual RNNs corresponding to the number of learning patterns, processing to set the weighting coefficient acquired from the learning processing, for the actual RNN 1, is performed.
At step S22, the arithmetic section 22 calculates a combined value of the coefficients acquired as a result of executing the processing shown in the flowchart of
Next, at step S22, the arithmetic section 22 executes processing to set the combined value (average value) calculated by the processing of step S21, as a weighting coefficient for the neurons of the actual RNN 1.
Thus, the coefficient acquired by learning the plural time series patterns is set for each neuron of the intermediate layer 12 of the actual RNN 1.
The weighting coefficient for each neuron of the intermediate layer 12 holds information related to a shareable dynamic structure in order to generate plural teaching time series patterns, and the parametric bias nodes hold necessary information for switching the shareable dynamic structure to a dynamic structure suitable for generating each teaching time series pattern. An example of the “shareable dynamic structure” will now be described. For example, as shown in
For example, as first data is inputted and learned, a time series pattern indicated by a curve L1 having relatively large amplitude is learned, as shown in
Similarly, as second data is inputted and learned, a time series pattern indicated by a curve L2 having relatively small amplitude is learned, as shown in
When generating a new time series pattern in the RNN 1 after such time series patterns are learned, processing as shown in the flowchart of
Specifically, first, at step S31, the parametric bias nodes 11-2 input a parameter that is different from the parameter in learning. At step S32, the intermediate layer 12 performs calculation based on a weighting coefficient with respect to the parameter inputted to the parametric bias nodes 11-2 by the processing of step S31. Specifically, inverse operation of the operation for calculating the parameter value in learning is carried out.
In this case, the time series pattern outputted from the neurons 13-1 of the output layer 13 is a time series pattern indicated by a curve L3 in
Hereinafter, the result of experiments will be described with reference to
When learning the first pattern, the error is almost 0.0 as indicated by a line L11 in
The output corresponding to the target shown in
One of the two parametric bias (parameter) values converges approximately at a value of 0.37 as indicated by a curve L14 in
The error is constant substantially at 0.0 as indicated by a line L21 in
In accordance with the target shown in
In the case the second time series pattern is learned, one of the two parametric bias values converges substantially at a value of 0.36 as indicated by a curve L24 in
The error in learning is substantially 0.0 as indicated by a curve L31 in
As shown in
In the case the third time series pattern is learned, one of the parametric bias values is substantially 0.21 as indicated by a curve L34 in
As the RNN 1 was caused to learn three time series patterns as shown in
Similarly, when values of 0.80 and 0.25 were inputted as parameters, a pattern as indicated by a curve L51 in
As is clear from the comparison of these, the amplitude of the curve L41 of
This is because the parameters (0.36, 0.36) of
The amplitude of the curve L51 of
This is because the values of the parameters (0.80, 0.25) of
In the above-described example, the RNN 1 is caused to learn linear time series patterns. However, similar results were obtained when the RNN 1 was caused to learn nonlinear time series patterns.
Specifically, after the RNN 1 is caused to learn a time series pattern as indicated by a curve L61 in
Specific examples will now be described.
When learning the fourth time series pattern, the error is almost 0.0 as indicated by a curve L71. The target is a sine wave as indicated by a curve L72. The corresponding output is indicated by a curve L73. This curve L73 substantially corresponds to the curve L72.
One of the two parametric bias values acquired in this case is 1.00 as indicated by a curve L74, and the other value is 0.79 as indicated by a curve L75.
The error in this learning is substantially 0.0 as indicated by a curve 81 in
The target is a deformed (strained) sine wave, which is different from the smooth sine wave indicated by the curve L72 in
As shown in
In this learning, one of the parametric bias values converges at 0.12 as indicated by a curve L84, and the other value converges substantially at 0.60 as indicated by a curve L85.
When parametric bias values (0.12, 0.68) are inputted to the parametric bias nodes 11-2 after the RNN 1 is caused to learn the two time series patterns shown in
Similarly, when parametric bias values (0.25, 0.59) are supplied, an output indicated by a curve L92 in
To compare the outputs of
In this manner, in this example, nonlinear arithmetic processing is performed to the parameters.
As is clear from
By thus causing the RNN to linear plural time series patterns and then inputting predetermined parameters, it is possible to generate and output a new time series pattern that is different from the learned time series patterns, using linear or nonlinear interpolation.
The parametric bias is a parameter for switching the spatio-temporal pattern generated by the RNN 1. The relation between this parameter and the spatio-temporal pattern is not predetermined but is decided by learning the taught spatio-temporal pattern.
This invention can be applied to, for example, “mimic movement learning” by a humanoid robot. This enables the robot to not only learn plural movement patterns (dancing and so on) taught by a person and reproduce those movements, but also extract common characteristics of the plural taught movement patterns and generate a new movement pattern based on the characteristics.
The above-described series of processing, which can be executed by hardware, can also be executed by software. In this case, for example, a personal computer 160 as shown in
In
The CPU 161, the ROM 162 and the RAM 163 are interconnected via a bus 164. Also an input/output interface 165 is connected to this bus 164.
The input/output interface 165 is connected with an input unit 166 including a keyboard, a mouse and the like, an output unit 167 including a display such as a CRT or LCD and a speaker, a storage unit 168 including a hard disk, and a communication unit 169 including a modem, a terminal adaptor and the like. The communication unit 169 performs communication processing via a network.
The input/output interface 165 is also connected with a drive 170, when necessary. A magnetic disk 171, an optical disc 172, a magneto-optical disc 173 or a semiconductor memory 174 is properly loaded on the drive 170, and a computer program read from the medium is installed into the storage unit 168, when necessary.
In the case of executing a series of processing by software, a program constituting the software is installed into the personal computer 160 from a network or a recording medium.
This recording medium may be not only a package medium such as the magnetic disk 171 (including a floppy disk), the optical disc 172 (including CD-ROM (compact disc read-only memory) and DVD (digital versatile disk)), the magneto-optical disc 173 (including MD (mini-disc)) or the semiconductor memory 174 which is distributed to provide the program to the user separately from the device and in which the program is recorded, but also the ROM 162 or the hard disk included in the storage unit 168 which is provided to the user in the form of being incorporated in the device and in which the program is recorded, as shown in
In this specification, the step of describing a program to be recorded to a recording medium includes the processing performed in time series in the described order and also includes processing executed in parallel or individually, though not necessarily in time series.
Moreover, in this specification, the system means the whole device including plural units and devices.
While the invention has been described in accordance with certain preferred embodiments thereof illustrated in the accompanying drawings and described in the above description in detail, it should be understood by those ordinarily skilled in the art that the invention is not limited to the embodiments, but various modifications, alternative constructions or equivalents can be implemented without departing from the scope and spirit of the present invention as set forth and defined by the appended claims.
As is described above, according to the present invention, a time series pattern can be generated. Moreover, the generated time series pattern can be a new time series pattern.
Number | Date | Country | Kind |
---|---|---|---|
2002-135238 | May 2002 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP03/00486 | 1/21/2003 | WO | 00 | 1/7/2004 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO03/096270 | 11/20/2003 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5408424 | Lo | Apr 1995 | A |
5956702 | Matsuoka et al. | Sep 1999 | A |
6249781 | Sutton | Jun 2001 | B1 |
6728691 | Neuneier et al. | Apr 2004 | B1 |
6735580 | Li et al. | May 2004 | B1 |
Number | Date | Country |
---|---|---|
2002-86378 | Mar 2002 | JP |
Number | Date | Country | |
---|---|---|---|
20050065900 A1 | Mar 2005 | US |