1. Field of the Invention
The present invention relates to a signal processing apparatus, a signal processing method, and a program therefor. More specifically, the invention relates to a signal processing apparatus, a signal processing method, and a program that perform a process of separating signals, in which a plurality of signals are mixed, by using the independent component analysis (ICA). In particular, the process is a real-time process, that is, a process of separating observed signals, which are successively input, into independent components with little delay and successively outputting them.
2. Description of the Related Art
First, as a related art of the invention, a description will be given of the independent component analysis (ICA) and a real-time implementation method of the independent component analysis (ICA).
A1. Description of ICA
The ICA is a type of multivariate analysis, and is a technique of separating multidimensional signals by using the statistical properties of the signals. For details on the ICA itself, refer to, for example, “Introduction to the Independent Component Analysis” (Noboru Murata, Tokyo Denki University Press).
Hereinafter, a description will be given of ICA for sound signals, in particular, ICA in the time frequency domain.
As shown in
In addition, it is assumed that the observed signal of the microphone n is xn(t). The observed signals of the microphone 1 and the microphone 2 are x1(t) and x2(t).
Observed signals for all microphones can be represented by a single expression as in Expression [1.2] below.
Here, x(t) and s(t) are column vectors having xk(t) and sk(t) as elements, respectively. A[1] is an n×N matrix having a[1]kj as elements. In the following description, it is assumed that n=N.
It is common knowledge that convolutive mixtures in the time domain are represented as instantaneous mixtures in the time frequency domain. An analysis using this characteristic is ICA in the time frequency domain.
The time frequency domain ICA itself is with reference to, for example, “19.2.4 Fourier Transform Methods” of “Explanation of Independent Component Analysis” and Japanese Unexamined Patent Application Publication No. 2006-238409 “Audio Signal Separating Apparatus/Noise Removal Apparatus and Method”).
Hereinafter, features relating to the invention will be mainly described.
Application of a short-time Fourier transform on both sides of Expression [1.2] mentioned above yields Expression [2.1] below.
In Expression [2.1],
ω is the frequency bin index, and
t is the frame index.
If ω is fixed, this expression can be regarded as instantaneous mixtures (mixtures with no time delay). Accordingly, to separate observed signals, Expression [2.5]for calculating the separation results [Y] is provided, and then a separating matrix W(ω) is determined so that, as the separation results, the individual components of Y(ω,t) are maximally independent.
In the case of time frequency domain ICA according to the related art, a so-called permutation problem occurs, in which “which component is separated into which channel” differs for each frequency bin. This permutation problem was almost entirely solved by the configuration disclosed in Japanese Unexamined Patent Application Publication No. 2006-238409 “Audio Signal Separating Apparatus/Noise Removal Apparatus and Method”, which is a patent application previously filed by the same inventor as the present application. Since this method is also employed in an embodiment of the invention, a brief description will be given of the technique for solving the permutation problem disclosed in Japanese Unexamined Patent Application Publication No. 2006-238409.
In Japanese Unexamined Patent Application Publication No. 2006-238409, in order to find a separating matrix W(ω), Expressions [3.1] to [3.3] represented as follows are iterated until the separating matrix W(ω) converges (or a certain number of times).
In the following, such iteration will be referred to as “learning”. It should be noted, however, that Expressions [3.1] to [3.3] are performed on all frequency bins, and further, Expression [3.1] is performed on all the frames of accumulated observed signals. In addition, in Expression [3.2], <·>t denotes the mean over all frames. The superscript H attached at the upper right of Y(ω,t) indicates the Hermitian transpose (which takes the transpose of a vector or a matrix, and also transforms its elements into conjugate complex numbers).
The separation results Y(t) are represented by Expression [3.4], and denotes a vector in which elements of all the channels and all the frequency bins of the separation results are arranged. Also, φω(Y(t)) is a vector represented by Expression [3.5]. Each element φω(Yk(t)) is called a score function, and is a logarithmic derivative of the multidimensional (multivariate) probability density function (PDF) of Yk(t) (Expression [3.6]). As the multidimensional PDF, for example, a function represented by Expression [3.7] can be used, in which case the score function φω(Yk(t)) can be represented as Expression [3.9]. It should be noted, however, that ∥Yk(t)∥2 is an L-2 norm (obtained by finding the square sum of all elements and then taking the square root of the resulting sum) of the vector Yk(t). An L-m norm as a generalized form of the L-2 norm is defined by Expression [3.8]. In Expressions [3.7] and [3.9], 7 denotes a term for adjusting the scale of Yk(ω, t), for which an appropriate positive constant, for example, sqrt(M) (square root of the number of frequency bins) is substituted. In Expression [3.3], η is a positive small value (for example, about 0.1) called a learning ratio or learning factor. This is used for gradually reflecting ΔW(ω) calculated in Expression [3.2] on the separating matrix W(ω).
In addition, while Expression [3.1] represents separation in one frequency bin (refer to
This may be accomplished by using the separation results Y(t) in all frequency bins represented by Expression [3.4] described above, and observed signals X(t) represented by Expression [3.11], and further the separating matrices for all frequency bins represented by Expression [3.10]. By using those vectors and matrices, separation can be represented by Expression [3.12]. According to an embodiment of the invention, Expressions [3.1] and [3.11] are used selectively as necessary.
In addition, the diagrams of X1 to Xn and Y1 to Yn shown in
In the above description, it is assumed that the number of sound sources N is equal to the number of microphones n. However, even when N<n, the separation is possible. In this case, signals corresponding to the sound sources are respectively output on N channels of the n output channels, but almost-silent signals corresponding to none of the sound sources are output on n-N remaining channels.
A2. Real-Time Implementation of ICA
The learning process described in the section “A1. Description of ICA”, in which Expressions [3.1] to [3.3] are iterated until the separating matrix W(ω) converges (or a predetermined number of times), is performed by a batch process. That is, as described above, the iteration process of Expressions [3.1] to [3.3], in which Expressions [3.1] to [3.3] are iterated after accumulating the whole of the observed signals, is referred to as learning.
This batch process can be applied to real-time (low-delay) sound source separation through some contrivance. As an example of a sound source separation process realizing a real-time processing method, a description will be given of the configuration disclosed in “Japanese Unexamined Patent Application Publication No. 2008-147920: Real-Time Sound Source Separation Apparatus and Method”, which is a patent application previously filed by the same applicant as the present application.
As shown in
In addition, in the case of real-time ICA (blockwise ICA) disclosed prior to Japanese Unexamined Patent Application Publication No. 2008-147920, there is no overlap between the blocks. Therefore, in order to shorten the update interval of the separating matrix, it is necessary to shorten the block length (=the time for which observed signals are accumulated). However, there is a problem in that a shorter block length results in lower separation accuracy.
As described above, the method of applying the batch process to each block of the observed signals is hereinafter referred to as a “blockwise batch process”.
A separating matrix found from each block is applied to subsequent observed signals (not applied to the same block) to generate the separation results. Herein, such a method will be referred to as a “shift application”.
As described above, a separating matrix is considered to represent a process the reverse of a mixing process.
Hence, when the mixing process is the same (for example, when the positional relation between sound sources and microphones has not changed) between the observed signals in the learning data block setting segment 41 and the observed signals 42 at the current time, signal separation can be performed even when a separating matrix learned in a different segment is applied. In such a manner, it is possible to realize separation with little delay.
The configuration disclosed in Japanese Unexamined Patent Application Publication No. 2008-147920 proposes a method in which a plurality of processing units called threads for finding a separating matrix from overlapped blocks are run in parallel per unit time shifts. This parallel processing method will be described with reference to
The “A) Accumulating” is the segment of dark gray in
Upon accumulating observed signals for a predetermined time (for example, four seconds), the state of each thread transitions to “B) Learning”. The “B) Learning” is the segment of light gray in
When the separating matrix W has sufficiently converged (or simply upon reaching a predetermined number of iterations) by learning (iteration of Expressions [3.1] to [3.3]), the learning is ended, and the thread transitions to the “C) Waiting” state (the white segment in
The separating matrix W obtained by learning is used for performing separation until learning in the next thread is finished. That is, the separating matrix W is used as a separating matrix 43 shown in
In the applied-separating-matrix specifying segment 51 from when the system is started to when the first separating matrix is learned, an initial value (for example, a unit matrix) is used as the separating matrix 43 in
In addition, when a separating matrix obtained in another thread exists at the point of starting learning, the separating matrix is used as the initial value of learning. This is referred to as “inheritance of a separating matrix”. In the example shown in
By performing such processing, it is possible to prevent or reduce the occurrence of permutation between threads. Permutation between threads refers to, for example, a problem such that in the separating matrix obtained in the first thread, voice is output on the first channel and music is output on the second channel, whereas those are reversed in the separating matrix obtained in the third thread.
As described above with reference to
By running a plurality of threads per unit time shifts in this way, the separating matrix is updated at an interval substantially equal to a shift between threads, that is, a block shift width 56.
B. Problems of Related Art
Next, the problems in the “A2. Real-time Implementation of ICA” described above will be studied. In the combination of the “blockwise batch process” and the “shift application” described in “A2. Real-time Implementation of ICA”, the sound source separation may be not accurately performed. As the reason, the following two factors can be considered separately.
B1. Tracking lag
B2. Residual sound
Hereinafter, the respective reasons why the two factors cause inaccuracy in the sound source separation will be described.
B1. Tracking Lag
When the “shift application” is employed, a mismatch occurs temporarily when the sound sources are changed (when the sound sources are moved or start playing sounds suddenly) between the segment used for learning of a separating matrix (for example, the learning data block 41 shown in
Thereafter, as a new separating matrix is obtained by the learning process which observes the changed sound sources, such a mismatch disappears eventually. However, until the new separating matrix is generated, the mismatch exists. This phenomenon will be herein referred to as a “tracking lag”. The tracking lag may be caused even when the sound starts playing suddenly or the sound stops playing and then starts playing again although the sound sources are not moved. Hereinafter, such a sound is referred to as a “sudden sound”.
(a) Sound source 1
(b) Sound source 2
The two sound sources are employed.
Time progresses from left to right. The block heights of the (a) sound source 1, the (b) sound source 2, and the (c) observed signal represent volumes thereof.
The (a) sound source 1 plays twice with the silent segment 67 interlaid therebetween. Output segments of the sound source are respectively represented by the sound-source-1 output segments 61 and 62. The sounds are output at the current time at which the current observed signal 66 is being observed.
The (b) sound source 2 plays continuously. That is, the sound source 2 has a sound-source-2 output segment 63.
The (c) observed signal can be represented by the sum of the signals which reach the microphones from the sound sources 1 and 2.
The block 64 of the learning data indicated by the dotted-line area in the (c) observed signal is the same segment as the learning data block 41 shown in
The observed signal 66 at the current time (t1) is an observed signal based on the sound source output 69 at the current time.
However, sometimes a mismatch may occur between the learning data and the current observed signal in accordance with the length of the silent segment 67 of the sound source 1 and the length of the learning data block 64 (which is the same as the learning data block 41 shown in
For example, in the (c) observed signal, the observed signal 66 at the current time (t1) includes both the sound-source-1 output segment 62 derived from the sound source 1 and the sound-source-2 output segment 63 derived from the sound source 2 as an observed signal. In contrast, in the learning data block 64, only the sound-source-2 output segment 63 originated from the sound source 2 was observed.
Similar to the observed signal 66 at the current time (t1), the situation, in which the sound out of the learning data block is currently being played, is expressed as “a sudden sound is generated”. In other words, since the learning data block 64 does not include the observed signal of the sound source 1, although the sound source 1 plays ahead of the block (corresponding to the sound-source-1 output segment 61), the sound of the sound source 1 (the segment of the sound-source-1 output segment 62) is the sudden sound in the separating matrix learned in the learning data block 64.
(a) Observed Signal
(b1) Separation Result 1
(b2) Separation Result 2
(b3) Separation Result 3
Time progresses from left to right in the drawing.
In the example shown in
The (a) observed signal includes the continuous sound 71 which is continuously played in the range of the time t0 to t5 and the sudden sound 72 which is output only in the range of the time t1 to t4.
The (a) observed signal in
Before the start of the output of the sudden sound 72, the separating matrix is sufficiently converged in the segment 73 from t0 to t1 during which only the continuous sound 71 is being played, and then the signal corresponding to the continuous sound 71 is output on only one channel. This is the (b1) separation result 1. Almost silent sound is output on other channels, that is, the (b2) separation result 2 and the (b3) separation result 3.
Here, suppose that the sudden sound 72 occurs. For example, someone who has been silent may suddenly start talking. At this time, the separating matrix applicable to the observed signal is a separating matrix which is generated by learning the data before the generation of the sudden sound 72, that is, only the data of the continuous sound 71 prior to the time t1 as observation data.
As a result, by applying the separating matrix generated on the basis of the observed signal prior to the time t1, the observed signal obtained by observing the sudden sound 72 after the time t1 is separated, and thus it is difficult to obtain a correct separation result corresponding to the observed signal. The reason is that the separating matrix generated on the basis of the observed signal prior to the time t1 is a separating matrix in which the sudden sound 72 included in the observed signal after the time t1 is not considered. Consequently, as the separation results from the application of the separating matrix, for example, a mismatch occurs between the actual observed signal, that is, the observed signal as a mixture of the continuous sound 71 and the sudden sound 72, and the separation results in the range of the time t1 to t3.
In the time period from when the play of the sudden sound is started to when the separating matrix in which the sudden sound is reflected is learned (in the segment 74 from the time t1 to t2), the phenomenon, in which the sudden sound is output on all the channels (the (b1) separation result 1, the (b2) separation result 2, and the (b3) separation result 3), occurs. That is, the sudden sound is scarcely subjected to the sound source separation. This time period is minimally equal to a value slightly larger than the learning time, and is maximally equal to the sum of the learning time and the block shift width. For example, in the system in which the learning time is 0.3 seconds and the block shift is 0.2 seconds, the sudden sound is not separated and is output on all the channels in a little over 0.3 seconds minimum and 0.5 seconds maximum.
Thereafter, in order of the learning process in a new learning block, a new separating matrix is generated and updated. The separating matrix update process excludes one channel (in
In the example shown in
The causes of the problem of the tracking lag, which occurs when the sudden sound is generated, are different depending on whether the sudden sound is a target sound or an interference sound. Hereinafter, each case will be described. The target sound means a sound serving as an analysis target.
When the sudden sound is the interference sound, in other words, when the continuous sound 71 continuously played is the target sound, it is preferable to remove the sudden sound. Accordingly, the problem is that the interference sound is not removed and remains in the (b1) separation result 1 shown in
On the other hand, when the sudden sound is the target sound, it is preferable to retain the sudden sound but remove the continuous sound 71 played continuously as the interference sound. It seems that the (b2) separation result 2 shown in
As described above, depending on the characteristics of the sudden sound, it is necessary to perform contrary processes of removing or retaining the sound. Hence, it is difficult to solve the problem by using a single method.
B2. Residual Sound
Next, in the combination of the “blockwise batch process” and the “shift application” described in the “A2. Real-Time Implementation of ICA”, “residual sound” as another factor which causes inaccuracy in the sound source separation will be described.
For example, the separating matrix is sufficiently converged in the segment 73 from the time t0 to t1, the segment 76 from the time t3 to t4, or the like in
The following points are considered as factors which cause the residual sound.
a) The length of the spatial reverberation is longer than the frame length of the short-time Fourier transform (STFT).
b) The number of the sound sources is larger than the number of the microphones.
c) The space between microphones is narrow, and thus the interference sound is not removed at a low frequency.
In the sound source separation system using the real-time ICA, there is a trade-off between the reduction in the tracking lag and the reduction in the residual sound. The reason is that it is advantageous for the reduction in the tracking lag to shorten the learning time but the residual sound increases in accordance with the method therefor.
The computational cost for the learning of the ICA is in proportion to the frame length of the short-time Fourier transform (STFT), and the square of the number of channels (the number of microphones). Accordingly, when the value is set to be small, it is possible to shorten the learning time although the number of loops is the same. Hence, it is also possible to shorten the tracking lag.
However, the reduction in the frame length further deteriorates one of the factors causing the residual sound, that is, the factor a).
Further, the reduction in the number of microphones further deteriorates one of the factors causing the residual sound, that is, the factor b).
Accordingly, a process of shortening the frame length of the short-time Fourier transform (STFT) or a process of reducing the number of channels (the number of microphones) contributes to the reduction in the tracking lag, whereas a problem arises in that the residual sound tends to occur.
As described above, the reduction in tracking lag and the residual sound are in a relationship in which, if one is intended to be solved, the other deteriorates.
The residual sound 78 shown in
On the other hand, when the above-mentioned “tracking lag” is large, the time, at which the accurate separation result of the sudden sound is obtained, is delayed. Specifically, there is an increase in the time period from the time t1, at which the sudden sound is generated, shown in
There may be different selections as to which sound source of a plurality of sound sources it is desirable to acquire the sound from, depending on their purpose. Here, the sound to acquire the accurate separation result is referred to as a “target sound”.
Depending on where between the continuous sound being played and the sudden sound the “target sound” is, it is preferable to perform a different process and a different setting.
The remaining one of the factors causing the residual sound is as follows.
c) Since the spaces between microphones are narrow, the interference sound is not removed at a low frequency.
This factor is irrespective of the real-time process. However, the problem can be solved by the configuration according to the embodiment of the invention, and will be thus described herein. In the ICA in the time frequency domain, when the spaces between the microphones are narrow (for example, about 2 to 3 cm), separation may not be sufficiently performed particularly at a low frequency. The reason is that it is difficult to obtain a sufficient phase difference in the spaces between the microphones. The separation accuracy at a low frequency can be improved by increasing the microphone spaces, whereas the separation accuracy at a high frequency is likely to be lowered by the phenomenon which is called spatial aliasing. Further, because of physical restriction, sometimes the microphones may not be installed with wide spaces.
The above-mentioned problems are summarized as follows.
(A) In the real-time ICA using the “blockwise processing” and the “shift application”, the “tracking lag” or the “residual sound” is caused by the sudden sound, and thus the sound source separation may be not accurately performed.
(B) The methods of coping with the “tracking lag” and the “residual sound” for accurately performing the sound source separation are contrary to each other depending on whether the sudden sound is the target sound or the interference sound. Hence, it is difficult to solve the problem by using a single method.
(C) In the framework of the real-time ICA according to the related art, there may be a trade-off relationship between the reduction in the “tracking lag” and the cancellation of the “residual sound”.
The embodiment of the invention has been made in consideration of the above-mentioned situation, and is addressed to provide a signal processing apparatus, a signal processing method, and a program capable of performing a high-accuracy separation process in units of the respective sound source signals as a real-time process with little delay by using the independent component analysis (ICA).
According to a first embodiment of the invention, there is provided a signal processing apparatus including a separation processing unit that generates observed signals in the time frequency domain by performing the short-time Fourier transform (STFT) on mixed signals as outputs, which are acquired from a plurality of sound sources by a plurality of sensors, and generates sound source separation results corresponding to the sound sources by performing a linear filtering process on the observed signals. The separation processing unit has a linear filtering process section that performs the linear filtering process on the observed signals so as to generate separated signals corresponding to the respective sound sources, an all-null spatial filtering section that applies an all-null spatial filter which form null beams toward all the sound sources included in the observed signals acquired by the plurality of sensors so as to generate signals filtered with the all-null spatial filters (spatially filtered signals) in which the acquired sounds in null directions are removed, and a frequency filtering section that performs a filtering process of removing signal components corresponding to the spatially filtered signals included in the separated signals by inputting the separated signals and the spatially filtered signals, thereby generating processing results of the frequency filtering section as the sound source separation results.
Further, the signal processing apparatus according to the first embodiment of the invention further includes a learning processing unit that finds separating matrices for separating the mixed signals, in which the outputs from the plurality of sound sources are mixed, through a learning process, which employs independent component analysis (ICA) to the observed signals generated from the mixed signals, and generates the all-null spatial filter which form null beams toward all the sound sources acquired from the observed signals. The linear filtering process section applies the separating matrices, which are generated by the learning processing unit, to the observed signals so as to separate the mixed signals and generate the separated signals corresponding to the respective sound sources. The all-null spatial filtering section applies the all-null spatial filters, which are generated by the learning processing unit, to the observed signals so as to generate the spatially filtered signals in which the acquired sounds in null directions are removed.
Furthermore, in the signal processing apparatus according to the first embodiment of the invention, the frequency filtering section performs the filtering process of removing signal components, which correspond to the spatially filtered signals included in the separated signals, through a process of subtracting the spatially filtered signals from the separated signals.
Further, in the signal processing apparatus according to the first embodiment of the invention, the frequency filtering section performs the filtering process of removing signal components, which correspond to the spatially filtered signals included in the separated signals, through a frequency filtering process based on a spectral subtraction which regards the spatially filtered signals as noise components.
Furthermore, in the signal processing apparatus according to the first embodiment of the invention, the learning processing unit performs a process of generating the separating matrices and the all-null spatial filters based on blockwise learning results by performing a learning process on a block-by-block basis for dividing the observed signals. In addition, the separation processing unit performs a process using the latest separating matrices and all-null spatial filters which are generated by the learning processing unit.
Further, in the signal processing apparatus according to the first embodiment of the invention, the frequency filtering section performs a process of changing a level of removal of components corresponding to the spatially filtered signals from the separated signals in accordance with a channel of separated signals.
Furthermore, in the signal processing apparatus according to the first embodiment of the invention, the frequency filtering section performs the process of changing the level of removal of components corresponding to the spatially filtered signals from the separated signals in accordance with a power ratio of the channels of the separated signals.
Further, in the signal processing apparatus according to the first embodiment of the invention, the separation processing unit generates the separating matrices and the all-null spatial filters subjected to a rescaling process as scale adjustment using a plurality of frames, which are data units cut out from the observed signals, including a frame corresponding to the current observed signals, and performs a process of applying the separating matrices and the all-null spatial filters subjected to the rescaling process to the observed signals.
According to a second embodiment of the invention, there is provided a signal processing method of performing a sound source separation process on a signal processing apparatus. The signal processing method includes a separation process step of generating observed signals in the time frequency domain by performing the short-time Fourier transform (STFT) on mixed signals as outputs, which are acquired from a plurality of sound sources by a plurality of sensors, and generating sound source separation results corresponding to the sound sources by performing a linear filtering process on the observed signals, in a separation processing unit. The separation process step includes a linear filtering process step of performing the linear filtering process on the observed signals so as to generate separated signals corresponding to the respective sound sources, an all-null spatial filtering step of applying all-null spatial filters which form null beams toward all the sound sources included in the observed signals acquired by the plurality of sensors so as to generate signals filtered with the all-null spatial filters (spatially filtered signals) in which acquired sounds in null directions are removed, and a frequency filtering step of performing a filtering process of removing signal components corresponding to the spatially filtered signals included in the separated signals by inputting the separated signals and the spatially filtered signals, thereby generating processing results of the frequency filtering step, as the sound source separation results.
According to a third embodiment of the invention, there is provided a program of performing a sound source separation process on a signal processing apparatus. The program executes a separation process step of generating observed signals in the time frequency domain by performing the short-time Fourier transform (STFT) on mixed signals as outputs, which are acquired from a plurality of sound sources by a plurality of sensors, and generating sound source separation results corresponding to the sound sources by performing a linear filtering process on the observed signals, in a separation processing unit. The separation process step includes a linear filtering process step of performing the linear filtering process on the observed signals so as to generate separated signals corresponding to the respective sound sources, an all-null spatial filtering step of applying an all-null spatial filter which form null beams toward all the sound sources included in the observed signals acquired by the plurality of sensors so as to generate signals filtered with the all-null spatial filters (spatially filtered signals) in which acquired sounds in null directions are removed, and a frequency filtering step of performing a filtering process of removing signal components corresponding to the spatially filtered signals included in the separated signals by inputting the separated signals and the spatially filtered signals, thereby generating processing results of the frequency filtering step, as the sound source separation results.
In addition, the program according to the embodiment of the invention is a program that can be provided to an information processing apparatus or a computer system capable of executing a various program codes, via a storage medium or communication medium that is provided in a computer-readable format. By providing such a program in a computer-readable format, processes corresponding to the program are realized on the information processing apparatus or the computer system.
Other purposes, features, and advantages of the embodiments of the invention will become apparent from the following detailed description based on embodiments of the invention and the accompanying drawings to be described later. In this specification, the system is defined as a logical assembly of a plurality of devices, and is not limited to a configuration in which the constituent devices are provided within the same casing.
In the configuration of the embodiment of the invention, the separating matrices for separating the mixed signals, in which the outputs from the plurality of sound sources are mixed, is obtained through the learning process, which employs independent component analysis (ICA) to the observed signals generated from the mixed signals, thereby generating the separated signals. In addition, the all-null spatial filters, which have a null in the sound sources detected as the observed signals, is applied to the observed signals, thereby generating the spatially filtered signal in which detected sounds are removed. Further, the filtering process of removing signal components corresponding to the spatially filtered signals included in the separated signals is performed, thereby generating the sound source separation results from results of the frequency filtering section. With such a configuration, it is possible to perform high-accuracy sound source separation on the mixed signals including the sudden sounds.
Hereinafter, a signal processing apparatus, a signal processing method, and a program according to an embodiment of the invention will be described in detail with reference to the drawings. Description will be given in order of the following items.
1. Configuration of Embodiment of the Invention and Brief Overview of Processing
2. Specific Examples of Signal Processing Apparatus of Embodiment of the Invention
3. Sound Source Separation Process Executed in Signal Processing Apparatus according to Embodiment of the Invention
3-1. Entire Sequence
3-2. Initialization Process
3-3. Thread Control Process
3-4. Separation Process
4. Processing in Learning Thread in Thread Computation Section
5. Other Examples (Modified Examples) of Signal Processing Apparatus of Embodiment of the Invention
6. Overview of Advantages based on Configuration of Signal Processing Apparatus according to Embodiment of the Invention
First, a configuration of an embodiment of the invention and a brief overview of processing will be described.
In the embodiment of the invention, processing of separating signals, in which a plurality of signals is mixed, is performed by using independent component analysis (ICA). However, as described above, when the sound source separation process is performed by using the separating matrix generated on the basis of the preceding observation data, a problem arises in that it is difficult to separate the sudden sound. In the embodiment of the invention, in order to solve the problem relating to, for example, the sudden sound, there is provided a configuration in which the following constituents are newly added to, for example, the real-time ICA system according to the related art disclosed in the patent application (Japanese Unexamined Patent Application Publication No. 2008-147920) previously filed by the present applicant.
(1) A configuration in which, in order to cope with the problem of distortion of the sudden sound, rescaling (processing of making the balance between frequencies close to the source signal) of the separation results is performed on a frame-by-frame basis.
It should be noted that the processing is referred to as “frequent rescaling”.
(2) A configuration in which, in order to remove the sudden sound, a filter (hereinafter referred to as an “all-null spatial filter”), which directs a null to all detected sound source directions, is generated from the same segment as the learning data of ICA. Further, a configuration in which processing corresponding to frequency filtering or the frequency filtering is performed between the result obtained by applying the separation results of ICA to the observed signals and the result obtained by applying the all-null spatial filter to the same observed signals.
It should be noted that the processing configuration is referred to as “all-null spatial filter & frequency filtering”.
(3) A configuration in which, in order to perform different processes in accordance with characteristics of the sudden sound, it is determined whether the respective output channels of ICA output the signals corresponding to the sound sources, and one of the processes is performed depending on the result thereof.
i) If it is determined that the signals corresponds to the sound sources, both the “frequent rescaling” and the “all-null spatial filter & frequency filtering” are applied.
As a result, the sudden sound is removed from the channels.
ii) If it is determined that the signals does not correspond to the sound sources, only the “frequent rescaling” is applied. As a result, the sudden sound is output from the channels.
It should be noted that the processing configuration is referred to as “determination for individual channels”.
Hereinafter, first, a brief overview will be given of (1) to (3) described above.
(1) Frequent Rescaling
In Japanese Unexamined Patent Application Publication No. 2008-147920 which is the patent application previously filed by the present applicant, the rescaling is performed on the separating matrix at the time of the end of the learning.
Referring to
For example, when the learning of the learning segment 58 of the thread 2 shown in
Accordingly, in the embodiment of the invention, the rescaling (the processing of making the balance between frequencies close to the original sound) is performed on frame-by-frame basis, thereby reducing distortion of the sudden sound). The frame-based rescaling process will be described with reference to
a) Observed Signal Spectrogram
b) Separation Result Spectrogram
The learning data block 81 shown in
The observed signal 82 at the current time shown in
The separating matrix 83 shown in
The rescaling in the related art had been performed by using the learning data of the learning data block 81. In contrast, in the processing according to the embodiment of the invention described below, the block, of which the end is the current time, with a regular length, that is, the block 87 including the current time shown in
(2) All-Null Spatial Filter & Frequency Filtering
Next, the “all-null spatial filter & frequency filtering” process, which is a process effective for removing the sudden sound, will be described with reference to
The all-null spatial filter 84 is a filter (a vector or a matrix) which form null beams toward all the sound sources existing in the segment of the learning data block 81, and has a function of passing only the sudden sound, that is, the sound in the direction from which sound had not been played in the learning data block 81. The reason is that the sound which had been played in the learning data block 81 is removed by the null, which is formed by the all-null spatial filter 84, as long as the sound keeps playing without changing its position, whereas the null is not formed in the direction of the sudden sound and thus the sudden sound is passed.
On the other hand, the separating matrix 83 passes the sudden sound. The results differ in accordance with the output channels. Thus, on a certain channel, the sudden sound is superimposed upon the sound source which has been output up to that time (the (b1) separation result 1 in
Here, the result of the all-null spatial filter is subtracted (or is subjected to an operation similar thereto) from the same result as the (b1) separation result 1 shown in
(a) observed signal;
(b) signal filtered with all-null spatial filter;
(c1) processing result 1;
(c2) processing result 2; and
(c3) processing result 3.
Time (t) progresses from left to right, and the height of each block represents a volume thereof.
The (a) observed signal is the same as the (a) observed signal in
When the all-null spatial filter is applied to the (a) observed signal shown in
In the range of the time t0 to t5, the continuous sound 91 being played is almost removed from the (b) signal filtered with all-null spatial filter. On the other hand, the start portion (from the time t1) of the sudden sound 92 remains without being removed. In the segment 94 from the time t1 to t2, the sudden sound 92 is scarcely removed.
The reason is that the all-null spatial filter has a function of removing the sound source included in the temporally preceding observed signal, but the sudden sound 92 is not included in the observed signal just prior to the segment 94 from the time t1 to t2, and is not removed by the all-null spatial filter.
The (b) signal filtered with all-null spatial filter shown in
Processing result 1=(separation result 1)−(signal filtered with all-null spatial filter)
In addition, in order to completely remove the sudden sound at the time of the subtraction, it is necessary to adjust the scale of the all-null spatial filtering result to the scale of the sudden sound which is included in the separating-matrix application result. This is referred to as “rescaling of the all-null spatial filter”. In addition, the rescaling process is performed as a process of adjusting the scale (the range of signal fluctuation) of one signal to that of another signal. In this case, the rescaling process is performed as a process of making the scale of the all-null spatial filtering result close to the scale of the sudden sound which is included in the separating-matrix application result. Since it is necessary to adjust the scales for each output channel of ICA, the all-null spatial filtering result obtained after rescaling is the same as the number of channels of ICA (the number of channels of the all-null spatial filtering result obtained before rescaling is 1).
The “subtraction” may be normal subtraction (subtraction in a complex number region), but the process of so-called 2-channel frequency filtering may be used by generalization.
The 2-channel frequency filtering will be described with reference to
Generally, the 2-channel frequency filtering is provided with two inputs.
Suppose that one is the observed signal 102 [X(ω,t)], and another one is the estimated noise 101 [N(ω,t)].
Those are signals with the same time and frequency.
From the two signals, the gain 104 (the factor multiplied to the observed signal) [G(ω,t)] is calculated by the gain estimation portion 103, and the gain is multiplied to the observed signal by the gain application portion 105, thereby obtaining the processing result 106. The processing result U(ω,t) is represented by the following expression.
U(ω,t)=G(ω,t)×X(ω,t)
Specifically, at the frequency in which noise is dominant, the gain is set to be small, and at the frequency in which noise is low, the gain is set to be large, thereby generating a noise-removed signal. The normal subtraction can be also regarded as a kind of the frequency filtering, but other than that, it is possible to apply the known method such as the spectral subtraction (spectral subtraction) or the Minimum Mean Square Error (MMSE)•Wiener Filter Joint MAP.
The details of the 2-channel frequency filtering process according to the embodiment of the invention will be described with reference to
Y′k(ω,t)
is input.
In addition, as an input of the estimated noise, the all-null spatial filtering result (after rescaling) 111 which is the sudden sound, that is,
Z′k(ω,t)
is input.
The gain estimation portion 113 inputs the all-null spatial filtering result 111 and the separating-matrix application result 112, thereby finding the gain 114 [Gk(ω,t)]. The gain application portion 115 multiplies the gain 114 [Gk(ω,t)] by the separating-matrix application result 112, that is, Y′k(ω,t), thereby finding Uk(ω,t) as the result in which the sudden sound is removed. The processing result Uk(ω,t) is represented by the following expression.
Uk(ω,t)=Gk(ω,t)×Y′k(ω,t)
In addition, if a non-linear method such as spectral subtraction is used in the frequency filtering, it is also possible to remove the “residual sound” described in the section of “Description of the Related Art”. That is, since it is difficult to remove the “residual sound” even by using the separating matrix and the all-null spatial filter, by subtracting the respective results from each other, the residual sound is canceled. Hence, it is possible to solve the problem in the trade-off between the tracking lag and the residual sound.
(3) Determination of Individual Channels
When the above-mentioned “all-null spatial filter & frequency filtering” process is applied to all channels, in a certain case, this causes more trouble. The case is that the sudden sound is the target sound. For example, in
Accordingly, on the basis of the following criterion, it is determined whether or not the “all-null spatial filter & frequency filtering” is applied, for each channel. Alternatively, the level of the frequency filtering is changed for each channel. In such a manner, it is possible to simultaneously achieve both the channels on which only the sound being played (the sound that has been played from the time before the sudden sound is generated) is output and the channel on which only the sudden sound is output.
Whether or not the “all-null spatial filter & frequency filtering” is applied to a certain channel, that is, whether or not it is preferred to remove the sudden sound depends on whether the signal corresponding to the sound source is being output from the channel just before the sudden sound is generated. If the signal corresponding to the sound source is already output, the frequency filtering is performed (or the amount of the subtraction is set to be large). In contrast, if the signal is not output, the frequency filtering is skipped (or the amount of the subtraction is set to be small).
For example, in
The result corresponds to the (c1) processing result 1 in
On the other hand, in the segment 73 from time t0 to t1 in the (b2) separation result 2 and the (b3) separation result 3 shown in
By performing the processing, the signal, which is produced from only the sudden sound when the sudden sound is generated, is output. Also in this case, the frequent rescaling is performed for each frame, and thus contrary to the method according to the related art, the distortion of the start portion of the sudden sound is reduced.
Whether or not the respective outputs (the application result of the separating matrix) of ICA correspond to the sound sources depends on the separating matrix. Accordingly, it is not necessary to perform the determination for each frame, and it is preferable to perform the determination at the timing at which the separating matrix is updated. The detailed criterion for the determination will be described later.
In addition, when the determination is performed on the basis of two choices as to whether “the frequency filtering is applied or not”, the processing result is greatly changed at the time of changing the application status. In order to prevent the phenomenon mentioned above, it is preferable to perform a process of continuously changing the level of the application of the frequency filtering (the amount of the subtraction) in accordance with continuous values representing whether or not the outputs of ICA correspond to the sound sources. Detailed description thereof will be described later.
Hereinafter, the specific examples of the signal processing apparatus according to the embodiment of the invention will be described. A configuration example of the signal processing apparatus according to the embodiment of the invention is shown in
The separation processing unit 123 shown on the left side of
In addition, the process in the separation processing unit 123, and the process in the learning processing unit 130 are performed in parallel. The process in the separation processing unit 123 is a foreground process, and the process in the learning processing unit 130 is a background process.
From the perspective of the system as a whole, the separation processing unit 123 performs the sound source separation process on the observed signals for each frame so as to generate the separation results, while appropriately replacing the separating matrix and the all-null spatial filter, which are applied to the separation process, with the latest one. The learning processing unit 130 provides the separating matrix and the all-null spatial filter, and the separation processing unit 123 applies the separating matrix and the all-null spatial filter which are provided from the learning processing unit 130, thereby performing the sound source separation process. In the three elements added to the configuration according to the embodiment of the invention, the generation of the all-null spatial filter is performed as a background process in the learning processing unit 130 in the same manner as the learning of the separating matrix. However, the frequent rescaling for the separating matrix and all-null spatial filter, the application of those to the observed signals, the frequency filtering, and the like are performed as foreground processes in the separation processing unit 123.
Hereinafter, processes of individual components will be described.
Sounds recorded by a plurality of microphones 121 are converted into digital signals by an AD conversion unit 122, and then sent to a Fourier transform section 124 of the separation processing unit 123. In the Fourier transform section 124, the digital signals are transformed into frequency-domain data by a windowed short-time Fourier transform (STFT) (details of which will be given later). At this time, a predetermined number of pieces of data called frames are generated. Subsequent processes are performed in units of the frames. The Fourier transformed data is sent to each of the covariance matrix calculation section 125, a separating matrix application section 126, the all-null spatial filtering section 127, and a thread control section 131.
Hereinafter, first, the flow of the signals in the foreground process in the separation processing unit 123 will be described. Then, the process of the learning processing unit 130 will be described.
The covariance matrix calculation section 125 of the separation processing unit 123 inputs the Fourier transform data of the observed signals generated by the Fourier transform section 124, thereby calculating the covariance matrices of the observed signals for each frame. The details of the calculation will be described later. The covariance matrices obtained herein are used to perform the rescaling for each frame in each of the separating matrix application section 126 and all-null spatial filtering section 127. In addition, the degree of the application of the frequency filtering to the frequency filtering section 128 is used as a criterion for determination.
In the separating matrix application section 126, the rescaling is performed on the separating matrix which was obtained in the learning processing unit 130 before the current time, that is, the separating matrix which is held in the separating matrix holding portion 133. Subsequently, the observed signals corresponding to one frame are multiplied by the rescaled separating matrix, thereby generating the separating-matrix application result corresponding to one frame.
In the all-null spatial filtering section 127, the rescaling is performed on the all-null spatial filter which was obtained in the learning processing unit 130 before the current time, that is, the all-null spatial filter which is held in the all-null spatial filter holding portion 134. Then, the observed signals corresponding to one frame are multiplied by the rescaled all-null spatial filter, thereby generating the all-null spatial filtering result corresponding to one frame.
The frequency filtering section 128 receives the result of the application of the separating matrix to the Fourier transform data based on the observed signals from the separating matrix application section 126, while receiving the result of the application of the all-null spatial filter to the Fourier transform data based on the observed signals from the all-null spatial filtering section 127. On the basis of both application results, the frequency filtering section 128 performs the 2-channel frequency filtering described above with reference to
The separation results sent to the inverse Fourier transform section 129 are transformed into time-domain signals, and are sent to a subsequent stage processing section 136. Examples of processing at a subsequent stage executed by the subsequent stage processing section 136 include sound recognition, speaker recognition, sound output, and the like. Depending on the subsequent-stage processing, frequency-domain data can be used as it is, in which case the inverse Fourier transform can be omitted.
Next, the Fourier transform section 124 also provides the Fourier transform data based on the observed signals to the thread control section 131 of the learning processing unit 130.
The observed signals sent to the thread control section 131 are sent to a plurality of learning threads 132-1 to 132-N of the thread computation processing section 132. The individual learning threads accumulate the given observed signals by a predetermined amount, and then find a separating matrix from the observed signals by using ICA batch processing. This processing is the same as the processing described above with reference to
The dotted line from the all-null spatial filtering section 127 and separating matrix application section 126 to the thread control section 131 indicates that the latest rescaled all-null spatial filter and separating matrix are reflected in initial learning value. Detailed description thereof will be given in “5. Other Examples (Modified Examples) of Signal Processing Apparatus of Embodiment of the Invention” in the latter part.
Next, referring to
A current-frame-index holding counter 151 is incremented by 1 every time one frame of observed signals is supplied, and is returned to the initial value upon reaching a predetermined value.
A learning-initial-value holding portion 152 holds the initial value of the separating matrix W when executing a learning process in each thread. Although the initial value of the separating matrix W is basically the same as that of the latest separating matrix, a different value may be used as well. For example, the separating matrix, to which the rescaling (a process of adjusting power between frequency bins, details of which will be given later) has not been applied, is used as the learning initial value, and the separating matrix, to which rescaling has been applied, is used as the latest separating matrix.
A planned-accumulation-start timing specifying information holding portion 153 holds information used for keeping the timing of starting accumulating at a constant interval between a plurality of threads. The use method will be described later. The planned-accumulation-start timing may be expressed by using relative time, or may be managed by the frame index or by the sample index of time-domain signal instead of relative time. The same applies to information for managing other kinds of “time” and “timing”.
An observed-signal-accumulation timing information holding portion 154 holds information representing which timing the observed signals, which are used as the basis for the learning of the separating matrix W being currently used in the separating section 127, are acquired at, that is, the relative time or frame index of observed signals corresponding to the latest separating matrix. Both the accumulation start and accumulation end timings of corresponding observed signals may be stored in the observed-signal-accumulation timing information holding portion 154. However, when the block length, that is, the accumulation time of the observed signals is constant, it suffices to store only one of these timings.
Further, the thread control section 131 has a pointer holding portion 155 which holds pointers linked to the individual threads, and controls the plurality of threads 132-1 to 132-N by using the pointer holding portion 155.
Next, referring to
The observed signal buffer 161 holds observed signals supplied from the thread control section 131.
The separation result buffer 162 holds the separation results, which are computed by the learning computation portion 163, prior to separating-matrix convergence.
The learning computation portion 163 executes a process of separating observed signals accumulated in the observed signal buffer 161, on the basis of a separating matrix W used for the separation process which is held in the separating matrix holding portion 164, accumulating the separation results into the separated-result buffer 162, and also updating the separating matrix being learned by using the separation results accumulated in the separated-result buffer 162.
The thread computation section 132 (=learning thread) is a state transition machine, and the current state is stored in a state storage portion 165. The state of a thread is controlled by the thread control section 131 on the basis of the counter value of a counter 166. The counter 166 changes in value in synchronization with supply of one frame of the observed signals, and switches its state on the basis of this value. Detailed description thereof will be given later.
An observed-signal start/end timing holding portion 167 holds at least one of pieces of information representing the start timing and the end timing of observed signals used for learning. As described above, information representing the timing may be the frame index or sample index, or may be the relative time information. In this case as well, although both the start timing and the end timing may be stored, when the block length, that is, the accumulation time of the observed signals is constant, it suffices to store only one of these timings.
A learning end flag 168 is a flag used for notifying the end of learning to the thread control section 131. At the time of activation of a thread, the learning end flag 168 is set OFF (flag is not up), and at the point when the learning ends, the learning end flag 168 is set ON. Then, after the thread control section 131 recognizes that the learning has ended, the learning end flag 168 is set OFF again through control of the thread control section 131.
In addition, the values in the data of the state storage portion 165, the counter 166, and the observed-signal start/end timing holding portion 167 can be rewritten by an external module such as the thread control section 131. For example, while the learning loop is run in the thread computation section 132, the thread control section 131 is able to change the value of the counter 166.
A preprocessing data holding portion 169 is an area that stores data which becomes necessary when observed signals to which preprocessing has been applied are returned to the original state. Specifically, for example, in cases where normalization of observed signals (adjusting the variance to 1 and the mean to 0) is executed in preprocessing, since values such as a variance (or a standard deviation or its inverse) and a mean are held in the preprocessing data holding portion 169, source signals prior to normalization can be recovered by using these values. In cases where, for example, decorrelation (also referred to as pre-whitening) is executed as preprocessing, a matrix, by which the observed signals are multiplied during the decorrelation, is held in the preprocessing data holding portion 169.
The all-null spatial filter holding portion 160 holds a filter that form null beams toward all the sound sources included in the observed signal buffer 161. The filter is generated from the separating matrix at the time of the learning end. Alternatively, there is a method of generating the filter from the data of the observed signal buffer. The generation method will be described later.
Next, the state transition of the learning threads 132-1 to 132-N will be described with reference to
In the learning state, a learning process loop is executed until the separating matrix W converges (or a predetermined number of times), and a separating matrix corresponding to the observed signals accumulated in the accumulating state is found. After the separating matrix W converges (or after the learning process loop is executed a predetermined number of times), the state transitions to waiting.
Then, in the waiting state, accumulating or learning of observed signals is not executed for a specified time, and the thread is put in the waiting state. The time for which the waiting state is maintained is determined by the time it took for learning. That is, as shown in
While these times may be managed in units of, for example, milliseconds, the times may be measured in units of frames that are generated by a short-time Fourier transform. In the following description, it is assumed that these times are measured (for example, counted up) in units of frames.
Referring to
The time necessary for accumulating observed signals is referred to as block length (block_len) (refer to
The state transitions from “accumulating to learning” and “waiting to accumulating” are made on the basis of the counter value. That is, within the thread that has started from “accumulating” (the accumulating state 171 in
When learning is finished, the state is made to transition to “waiting” (the waiting state 173 in
On the other hand, as for the thread that has transitioned from the “initial state” 181 to “waiting” (the waiting state 173 in
To realize these operations, the counter of the thread 2 is set as:
(thread length)−(block shift width): (thread_len)−(block_shift).
In addition, the counter of the thread 3 is set as:
(thread length)−(2×block shift width): (thread_len)−(block_shift×2).
With these settings, after the value of the counter reaches the thread length (thread_len), the state transitions to “accumulating”, and thereafter, as in the thread 1, the cycle of “accumulating, learning, and waiting” is repeated.
The number of learning threads to be prepared is determined by the thread length and the block shift width. Letting the thread length be represented as thread_len, and the block shift width be represented as block_shift, the number of necessary learning threads is found by
(thread length)/(block shift width), that is, thread_len/block_shift.
The fractions thereof are rounded off.
For example, in
[thread length (thread_len)]=1.5×[block length (block_len)], and
[block shift width (block_shift)]=0.25×block length (block_len)].
Hence, the number of necessary threads is 1.5/0.25=6.
3-1. Entire Sequence
Next, referring to the flowchart shown in
First, referring to the flowchart in
The sound input in step S103 is a process of capturing a predetermined number of samples from an audio device (or a network, a file, or the like depending on the embodiment) (this process will be referred to as “capture”), and storing the captured samples in a buffer. This is performed for the number of microphones. Hereinafter, the captured data will be referred to as an observed signal.
Next, in step S104, the observed signal is sliced off for each predetermined length, and a short-time Fourier transform (STFT) is performed. Details of the short-time Fourier transform will be described with reference to FIG. 18.
For example, an observed signal xk recorded with the k-th microphone in the environment as shown in
The frames to be sliced may be overlapped, like the frames 191 to 193 shown in the drawing, which makes it possible for the spectrums Xk(t−1) to Xk(t+1) of consecutive frames to change smoothly. Spectrums, which are laid side by side in accordance with the frame index, are referred to as spectrograms.
Since there is a plurality of input channels (equal to the number of microphones) according to an embodiment of the invention, the Fourier transform is also performed for the number of channels. In the following, the Fourier transformed results corresponding to all channels and one frame are represented by a vector X(t) (Expression [3.11] described above). In Expression [3.11], n denotes the number of channels (=the number of microphones). M denotes the total number of frequency bins, and letting J represent the number of points in the short-time Fourier transform, M=J/2+1.
Returning to the flow in
Next, separation is performed on the observed signals X(t), which are generated in step S105, in step S106. Letting the separating matrix be W (Expression [3.10]), the separation results Y(t) (Expression [3.4]) are found by
Y(t)=WX(t) (Expression [3.12]).
Next, in step S107, an inverse Fourier transform (inverse FT) is applied to the separation results Y(t), thereby recovering the signals back to time-domain signals. Thereafter, in step S108, the separation results are transmitted to subsequent-stage processing. The above steps S103 to S108 are repeated to the end.
3-2. Initialization Process (S101)
Details of the initialization process in step S101 in the flowchart shown in
In step S151, the thread control section 131 shown in
The current-frame-index holding counter 151 (refer to
An appropriate initial value is substituted into the learning-initial-value holding portion 152 (refer to
Further, in the planned-accumulation-start timing specifying information holding portion 153, the calculated value of the following expression is set:
(number of necessary threads−1)×[block shift width (block_shift)].
This value indicates the timing (the frame index) at which accumulating of the thread with the largest thread index starts.
Then, since timing information (frame index or relative time information) representing observed signals corresponding to the latest separating matrix is held in the observed-signal-accumulation timing information holding portion 154, initialization is performed at this time, and 0 is held.
In the separating matrix holding portion 133 (refer to
Further, an initial value is substituted into the all-null spatial filter holding portion 134 (refer to
An initial value is also substituted into the power ratio holding portion 135 (refer to
In step S152, the thread control section 131 secures the number N of necessary threads to be executed in the thread computation section 132, and sets their state to the “initialized” state.
At this time, the number N of necessary threads is obtained by rounding off decimals of thread length/block shift width (thread_len/block_shift) (that is, an integer larger than and closest to the value of thread_length/block_shift).
In step S153, the thread control section 131 starts a thread loop, and until initialization of all threads is finished, the thread control section 131 detects uninitialized threads and executes the processes from step S154 to step S159. The loop is run for the number of threads generated in step S152. It should be noted that the thread index increases in order from 1 and is represented as a variable “s” in the loop (instead of the loop, parallel processes may be performed for the number of learning threads, it is the same for the loop of the learning threads to be described later).
In step S154, the thread control section 131 determines whether or not the thread index is 1. Since the initial setting is different between the first thread and the others, the process branches in step S154.
If it is determined in step S154 that the thread index is 1, in step S155, the thread control section 131 controls a thread with a thread index 1 (for example, the thread 132-1), and initializes its counter 166 (refer to
In step S156, the thread control section 131 issues, to the thread with the thread index 1 (for example, the thread 132-1), a state transition command for causing the state to transition to the “accumulating” state, and the process advances to step S159. The state transition is performed by issuing, from the thread control section to the learning thread, a command (hereinafter referred to as a “state transition command”) to the effect that “transition to the designated state” (in the following description, it is the same for all kinds of state transitions).
If it is determined in step S154 that the thread index is not 1, in step S157, the thread control section 131 sets the value of the counter 166 of the corresponding thread (one of the threads 132-2 to 132-N) to thread_len−block_shift×(thread index−1).
In step S158, the thread control section 131 issues a state transition command for causing the state to transition to the “waiting” state.
After the process in step S156 or step S158, in step S159, the thread control section 131 initializes information within the thread which has not been initialized yet, that is, information representing a state stored in the state storage portion 165 (refer to
When all the threads secured in the thread computation section 132, that is, the threads 132-1 to 132-N have been initialized, in step S160, the thread loop is ended, and the initialization ends.
Through such processing, the thread control section 131 initializes all of the plurality of threads secured in the thread computation section 132.
The processes in step S154 to S158 in
3-3. Thread Control Process (S105)
Next, referring to the flowchart in
It should be noted that this flowchart represents a flow as seen from the thread control section 131, and not from the learning threads 132-1 to 132-N. For example, “learning-state process” is defined as a process performed by the thread control section 131 when the state of a learning thread is “learning” (regarding the process of the learning thread itself, refer to
Steps S201 to S206 represent a loop for a learning thread, and the loop is run for the number of threads generated in step S152 of the flow shown in
A description will be given of individual steps in the flow. In step S201, the thread control section 131 starts a thread loop, and with a variable “s”, which indicates the thread index of a thread on which control is executed, set as s=1, the thread control section 131 increments the variable “s” when one thread is finished, and repeats the thread loop process from steps S202 to S207 until s=N.
In step S202, the thread control section 131 acquires information representing the internal state of a thread having a thread index indicated by the variable “s”, which is held in the state storage portion 165 for the thread. If it is detected that the state of the thread having a thread index indicated by the variable “s” is “waiting”, in step S203, the thread control section 131 executes a waiting-state process, which will be described later with reference to the flowchart in
If it is detected in step S202 that the state of the thread having a thread index indicated by the variable “s” is “accumulating”, in step S204, the thread control section 131 executes an accumulating-state process, which will be described later with reference to the flowchart in
If it is detected in step S202 that the state of the thread having a thread index indicated by the variable “s” is “learning”, in step S205, the thread control section 131 executes a learning-state process, which will be described later with reference to the flowchart in
After finishing the process in step S203, step S204, or step S205, in step S206, the thread control section 131 increments the variable “s” by 1. Then, when the variable “s” indicating the thread index of a thread on which control is executed has become s=N, the thread loop is ended.
In step S207, the thread control section 131 increments the frame index held in the current-frame-index holding counter 151 (refer to
Through such processing, the thread control section 131 is able to control all of the plurality of threads in accordance with their state.
While it has been described above that the thread loop is repeated for the number N of launched threads, instead of repeating the thread loop, parallel processes corresponding to the number N of threads may be executed.
Next, referring to the flowchart in
This waiting-state process is a process that is executed by the thread control section 131 when the state of a thread corresponding to the variable “s” is “waiting” in the thread control process described above with reference to
In step S211, the thread control section 131 increments the counter 166 (refer to
In step S212, the thread control section 131 determines whether or not the value of the counter 166 of the corresponding thread 132 is smaller than the thread length (thread_len). If it is determined in step S212 that the value of the counter 166 is smaller than the thread length, the waiting-state process is ended, and the process advances to step S206 in
If it is determined in step S212 that the value of the counter 166 is not smaller than the thread length, in step 5213, the thread control section 131 issues to the corresponding thread 132 a state transition command for causing the state of the thread 132 to transition to the “accumulating” state.
That is, the thread control section 131 issues a state transition command for causing a thread, which is in the “waiting” state in the state transition diagram described above with reference to
In step S214, the thread control section 131 initializes the counter 166 (refer to
Through such processing, the thread control section 131 is able to control a thread that is in the “waiting” state, and on the basis of the value of the counter 166 of the thread, cause the state of the thread to transition to “accumulating”.
Next, referring to the flowchart in
This accumulating-state process is a process that is executed by the thread control section 131 when the state of a thread corresponding to the variable “s” is “accumulating” in the thread control process described above with reference to
In step S221, the thread control section 131 supplies observed signals X(t), which corresponds to one frame, to the corresponding thread 132 for learning. This process corresponds to the supply of observed signals from the thread control section, which is shown in
In step S222, the thread control section 131 increments the counter 166 of the corresponding thread 132 by 1.
In step S223, the thread control section 131 determines whether or not the value of the counter 166 of the corresponding thread 132 is smaller than the block length (block_len), in other words, whether or not the observed signal buffer 161 (refer to
If it is determined in step S223 that the value of the counter 166 is not smaller than the block length, in other words, the observed signal buffer 161 of the corresponding thread is full, in step S224, the thread control section 131 issues, to the corresponding thread 132, a state transition command for causing the state of the thread 132 to transition to the “learning” state. Then, the accumulating-state process is ended, and the process advances to step S206 in
That is, the thread control section 131 issues a state transition command for causing a thread, which is in the “accumulating” state in the state transition diagram described above with reference to
Through such processing, the thread control section 131 can supply observed signals to a thread that is in the “accumulating” state to control the accumulating of the observed signals, and on the basis of the value of the counter 166 of the thread, cause the state of the thread to transition from “accumulating” to “learning”.
Next, referring to the flowchart in
This learning-state process is a process that is executed by the thread control section 131 when the state of a thread corresponding to the variable “s” is “learning” in the thread control process described above with reference to
In step S231, the thread control section 131 determines whether or not the learning end flag 168 (refer to
If it is determined in step S231 that the learning end flag is not ON, that is, a learning process is being executed in the corresponding thread, the process advances to step S232 where a process of comparing times is performed. The “comparing of times” refers to a process of comparing the observed-signal start time 167 (refer to
On the other hand, when the observed-signal start time 167 (refer to
Next, in step S234, the thread control section 131 determines whether or not the value of the counter 166 of the corresponding thread 132 is smaller than the thread length (thread_len). If it is determined in step S234 that the value of the counter 166 is smaller than the thread length, the learning-state process is ended, and the process advances to step S206 in
If it is determined in step S234 that the value of the counter 166 is not smaller than the thread length, in step S235, the thread control section 131 subtracts a predetermined value from the value of the counter 166. Then, the learning-state process is ended, and the process advances to step S206 in
The case where the value of the counter reaches the thread length during learning corresponds to a case where learning takes such a long time that the period of “waiting” state does not exist. In that case, since learning is still continuing, and the observed signal buffer 161 is being used, it is not possible to start the next accumulating. Accordingly, until learning ends, the thread control section 131 postpones the start of the next accumulating, that is, issuing of a state transition command for causing the state to transition to the “accumulating” state. Hence, the thread control section 131 subtracts a predetermined value from the value of the counter 166. While the value to be subtracted may be, for example, 1, the value may be larger than 1, for example, a value such as 10% of the thread length.
When the transition to the “accumulating” state is postponed, the interval of the accumulation start time becomes irregular between threads, and in the worst cases, there is even a possibility that observed signals of substantially the same segment are accumulated between the pluralities of threads. When this happens, not only do several threads become meaningless, but for example, depending on the multi-threaded implementation of the OS executed by a CPU, there is a possibility that the learning time further increases as a plurality of learning processes are simultaneously run on the single CPU, and the interval becomes further irregular.
To avoid such a situation, the wait times in other threads may be adjusted so that the interval of the accumulation start timing becomes regular again. This process is executed in step S241. Details of this wait-time adjusting process will be described later.
A description will be given of the process in a case when the learning end flag is determined to be ON in step S231. This process is executed once every time a learning loop within a learning thread ends. If it is determined in step S231 that the learning end flag is ON, and a learning process has ended in the corresponding thread, in step S237, the thread control section 131 sets the learning end flag 168 of the corresponding thread 132 OFF. This process represents an operation for preventing this branch from being continuously executed.
Thereafter, the thread control section 131 checks whether or not an abort flag 170 (refer to
Through such processing, the thread control section 131 can determine whether or not learning has ended in a thread in the “learning” state by referring to the learning end flag 168 of the corresponding thread. If the learning has ended, the thread control section 131 updates the separating matrix W and sets the wait time, and also causes the state of the thread to transition from “learning” to “waiting” or “accumulating”.
Next, referring to the flowchart in
In step S251, the thread control section 131 determines whether or not the start timing of observed signals is earlier than the accumulation start timing by comparing those with each other. The start timing of observed signals is held in the observed-signal start/end timing holding portion 167 (refer to
That is, as shown in
In this regard, when the determination in step S251 is not executed, and a separating matrix in which learning has ended later is treated as the latest separating matrix, a separating matrix W2 derived from the thread 2 is overwritten by a separating matrix W1 derived from the thread 1 which is obtained by learning with observed signals acquired at the earlier timing. Accordingly, to ensure that a separating matrix obtained with observed signals acquired at the later timing is treated as the latest separating matrix, the start timing of observed signals held in the observed-signal start/end timing holding portion 167 is compared with the accumulation start timing corresponding to the current separating matrix which is held in the observed-signal-accumulation timing information holding portion 154.
In step S251, it may be determined that the start timing of observed signals is earlier than the accumulation start timing corresponding to the current separating matrix. In other words, it may be determined that the separating matrix W obtained as a result of learning in this thread has been learned on the basis of signals observed at an earlier timing than those corresponding to the separating matrix W being currently held in the observed-signal-accumulation timing information holding portion 154. In this case, the separating matrix W obtained as a result of learning in this thread is not used, and thus the process of updating the separating matrix and the like ends.
In step S251, it may be determined that the start timing of observed signals is not earlier than the accumulation start timing corresponding to the current separating matrix. That is, it may be determined that the separating matrix W obtained as a result of learning in this thread has been learned on the basis of signals observed at a later timing than those corresponding to the separating matrix W being currently held in the observed-signal-accumulation timing information holding portion 154. In this case, in step S252, the thread control section 131 acquires the separating matrix W obtained by learning in the corresponding thread, and supplies the separating matrix W to the separating matrix holding portion 133 (refer to
In step S253, the thread control section 131 sets the initial value of learning in each of threads held in the learning-initial-value holding portion 152.
Specifically, as the learning initial value, the thread control section 131 may set a separating matrix W obtained by learning in the corresponding thread, or may set a value different from a separating matrix W which is computed by using the separating matrix W obtained by learning in the corresponding thread. For example, the value, which is obtained after rescaling is applied, is substituted into the separating matrix holding portion 133 (refer to
In step S254, the thread control section 131 sets timing information held in the observed-signal start/end timing holding portion 167 (refer to
Through the process in step S254, an indication is provided regarding from observed signals in what time segment the separating matrix W being currently used, that is, the separating matrix W held in the separating matrix holding portion 133 has been learned.
Next, referring to the flowchart in
In step S281, the thread control section 131 calculates the remaining wait time.
Specifically, let rest represent the remaining wait time (the number of frames), Ct represent the planned-accumulation-start timing (the frame index or the corresponding relative time) held in the planned-accumulation-start timing specifying information holding portion 153 (refer to
rest=Ct+block_shift−Ft.
That is, since Ct+block_shift means the planned next accumulation start time, by subtracting Ft from this, the “remaining time until the planned next accumulation start time” is found.
In step S282, the thread control section 131 determines whether or not the calculated remaining wait time rest is a positive value. If it is determined in step S282 that the calculated remaining wait time rest is not a positive value, that is, the calculated value is zero or a negative value, the process advances to step S286 described later.
If it is determined in step S282 that the calculated remaining wait time rest is a positive value, in step S283, the thread control section 131 issues to the corresponding thread a state transition command for causing the state of the thread to transition to the “waiting” state.
In step S284, the thread control section 131 sets the value of the counter 166 (refer to
In step S285, the thread control section 131 adds the value of block_shift to the value Ct held in the planned-accumulation-start timing specifying information holding portion 153 (refer to
If it is determined in step S282 that the calculated remaining wait time rest is not a positive value, that is, the calculated value is zero or a negative value, this means that accumulating has not started even through the planned-accumulation-start timing is passed. Therefore, it is necessary to start accumulating immediately. Accordingly, in step S286, the thread control section 131 issues to the corresponding thread a state transition command for causing the state of the thread to transition to the “accumulating” state.
In step S287, the thread control section 131 initializes the value of the counter (for example, sets the counter to 0).
In step S288, the thread control section 131 sets the next accumulation start timing, that is, Ft indicating the current frame index, in the planned-accumulation-start timing specifying information holding portion 153, and ends the remaining-wait-time calculating process.
Through such processing, in accordance with the time necessary for the “learning state” in each thread, the time, for which each thread is to be placed in the “waiting” state, can be set.
3-4. Separation Process (S106)
Next, referring to the flowchart shown in
The steps S301 to S310 shown in the flow of
In step S302, necessary covariance matrices are calculated in advance by the rescaling to be described later. This is a process corresponding to the covariance matrix calculation section 125 shown in
However, the segment in which the uniform operation <•>t is performed is the block 87 including the current time shown in
Next, in step S303, the rescaling of the separating matrix is performed. The rescaling is the same as the “frequent rescaling” described above in the section of “1. Configuration of Embodiment of the Invention and Brief Overview of Processing”. The purpose of the rescaling process is for reducing distortion which is caused when the sudden sound is output. Basic idea of the rescaling is such that the separation results are projected onto specific microphones. Here, “projected onto specific microphones” means that, for example in
The rescaling process is performed by using the frame including the current observed signals among the frames as data units which are cut out from the observed signals. As described above, the covariance matrix calculation section 125 of the separation processing unit 123 inputs the Fourier transform data of the observed signals generated by the Fourier transform section 124, thereby calculating the covariance matrices of the observed signals for each frame. The covariance matrices obtained herein are used to perform the rescaling for each frame in each of the separating matrix application section 126 and all-null spatial filtering section 127.
For the rescaling process, first a rescaling matrix R(ω) is found on the basis of Expressions [4.1] and [4.2] mentioned above. Next, a diagonal matrix, in which the 1-th row (“1” (a lower-case letter of L) is an index of the microphone as the projection target) of the rescaling matrix R(ω) is formed as its elements, is found (the first term of the right side of Expression [4.6]). The diagonal matrix is multiplied to the separating matrix W(ω) before the rescaling, thereby obtaining a rescaled separating matrix W′(ω) (Expression [4.6]).
In step S304, the rescaled separating matrix W′(ω) is multiplied to the observed signal X(ω,t) (Expression [4.7]), thereby obtaining the separating-matrix application result Y′(ω,t).
Y′(ω,t)=W′(ω)×X(ω,t)
This process corresponds to a linear filtering process using the rescaled separating matrix W′(ω) to the observed signal X(ω,t).
The processes in steps S303 and S304, in the processing example shown in
acquiring the observed signal X(t) 82 at the current time, and applying the separating matrix 83.
The separating matrix 83 shown in
Further, readjustment based on Expressions [4.8] and [4.9] is performed as necessary. This is a process of checking whether the sum of the elements of the rescaled separating-matrix application result Y′(ω,t) does not exceed the absolute value of the observed signal X1(ω,t) corresponding to the microphone as a projection target and, if the sum exceeds the absolute value, decreasing the absolute value of Y′(ω,t). The rescaling factor obtained by Expression [4.1] tends to be a large value as long as the sound remains in the segment (87 in
Next, in step S305, the rescaling is performed on the all-null spatial filter. The purpose of the rescaling is for canceling out the sudden sounds through the later-described frequency filtering by adjusting the scale between the sudden sound which is included in the application result of the all-null spatial filter and the sudden sound which is included in the application result of the separating matrix.
The separation processing unit 123 shown in
For example, in the configuration shown in
In step S305, in the process of rescaling the all-null spatial filter, the rescaling matrix Q(ω) is found by Expressions [7.1] and [7.2] below (Y′(ω,t) in Expression [7.1] is a value prior to the application of the readjustment of Expression [4.9]).
However, B(ω) in Expression [7.2] is the all-null spatial filter before the rescaling, and is a filter which generates one output from n inputs (a method of calculating B(ω) will be described later). Further, Z(ω,t) in Expression [7.1] is the all-null spatial filtering result before the rescaling, and is calculated by Expression [5.5]below.
Here, Z(ω,t) is not a vector, but a scalar. Further, Q(ω) is a row vector (a horizontally long vector) formed of n elements. By multiplying Q(ω) by B(ω) (Expression [7.3]), the rescaled all-null spatial filter B′(ω) is obtained. B′(ω) is a matrix with n rows and n columns.
In step S306, by multiplying the rescaled all-null spatial filter B′(ω) by the observed signals (Expression [7.4]), the rescaled all-null spatial filtering result Z′(ω,t) is obtained. However, μk(ω) in Expression [7.4] is obtained by Expression [4.8], and when readjusting Y′(ω,t), is for readjusting Z′(ω,t) as well.
The all-null spatial filtering result Z′(ω,t) is a column vector (a vertically long vector) formed of n elements, and the k-th element thereof is the all-null spatial filtering result in which the scale is adjusted to Y′k(ω,t).
Steps S305 and S306, as described with reference to the process in
acquiring the observed signal X(t) 82 at the current time, generating the rescaled all-null spatial filter B′(ω) 84, and multiplying the observed signal to the rescaled all-null spatial filter B′(ω) (Expression [7.4]) so as to thereby obtain the rescaled all-null spatial filtering result Z′(ω,t).
The next steps S307 to S310 are a loop, and means that the frequency filtering in step S308 is performed for each channel. It should be noted that, instead of the loop, the steps may be executed as parallel processes.
The frequency filtering in step S308 is a process of multiplying, for each frequency, a different factor to the rescaled separating-matrix application result Y′k(ω,t) (the k-th element of the vector Y′(ω,t)). However, in the embodiment of the invention, the frequency filtering is used for removing the rescaled all-null spatial filtering result (substantially the same as the sudden sound) from the rescaled separating-matrix application result Y′k(ω,t).
As examples of the frequency filtering, the following three points will be described.
(1) Complex Subtraction
(2) Spectral Subtraction
(3) Wiener Filter
(1) First, the frequency filtering based on the complex subtraction will be described. This process is a filtering process of removing signal components corresponding to the signals, which are filtered with the all-null spatial filters, included in the separated signals through the process of subtracting the signals filtered with the all-null spatial filters from the separated signals which are generated by applying the separating matrix.
The following Expression [8.1] is an expression representing the complex subtraction.
In Expression [8.1] described above, the factor αk is a real number of 0 or more. By using the factor, “(3) Determination for Individual Channels”, which is described above in the section of “1. Configuration of Embodiment of the Invention and Brief Overview of Processing”, is realized.
That is, in order to perform different processes in accordance with characteristics of the sudden sound, it is determined whether the respective output channels of ICA output the signals corresponding to the sound sources, and one of the processes is performed depending on the result thereof.
i) If it is determined that the signals corresponds to the sound sources, both the “frequent rescaling” and the “all-null spatial filter & frequency filtering” are applied.
As a result, the sudden sound is removed from the channels.
ii) If it is determined that the signals does not correspond to the sound sources, only the “frequent rescaling” is applied. As a result, the sudden sound is output from the channels.
This is referred to as “determination for individual channels”.
As described above, depending on whether the respective channels output the signals corresponding to the sound sources before the sudden sound is generated, the amount of reduction in sudden sound is adjusted.
There are various methods of determining whether or not the output of each channel corresponds to the sound sources. However, in the following description, a method of using a power of the separating-matrix application result is adopted. That is, the following properties are used: the channels corresponding to the sound sources have relatively large powers; and the channels not corresponding to the sound sources have relatively small powers.
The factor αk represented by Expression [8.1] described above is calculated by Expression [8.5]. In this expression, rk is a power ratio of the channel k, and α is the maximum of αk. The power ratio is a ratio of a power of each channel (k) to a total power of all observed sounds or to a power of the maximum sound. The power ratio rk is calculated by applying Expression [8.6] or [8.7], where the power (the volume) of the channel k is represented by Vk. Details of the expressions will be described later.
The f( ) is defined as a function of setting a value, which is equal to or more than 0 and equal to or less than 1, to a return value, and a function represented by Expression [8.10] and the graph shown in
The fmin in Expression [8.10] is 0 or a small positive value. The effect of setting fmin to a value other than 0 will be described later.
The frequency filtering in step S308 is performed by the frequency filtering section 128 shown in
The power ratio rk is calculated by Expressions [8.6] to [8.9], but the uniform operation <•>t included in Expressions [8.8] and [8.9] is performed in the same segment as the observed signals used for learning the separating matrix. That is, the segment is not the segment of the block 87, which includes the current time in the processing example shown in
Through the complex subtraction (Expression [8.1]), it is also possible to remove the sudden sound. However, since that is a kind of the linear filtering, it is difficult to solve the problem in “the trade-off between the tracking lag and the residual sound” described in “Problems of Related Art”. On the other hand, when non-linear frequency filtering described below is used, the trade-off can be solved.
Expression [8.2] described above is a general expression of the frequency filtering. That is, the term, which is obtained by normalizing the rescaled separating-matrix application result Y′k(ω,t) by the absolute value, that is,
Y′k(ω,t)/|Y′k(ω,t)|
is multiplied by gain Gk(ω,t). Depending on the frequency filtering, there are various methods of calculating the gain, but in the spectral subtraction method (the spectral subtraction) described below, the gain is calculated from a difference of spectral amplitudes.
(2) The frequency filtering based on the spectral subtraction will be described.
The frequency filtering process based on the spectral subtraction is a filtering process of removing signal components, which correspond to the signals, which are filtered with the all-null spatial filters, included in the separated signals generated by applying the separating matrix, through a frequency filtering process based on a spectral subtraction of setting the signals filtered with the all-null spatial filters as noise components.
The expressions in the spectral subtraction method is just as in Expressions [8.3] and [8.4] described above. Expression [8.3] is subtraction of the amplitude itself, and is called Magnitude Spectral Subtraction. Expression [8.4] is subtraction of the square of the amplitude, and is called Power Spectral Subtraction. In both expressions, max{A, B} represents an operation of setting a larger one of the two parameters to a return value. The αk is a term which is generally called an over-subtraction factor. However, in the embodiment of the invention, by computing Expression [8.5], the term has a function of adjusting an amount of the subtraction depending on whether “the signal corresponding to the sound source is output”. The β is called a flooring factor, and is a small value (for example, 0.01) close to 0. The second term of max{ } prevents the gain obtained after the subtraction from being 0 or a negative value.
The calculation of αk is, as in the complex subtraction, performed on the basis of Expressions [8.5] to [8.10]. In Expression [8.10], when fmin is set to a small positive value instead of 0,
even when rk<r—min, the frequency filtering has a small effect, and thus it is possible to remove the “residual sound” to a certain extent.
(3) The frequency filtering based on Wiener filter will be described.
The Wiener filter is a filter for calculating the factor Gk(ω,t) on the basis of the priori SNR which is a power ratio between the target sound and the interference sound. When the priori SNR is given, it is common knowledge that the factor found by the Wiener filter is optimal in terms of square error minimization in the performance of removing the interference sound. Regarding details of the Wiener filter, refer to, for example, the following.
Japanese Patent Application No. 2007-533331 [H18.8.31]
PCT Application No. WO07/026,827 [H21.3.12]
Title of the Invention: Post Filter for Microphone Array
Applicant: Japan Advanced Institute of Science and Technology, Toyota Motor Corp.
Inventors: Masato AKAGI, Junfeng LI, Masaaki UECHI, and Kazuya SASAKI
On the basis of the Wiener filter, in order to calculate the factor, the value of the priori SNR is necessary, but the value is generally not given. Here, instead of the priori SNR, a posteriori SNR, which is a power ratio between the observed signal and the interference sound, and a one-frame-based priori SNR, in which the processing result in the previous frame is regarded as the target sound, may be used. Accordingly, there are proposed methods of estimating the priori SNR for each frame by using the above-mentioned SNRs, and the methods are called Decision Directed (DD) methods. The method of removing the sudden sound by using the DD method will be described with reference to Expressions [8.12] to [8.14] (in the expressions, the superscript [post] and [prior] is to represent “posteriori” and “priori” distinctly).
Expression [8.12] is an expression for finding the posteriori SNR corresponding to one frame. In the expression, αk is calculated from Expression [8.5] and the like. However, in the Wiener filter, it is not necessary to perform the over-subtraction, and thus the setting may be made so that α=1. Alternatively, by setting α<1, it is also possible to reduce the effect of removal of the sudden sound. Next, on the basis of Expression [8.13], the estimate value of the priori SNR is calculated. In the expression, K is a forgetting factor, and uses a value less than 1 and close to 1.
From the estimate value of the priori SNR, the factor Gk(ω,t) of the frequency filtering is calculated by using Expression [8.14].
As the frequency filtering method, in the above,
(1) Complex Subtraction,
(2) Spectral Subtraction, and
(3) Wiener Filter,
were described, but other than the methods, the following methods can be also adopted.
(4) Minimum Mean Square Error (MMSE) Short Time Spectral Amplitude (STSA), or MMSE Log Spectral Amplitude (LSA)
Regarding details thereof, refer to the following.
* “MMSE STSA with Noise Estimation Based on Independent Component Analysis”
Ryo OKAMOTO, Yu TAKAHASHI, Hiroshi SARUWATARI and Kiyohiro SHIKANO,
Collection of Lecture Notes, Acoustical Society of Japan, 2-9-6, pp. 663-666, March 2009.
*Japanese Patent Publication No. 4172530, Noise Suppression Method, Apparatus, And Computer Program
*“Diffuse Noise Suppression by Crystal-Array-Based Post-Filter Design”
Nobutaka ITO, Nobutaka ONO, and Shigeki SAGAYAMA
Through the separation process according to the flowchart shown in
The processes of the thread control section 131, which is shown in
The thread computation section 132 is, after start-up, initialized in step S391. The start-up timing is a period of the initialization process in step S101 of the entire flow in
In the thread computation section 132, the learning thread is initialized in step S391 after the start-up. Then, the learning thread waits until an event occurs (blocks processing) (this “wait” is different from “waiting” which indicates one of the learning thread states). The event occurs when any of the following actions has been performed.
A state transition command has been issued.
Frame data has been transferred.
An end command has been issued.
The subsequent processing is branched in accordance with which event has occurred (step S392). That is, in accordance with the event input from the thread control section 131, the subsequent process is branched.
If it is determined in step S393 that a state transition command has been input, the corresponding command processing is executed in step S394.
If it is determined in step S393 that an input of a frame data transfer event has been received, in step S395, the thread 132 acquires frame data. Next, in step S396, the thread 132 accumulates the acquired frame data in the observed signal buffer 161 (refer to
The observed signal buffer 161 (refer to
If it is determined in step S393 that an end command has been input, in step S397, the thread 132 executes, for example, appropriate pre-termination processing such as freeing of the memory, and the process is ended.
Through such processing, processing is executed in each thread on the basis of control by the thread control section 131.
Next, referring to the flowchart in
In step S401, the thread 132 branches the subsequent processing in accordance with the supplied state transition command. In the following description, a command to the effect that “transition to the OO state” will be expressed as “state transition command “OO””.
If, in step S401, the supplied state transition command is a “state transition command “waiting”” that instructs transition to the “waiting” state, in step S402, the thread 132 stores information representing that the current state is “waiting” into the state storage portion 165 (refer to
If, in step S401, the supplied state transition command is a “state transition command “accumulating”” that instructs transition to the “accumulating” state, in step S403, the thread 132 stores information representing that the current state is “accumulating” into the state storage portion 165, that is, transitions into the state “accumulating”, and then ends the command processing.
If, in step S401, the supplied state transition command is a “state transition command “learning”” that instructs transition to the “learning” state, in step S404, the thread 132 stores information representing that the current state is “learning” into the state storage portion 165, that is, transitions into the state “learning”.
Further, in step S405, the thread 132 executes a separating-matrix learning process. Details of this process will be given later.
In step S406, to notify the thread control section 131 of the end of learning, the thread 132 sets the learning end flag 1680N and ends the process. By setting the flag, the thread 132 notifies the thread control section 131 to the effect that learning has just ended.
Through such processing, the state of each thread is made to transition on the basis of a state transition command supplied from the thread control section 131.
Next, referring to the flowchart in
In step S411, as necessary, the learning computation portion 163 (refer to
Specifically, the learning computation portion 163 performs such processing as normalization or decorrelation (or pre-whitening) on observed signals accumulated in the observed signal buffer 161 before the learning loop is started. For example, when performing normalization, the learning computation portion 163 finds a standard deviation of observed signals from frames within a block, and, with the diagonal matrix formed by the inverse of the standard deviation represented by S, calculates X′=SX by Expression [9.1] below. Here, X is a matrix obtained from the observed signals of all frames within the block, and a segment expressed by the learning data block 81 of
Meanwhile, decorrelation is a transformation that transforms a covariance matrix into a unit matrix. While there are several methods of decorrelation, description will be given herein of a method using eigenvectors and eigenvalues of the covariance matrices.
From the accumulated observed signal (for example, the learning data block 81 in
That is, when X′(ω,t) is represented as a term of multiplying P(ω) by the observed signal X(ω,t) (Expression [9.10]), the covariance matrices of X′(ω,t) satisfy the relationship of Expression [9.11].
By performing the decorrelation as preprocessing, it is possible to reduce the number of loops until convergence thereof in the learning. Further, in the embodiment of the invention, it is possible to generate the all-null spatial filter from the eigenvectors (details thereof will be described later).
The observed signal X that appears in the following expressions can also be expressed as the observed signal X′ on which the preprocessing has been performed.
In step S412, the learning computation portion 163 acquires, as the initial value of a separating matrix, a learning initial value W held in the learning-initial-value holding portion 152 of the thread control section 131, from the thread control section 131.
The processes from steps S413 to S419 represent a learning loop, and these processes are repeated until W converges or until the abort flag becomes ON. The abort flag is a flag that is set ON in step S236 in the flow of the learning-state process in
If it is determined in step S413 that the abort flag is OFF, the process advances to step S414. In step S414, the learning computation portion 163 determines whether or not the value of the separating matrix W has converged. Whether or not the value of the separating matrix W has converged is determined by using, for example, a matrix norm. ∥W∥ as the norm of the separating matrix W (the square sum of all the matrix elements), and ∥H∥ as the norm of ΔW are calculated, and W is determined to have converged when the ratio between the two norms, ∥ΔW∥/∥W∥, is smaller than a predetermined value (for example, 1/1000). Alternatively, the determination may be simply made on the basis of whether or not the loop has been run a predetermined number of times (for example, 50 times).
If it is determined in step S414 that the value of the separating matrix W has converged, the process advances to step S420 described later, where post-processing is executed, and the process is ended. That is, the learning process loop is executed until the separating matrix W converges.
If it is determined in step S414 that the value of the separating matrix W has not converged (or when the number of times the loop is executed has not reached a predetermined value), the processing proceeds into the learning loop in steps S415 to S419. Learning is performed as a process of iterating Expressions [3.1] to [3.3] described above for all frequency bins. That is, to find the separating matrix W, Expressions [3.1] to [3.3] are iterated until the separating matrix W converges (or a predetermined number of times). This iteration is referred to as “learning”. The separation results Y(t) are represented by Expression [3.4]
Step S416 corresponds to Expression [3.1].
Step S417 corresponds to Expression [3.2].
Step S418 corresponds to Expression [3.3].
Since Expressions [3.1] to [3.3] are to be computed for each frequency bin, by running a loop with respect to frequency bins in steps S415 and S419, ΔW is found for all frequency bins.
It should be noted that, as an algorithm of ICA, an expression other than Expression [3.2] can be applied. For example, when the decorrelation is performed as preprocessing, it may be preferable to use the following Expressions [3.13] to [3.15] in the gradient method based on the orthonormal constraint. Here, X′(ω,t) in Expression [3.13] represents the decorrelated observed signal.
Numerical Expression 9
Y(ω,t)=W(ω)X′(ω,t) [3.13]
D(ω)=<φω(Y(t))Y(ω,t)H>t [3.14]
ΔW(ω)={D(ω)−D(ω)H}W(ω) [3.15]
After the above loop process ends, the process returns to step S413 to perform the determination with regard to the abort flag, and the determination of the convergence of the separating matrix in step S414. The process is ended when the abort flag is ON. If convergence of the separating matrix is confirmed in step S414 (or a specified number of loops has been reached), the process advances to step S420.
Details of the post-processing in step S420 will be described with reference to the flowchart shown in
In step S420, the following processes are executed as post-processing.
(1) Making the separating matrix correspond to the observed signals prior to normalization.
(2) Adjusting the balance between frequency bins (the rescaling).
First, a description will be given of the process of (1) making the separating matrix correspond to the observed signals prior to normalization.
In a case where normalization has been performed as preprocessing, the separating matrix W found by the above-described processes (steps S415 to S419 in
Specifically, assuming that the matrix applied at the time of normalization is S(ω), in order to associate W(ω) with the observed signals prior to normalization, a correction may be performed such that
W(ω)←W(ω)S(ω) (Expression [9.1]).
Likewise, when the decorrelation is performed as preprocessing, a correction is performed such that
W(ω)←W(ω)P(ω)(P(ω) is the decorrelating matrix).
Next, a description will be given of the process of (2) adjusting the balance between frequency bins (the rescaling).
Depending on the ICA algorithm, the balance (scale) between frequency bins of the separation results Y may differ from the balance of the original source signals in some cases (for example, Japanese Unexamined Patent Application Publication No. 2006-238409 “Audio Signal Separating Apparatus/Noise Removal Apparatus and Method”). In such cases, it is necessary to correct the scale of frequency bins in post-processing. For the correction of the scale, a correcting matrix is calculated from Expressions [9.5] and [9.6]. Here, “1” (a lower-case letter of L) in Expression [9.5] is the index of the microphone as a projection target. When the correcting matrix is obtained, the separating matrix W(ω) is corrected on the basis of Expression [9.3].
In addition, by collecting the following:
(1) Making the separating matrix correspond to the observed signals prior to normalization; and
(2) Adjusting the balance between frequency bins (the rescaling),
it may be allowed to perform the correction at once by applying Expression [9.4] thereto. The separating matrix, which is rescaled in such a manner, is stored in the separating matrix holding portion 133 shown in
Next, the process advances to processing of generating the all-null spatial filter in step S453. In the method of generating the all-null spatial filter, there are the following two possible methods of:
(1) Generation from the separating matrix; and
(2) Generation from the eigenvector of the covariance matrices of the observed signals.
First, description will be given of “(1) the method of generating the all-null spatial filter from the separating matrix”.
Letting the separating matrix, which is rescaled in step S452, be W(ω) and the low vectors be W1(ω) to Wn(ω), the all-null spatial filter B(ω) is calculated by Expression [5.1] described above. However, “1” (a lower case letter of L) represents an index of the microphone as a projection target. The “e1” represents an n-dimensional row vector, and is a matrix in which only the 1-th element is 1 and the others are 0.
When the all-null spatial filter B(ω) obtained by Expression [5.1] is multiplied by the observed signals X(ω), the results Z(ω,t) are obtained as the all-null spatial filtering results (Expression [5.4]).
Expression [5.3] shows the reason why the all-null spatial filter B(ω) calculated in such a manner functions as the all-null spatial filter.
In Expression [5.3],
Wk(ω)X(ω,t)
is the k-th channel of the separating-matrix application results.
The separating matrix is rescaled in the rescaling process of the separating matrix in step S452 of the separation process flow described above with reference to
Accordingly, it can be expected that the left side of Expression [5.3] is close to 0. Further, the left side of Expression [5.3] can be changed as the right side of Expression [5.4] through the all-null spatial filter B(ω) of Expression [5.1]. Specifically, B(ω) can be regarded as a filter of generating signals close to 0 from the observed signals X(ω,t), that is, the all-null spatial filter.
When the convergence of the separating matrix is not sufficient, the all-null spatial filter, which is generated from the separating matrix, has a characteristic that passes even the sound sources included in the segment of the learning data to some extent. For example, first in the related art described with reference to
Next, description will be given of “(2) the method of generating the all-null spatial filter from the eigenvectors of the covariance matrices of the observed signals”.
When the decorrelation is used as the “preprocessing” in step S411 in the learning process of the separating matrix described with reference to
Here, all the eigenvalues are 0 or more, and arranged in descending order. That is, the following condition is satisfied.
λ1≧λ2≧ . . . ≧λn≧0
In this case, the eigenvector pn corresponding to the minimum eigenvalue λn has a characteristic of the all-null spatial filter. Accordingly, when the all-null spatial filter B(ω) is set as in Expression [6.2], then it is possible to use the all-null spatial filter B(ω) as in “(1) generation from the separating matrix”.
This method is able to reduce the above-mentioned “residual sound” by combining with a way of separating the sound sources by multiplying the observed signals in the time frequency domain by a vector or a matrix even other than ICA.
The all-null spatial filter, which is generated in such a manner, is stored in the all-null spatial filter holding portion 134 shown in
The description so far given of the process of generating the all-null spatial filter in step S453 is ended.
Next, a process of “calculating a power ratio” in step S454 will be described. For example, the power ratio is referenced in the “frequency filtering” process in step S308 in the separation process described above with reference to
Before the calculation of the power ratio, first by using Expression [8.8] or [8.9] described above, the power (the square sum of elements in the segment) is calculated for each channel. However, the separating matrix Wk(ω) is the separating matrix rescaled in step S452, the uniform operation <•>t is performed in the segment (for example, the learning data block 81 shown in
The power ratio calculation is performed by applying any of the above-mentioned Expressions [8.6], [8.7], and [8.11]. The power (the variance) of the channel k is represented by Vk, and a power ratio rk is calculated by applying any of the above-mentioned Expressions [8.6], [8.7], and [8.11] thereto. The three expressions are different in denominators thereof. The denominator of Expression [8.6] is the maximum when the powers among the channels are compared in the same segment. The denominator of Expression [8.7] is a power, which is obtained when a very large sound is input, calculated as a Vmax in advance. The denominator of Expression [8.11] is a mean of the power Vk among the channels. Determination as to which one to use differs depending on usage environments. For example, if the usage environment is relatively silent, it is preferable to use Expression [8.7], and if background noise is relatively large in the usage environment, it is preferable to use Expression [8.6]. In contrast, when rmin and rmax may be set to satisfy rmin≦1≦rmax by using Expression [8.11], the operation is relatively stable in a wide range of environments. The reason is that, since there are at least one channel to which the frequency filtering is not applied and at least one channel to which the frequency filtering is applied, there is no case where the sudden sound is removed or retained on all channels when it should not be.
The power ratio rk corresponding to the channel calculated in such a manner is stored in the power ratio holding portion 135 shown in
The description so far given of the process of calculating the power ratio in step S454 is ended.
Next, modified examples different from the above-mentioned examples will be described.
5-1. Modified Example 1
The above-mentioned example describes a method using the function (Expression [8.10] and
As a different possible method, there is also a method of “applying the frequency filtering to the channels other than the channel, of which the power is minimal, by comparing the powers of the separating-matrix application results among the channels”. That is, the minimum power channel is secured for the output of the sudden sound all the time. Since there is a high possibility that the minimum power channel does not correspond to any sound source, the channel is available even in such a simple method.
However, in order to prevent the channel, on which the sudden sound is output, from being frequently changed (for example, being changed while the sudden sound is being played), contrivance is necessary. Here, as such, the following two points are described:
(1) Smoothing in calculation of the power ratio; and
(2) Reflecting the all-null spatial filter in the initial learning value.
(1) Smoothing in calculation of the power ratio
First, the smoothing in calculation of the power ratio will be described.
The power for each channel is calculated on the basis of Expression [10.1] represented as follows.
When the power for each channel is calculated on the basis of Expression [10.1], a plurality of the output channels, of which the powers are substantially the same, may exist. In this case, the minimum power channel tends to be frequently changed. For example, when the observed signals are substantially silent, all the output channels are substantially silent. That is, all the output powers become substantially the same, and the minimum power channel is determined depending on a small difference therebetween. Thus, the phenomenon, in which the minimum power channel is frequently changed, may occur.
In order to prevent the phenomenon, the amount of subtraction (or the over-subtraction factor) αk is calculated by Expression [10.3] instead of Expression [8.5] described above. However, αmin is 0 or is a positive value close to 0, and α is the maximum value of αk as in Expression [8.5]. That is, the frequency filtering is scarcely applied to the minimum power channel, and the frequency filtering is applied, as it is, to the other channels. It should be noted that by setting αmin to a positive value close to 0, even on the channel which is secured for the sudden sound, it is possible to reduce the “residual sound” (refer to “Problems of Related Art”) to a certain extent.
(2) Reflecting all-null spatial filter to initial learning value
Next, description will be given of the method of reflecting the all-null spatial filter to the initial learning value. By not applying the frequency filtering to only the minimum power channel (or by scarcely applying the frequency filtering thereto), the sudden sound is output on only that channel. On the other hand, when the sudden sound is continuously played, then the situation is reflected in the separating matrix, and the sudden sound is output on only one channel even if there is no operation of the frequency filtering. For example,
In order to continuously output the sudden sound even thereafter on the channel to which the frequency filtering is not applied (in order to prevent the channel change), it is preferable that the information as to “which channel the frequency filtering is applied to (or not applied to)” should be reflected in the initial value of the next learning. The method will be described below.
In the above-mentioned example, the setting of the initial learning value is performed in step S253 (that is, immediately after the end of the learning) of the “separating matrix update process” described with reference to
For the calculation of the initial value of the separating matrix W in step S412 of the “separating matrix learning process” described with reference to
When the setting is made so that α′=1 and α′min=0 (or a positive value close to 0), the separating matrix W(ω) calculated by Expression [10.4] has a characteristic that the minimum power channel outputs the sudden sound and the other channels suppress the sudden sound. Accordingly, by setting such a value to the initial learning value, the sudden sound is highly likely to be continuously output on the same channel even after the learning.
As necessary, instead of Expression [10.4], an operation in Expression [10.6] may be performed. In this expression, the “normalize ( )” represents an operation that normalizes the norm of each row vector by 1 in the matrix in the bracket.
Further, when there is a probability that the learning times between the learning threads are overlapped (for example, the learning time 57 and the learning time 58 are temporally overlapped in
Comparing with Expressions [8.1] to [8.10] representing the determination method based on the modified example in advance, trouble arises only in the case where the sudden sound is newly played in a state where exactly n sound sources (n is the same as the number of microphones) are continuously played. That is, although the sudden sound is removed through the frequency filtering on the n−1 output channels, the frequency filtering is not applied to the channel of which the power is smallest, and thus the sudden sound is superimposed and is output (even in this case, n−1 channels have merit as compared with the related art).
On the other hand, when the number of sound sources before the play of the sudden sound is smaller than n, it can be expected in advance from which channel the sudden sound will be output. Hence, in the application such that mainly the sudden sound is used as a target sound (for example, sometimes a command is input through a voice in an environment where music is being played), there is an advantage that it is easy to specify which one of the plurality of output channels of ICA is the target sound.
5-2. Modified Example 2
Combination with Linear Filtering other than ICA
In the above-mentioned example, the all-null spatial filter and the frequency filtering (the subtraction) are combined with the real-time ICA, but can be also combined with the linear filtering process other than ICA. In such a manner, it is possible to reduce the “residual sound”. Here, description will be given of a configuration example of the case of combination with the linear filtering, and then description will be given of processing in a case where a minimal variance beamformer (MVBF) is used as a specific example of the linear filtering.
By providing a system that generates and applies a certain linear filter (the Fourier transform section 303-4 the linear filter generation & application section 305) and a system that generates and applies the all-null spatial filter (the Fourier transform section 303-4 the all-null spatial filter generation & application section 304), the frequency filtering (the subtraction) is performed on each application result. The dashed line from the linear filter generation & application section 305 to the all-null spatial filter generation & application section 304 indicates that the rescaling (adjusting the scale of the all-null spatial filtering result to the scale of the linear filtering result) is performed on the application result of the all-null spatial filter as necessary.
The linear filtering described herein means a process of separating, extracting, and removing signals by providing the separating matrix W(ω) as a matrix or a vector and multiplying the observed signal vector X(ω,t) by W(ω) (that is, in terms of the separation result: Y(ω,t)=W(ω) X(ω,t)).
Hereinafter, description will be given of the case where the minimal variance beamformer is used as the linear filtering. The minimal variance beamformer is one of techniques of extracting a target sound by using information on the direction of the target sound in the environment where the target sound and the interference sound are mixed, and is a kind of a technique called an adaptive beamformer (ABF).
For details thereof, for example, refer to the following document.
“Measurement of Sound Field and Directivity Control” Nobutaka ONO, Shigeru ANDO
22-th Sensing Forum Document, pp. 305-310, September, 2005. http://hil.t.u-tokyo.ac.jp/publications/download.php?bib=Ono2005SensingForum09.pdf
Hereinafter, referring to
H1(ω) to Hn(ω), which are functions (the impulse responses) of transfer from the sound sources to the microphones, are given, and a vector formed of those as elements is represented by H(ω). The vector H(ω) is defined by the following Expression [11.1].
The vector H(ω) is called a steering vector. In the minimal variance beamformer (MVBF) which is a specific example of the linear filtering, even when proper transfer functions are not used, if a ratio of H1(ω) to Hn(ω) is correct, it is possible to extract the target sound. Hence, the steering vector can be calculated from the sound source direction or position of the target sound, and can be also estimated from the observed signals in the segment (where the interference sound is entirely stopped) where only the target sound is being played.
As shown in
D(ω) which is a filter of the minimal variance beamformer (MVBF) is found by Expression [11.5]. In this expression, ΣXX(ω) is defined as the covariance matrices of the observed signals, and can be obtained from the operation in Expression [4.4] as in ICA. It should be noted that, under constraint (corresponding to Expression [11.4]) such that “the sound derived from the target sound 354 is made to remain as it is”, Expression [11.5] is derived by solving the problem for finding the MVBF filter D(ω) which minimizes the variance <|Y(ω,t)|2> of Y(ω,t). The MVBF filter D(ω) calculated by Expression [11.5] keeps the gain in the target sound direction at 1, and form null beams in each interference sound direction.
However, in the extraction of the sound sources using MVBF, there is the problem of the “residual sound” in ICA. That is, when the number of sound sources of the interference sounds is equal to or more than the number of microphones, or when the interference sound is not directional (that is, when the interference sound does not originate from a point sound source), it is difficult to eliminate the interference sound through null, and thus the extraction ability deteriorates. Further, due to the arrangement of the microphones, the accuracy of extraction in a certain frequency band is likely to be deteriorated.
Further, due to the restriction of the computational cost, the update of the filter may not be performed for each frame but may be performed only at a frequency of one time per plural frames. In this case, the phenomenon of the “tracking lag” also occurs. For example, when the update of the filter is performed at a frequency of one time per 10 frames, in the interval of maximum 9 frames subsequent to the play of the sudden sound, the sound is output without being removed.
On the other hand, by combining the all-null spatial filter and the frequency filtering with the MVBF according to the embodiment of the invention, it is possible to cope with the “residual sound” and the “tracking lag”. At this time, by performing the eigendecomposition on the covariance matrices, it is possible to calculate the all-null spatial filter without increasing the computational cost. Hereinafter, the method will be described.
The covariance matrices of the observed signals are calculated for each frame by Expression [4.4] described above. Then, the eigendecomposition is performed on the covariance matrices in accordance with the frequency of the update of the MVBF filter (Expression [6.1] described above). Similarly to the case of the combination with ICA, the all-null spatial filter is a transposition of the eigenvector corresponding to the minimum eigenvalue (Expression [6.2]).
When using the eigendecomposition result, it is possible to calculate the MVBF filter from the simple expression which does not include an inverse matrix. The reason is that, when the decorrelating matrix P(ω) which is calculated from Expression [9.9] described above is used, the covariance matrices of the observed signals can be written as Expression [11.7], and thereby the MVBF filter can be written as Expression [11.8]. In other words, when the eigendecomposition is used as a way of finding the covariance matrices of the observed signals in Expression [11.5], the all-null spatial filter is obtained at the same time.
The all-null spatial filter B(ω) calculated in such a manner is subjected to the rescaling (the processing of adjusting the scale of the all-null spatial filtering result to the scale of the MVBF filtering result). The rescaling is performed by multiplying the all-null spatial filter B(ω) by the factor Q(ω) which is calculated by Expression [11.9] (Expression [11.11]). The application result Z′(ω,t) of the rescaled all-null spatial filter is performed on the basis of Expression [11.12]. Since the MVBF-side output is 1 channel, Z′(ω,t) is also 1 channel (that is, Z′(ω,t) is scalar).
The frequency filtering (the subtraction in a wide range of meaning) is performed between the all-null spatial filtering result (Expression [11.12]) and the MVBF result (Expression [11.3]) generated in such a manner. In accordance therewith, the “residual sound” is removed from the MVBF result. Further, since the MVBF filter is updated for each group of the plural frames, even when the “tracking lag” occurs, it is possible to remove the sudden sound.
Hereinafter, the advantages based on the configurations of the signal processing apparatus according to the embodiments of the invention will be summarized and described. The advantages based on the configurations of the signal processing apparatus according to the embodiments of the invention are as follows.
(1) In the real-time sound source separation system using the independent component analysis, not only the separating-matrix application result but also the all-null spatial filtering result are generated, the frequency filtering or the subtraction is performed between both results, and thereby it is possible to remove the sudden sound.
(2) By changing the force (or the subtraction amount), which applies the frequency filtering, depending on whether the signal corresponding to the sound source is output before the generation of the sudden sound,
a) it is possible to remove the sudden sound from the channels on which the signals corresponding to the sound sources are being output, and
b) it is possible to output the sudden sound from the channel on which the signals corresponding to the sound sources are not being output.
(3) By performing the rescaling on the separating matrix for each shortest one frame, it is possible to reduce distortion caused when the sudden sound is output.
The present invention has been described above in detail with reference to specific examples. However, it is obvious that a person skilled in the art can make various modifications to and substitutions for the embodiments without departing from the scope of the invention. That is, the invention has been disclosed by way of examples, and should not be construed restrictively. The scope of the invention should be determined with reference to the appended claims.
The series of processes described in this specification can be executed by hardware, software, or a combined configuration of both. When the processes are executed by software, the processes can be executed by installing a program recording the process sequence into a memory within a computer embedded in dedicated hardware, or by installing the program into a general purpose computer capable of executing various processes. For example, the program can be pre-recorded on a recording medium. Other than being installed into a computer from a recording medium, the program can be received via a network such as the LAN (Local Area Network) or the Internet, and installed into a built-in recording medium such as a hard disk.
The various processes described in this specification may be executed not only time sequentially in the order as they appear in the description, but may be executed in parallel or independently depending on the throughput of the device executing the processes or as necessary. In addition, the term system as used in this specification refers to a logical assembly of a plurality of devices, and is not limited to one in which the constituent devices are located within the same casing.
The present application contains subject matter related to that disclosed in Japanese Priority Patent Application JP 2009-265075 filed in the Japan Patent Office on Nov. 20, 2009, the entire contents of which are hereby incorporated by reference.
It should be understood by those skilled in the art that various modifications, combinations, sub-combinations and alterations may occur depending on design requirements and other factors insofar as they are within the scope of the appended claims or the equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
P2009-265075 | Nov 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
7039546 | Sawada et al. | May 2006 | B2 |
7428490 | Xu et al. | Sep 2008 | B2 |
20070053455 | Sugiyama | Mar 2007 | A1 |
20080228470 | Hiroe | Sep 2008 | A1 |
Number | Date | Country |
---|---|---|
2006-238409 | Sep 2006 | JP |
2008-147920 | Jun 2008 | JP |
4172530 | Oct 2008 | JP |
4671303 | Apr 2011 | JP |
WO 2007026827 | Mar 2007 | WO |
Entry |
---|
Ono, N. et al., “Measurement of Sound Field and Directivity Control,” the 22th Sending Forum Document, pp. 305-310, Sep. 2005 (6 pages). |
Ito, N. et al., “Diffuse noise suppression by crystal-array-based post-filter design,” The Institute of Electronics, Information and Communication Engineers, Technical Report of IEICE, (4 pages). |
Okamoto, R. et al., “MMSE STSA with Noise Estimation Based on Independent Component Analysis,” Collecction of Lecture Notes, Acoustical Society of Japan, 2-9-6, Mar. 2009 pp. 663-666. |
Hyvarinen et al., Introduction, “Independent Component Analysis,” 2001 John Wiley & Sons, (12 pages). |
Number | Date | Country | |
---|---|---|---|
20110123046 A1 | May 2011 | US |