1. Field of the Invention
The present invention relates to a sound processing device, a sound processing method, and a sound processing program.
1. Description of Related Art
A mechanical apparatus having a power source such as a motor, for example, a robot, generates sound due to a motion. A microphone built in or disposed proximal to the mechanical apparatus receives the sound of the mechanical apparatus along with a target sound such as speech uttered by a person. Such sound is referred to as ego-noise. In order to utilize the target sound received through the use of the microphone, it is necessary to reduce or remove the ego-noise of the mechanical apparatus. For example, when performing speech recognition on a target sound, it is not possible to guarantee a given recognition rate without reducing the ego-noise. Therefore, techniques of reducing ego-noise have been proposed in the past.
For example, in a sound data processing device described in JP-A-2010-271712, an operating state of a mechanical apparatus is acquired, sound data corresponding to the acquired operating state is acquired, sound data of a template of the operating state closest to the acquired operating state is searched for from a database which stores various operating states of the mechanical apparatus and corresponding sound data in a unit time, and the sound data of the template of the operating state closest to the acquired operating state is subtracted from the acquired sound data to calculate an output from which noise generated by the mechanical apparatus is reduced.
However, in the sound data processing device described in JP-A-2010-271712, templates prepared in advance are used. In order to guarantee noise-removing performance under various circumstances which vary frequently such as ambient noise, a lot of templates are necessary. On the other hand, it is not realistic to prepare enough templates to cope with all circumstances. As the number of templates increases, the processing time also increases. Accordingly, there is a problem in that it is not possible to secure noise-suppressing performance by only using a limited number of templates.
The invention is made in consideration of the above-mentioned problem and an object thereof is to provide a sound processing device, a sound processing method, and a sound processing program, which can improve noise-suppressing performance.
(1) The invention is made to solve the above-mentioned problem, and an aspect of the invention is a sound processing device including: a storage unit configured to store first operation data corresponding to a motion of a mechanical apparatus and a first sound feature value corresponding to the motion in correlation with each other; a noise estimating unit configured to estimate a third sound feature value corresponding to a noise component based on a second sound feature value corresponding to an acquired sound signal; a sound feature value processing unit configured to calculate a target sound feature value from which the noise component is removed based on the second sound feature value and the third sound feature value; and an updating unit configured to update the first sound feature value stored in the storage unit based on detected second operation data and the third sound feature value estimated by the noise estimating unit.
(2) In the sound processing device, the updating unit may be configured to select the first sound feature value stored in the storage unit based on the second operation data and may update the first sound feature value to a value obtained by multiplying the first sound feature value and the third sound feature value by corresponding weighting coefficients and adding the multiplied values.
(3) In the sound processing device, the updating unit may be configured to store the second operation data and the third sound feature value estimated by the noise estimating unit in the storage unit in correlation with each other when the degree of similarity between the second operation data and the first operation data stored in the storage unit is lower than a predetermined degree of similarity.
(4) The sound processing device may further include a speech determining unit configured to determine whether the sound signal is a speech signal or a non-speech signal, the noise estimating unit may include a stationary noise estimating unit configured to estimate a sound feature value of a stationary noise component based on the sound signal when the speech determining unit determines that the sound signal is a non-speech signal, and the updating unit may be configured to update the first sound feature value based on a non-stationary component from which the sound feature value of the stationary noise component estimated by the stationary noise estimating unit based on the second sound feature value as the noise component is removed.
(5) The sound processing device may further include a motion detecting unit configured to determine whether or not an instruction data corresponds to a motion causing the mechanical apparatus to generate ego-noise when the instruction data related to the motion is input to the mechanical apparatus, the noise estimating unit may be configured to estimate the third sound feature value based on the second sound feature value when the motion detecting unit determines that the instruction data corresponds to the motion causing the mechanical apparatus to generate ego-noise, and the updating unit may be configured to update the first sound feature value based on a component obtained by subtracting the third sound feature value estimated by the noise estimating unit from the second sound feature value.
(6) Another aspect of the invention is a sound processing method in a sound processing device having a storage unit configured to store first operation data corresponding to a motion of a mechanical apparatus and a first sound feature value corresponding to the motion in correlation with each other, including the steps of: estimating a third sound feature value corresponding to a noise component based on a second sound feature value corresponding to an acquired sound signal; calculating a target sound feature value from which the noise component is removed based on the second sound feature value and the third sound feature value; and updating the first sound feature value stored in the storage unit based on detected second operation data and the third sound feature value.
(7) Another aspect of the invention is a sound processing program causing a computer of a sound processing device, which has a storage unit configured to store first operation data corresponding to a motion of a mechanical apparatus and a first sound feature value corresponding to the motion in correlation with each other, to perform the steps of: estimating a third sound feature value corresponding to a noise component based on a sound feature value of an acquired sound signal; calculating a target sound feature value from which the noise component is removed based on a second sound feature value corresponding to the sound signal and the third sound feature value; and updating the first sound feature value stored in the storage unit based on detected second operation data and the third sound feature value.
According to the above-mentioned aspects of (1), (6), and (7), since the updated sound feature value of a noise component is used to remove noise, it is possible to improve noise-removing performance.
According to the configuration of (2), it is possible to make both adaptability to a variation in noise characteristics and stability of a motion compatible with each other.
According to the configuration of (3), it is possible to improve adaptability to a sudden variation in noise characteristics.
According to the configuration of (4), it is possible to improve adaptability to a variation in non-stationary noise characteristics.
According to the configuration of (5), it is possible to improve adaptability to ego-noise generated by a motion of the mechanical apparatus based on an instruction to the mechanical apparatus to be controlled
Hereinafter, a first embodiment of the invention will be described in detail with reference to the accompanying drawings.
The sound processing device 1 includes a sound pickup unit 11, a motion detecting unit 12, a frequency domain conversion unit 131, a power calculating unit 132, a noise estimating unit 133, a template storage unit 134, a subtraction unit 135, a time domain conversion unit 136, a template creating unit 138, a template reconstructing unit 139, and an output unit 14.
In the sound processing device 1, the template storage unit 134 stores operation data indicating a motion of a mechanical apparatus and a spectrum of the motion in correlation with each other and the noise estimating unit 133 estimates a spectrum of a noise based on an input (acquired) sound signal and input (detected) operation data. In the sound processing device 1, the subtraction unit 135 subtracts the estimated spectrum of noise from the spectrum of the input sound signal and calculates an estimated target spectrum and creates a target sound signal in the time domain based on the calculated estimated target spectrum. On the other hand, the sound processing device 1 determines whether the input sound signal is a speech signal or a non-speech signal other than the speech signal, and calculates a spectrum of a non-stationary noise component based on the spectrum of the input sound signal when it is determined that the input sound signal is a non-speech signal. The sound processing device 1 updates a sound feature value stored in the template storage unit 134 based on the input operation data and a sound feature value of the non-stationary noise component.
The sound pickup unit 11 creates a sound signal y(t) as an electrical signal based on received sound waves and outputs the created sound signal y(t) to the frequency domain conversion unit 131 and the template creating unit 138. Here, t represents the time. The sound pickup unit 11 is, for example, a microphone recording a sound signal of an audible frequency band (20 Hz to 20 kHz).
The motion detecting unit 12 creates a motion signal (operation data) indicating a motion of the mechanical apparatus and outputs the created motion signal to the noise estimating unit 133 and the template creating unit 138. The motion detecting unit 12 creates a motion signal of the mechanical apparatus such as a robot equipped with the sound processing device 1. Here, the motion detecting unit 12 includes, for example, J encoders (position sensors) (where J is an integer greater than 0, for example, 30) and the encoders are mounted on motors (drivers) of the mechanical apparatus and measure angular positions θj(l) of corresponding joints. Here, j is an index of an encoder and is an integer greater than 0 and less than or equal to J, and 1 is an index representing the frame time. The motion detecting unit 12 calculates an angular velocity θ′j(l) which is a time derivative and an angular acceleration θ″j(l) which is a time derivative of the angular velocity for a measured angular position θj(l). The motion detecting unit 12 integrates the angular position θj(l), the angular velocity θ′j(l), and the angular acceleration θ″j(l) of each encoder over all the encoders to construct a feature vector F(l). The feature vector F(l) is a 3J-dimension vector [θ1(l), θ′1(l), θ″1(l), θ2(l), θ′2(l), θ″2(l), . . . , θJ(l), θ′J(l), θ″J(l))] indicating an operating state. The motion detecting unit 12 creates a motion signal indicating the constructed feature vector F(l).
The frequency domain conversion unit 131 converts the sound signal y(t) input from the sound pickup unit 11 and expressed in the time domain into a complex input spectrum Y(k, l) expressed in the frequency domain. Here, k represents an index (frequency bin) indicating a frequency. The frequency domain conversion unit 131 performs a discrete Fourier transform (DFT) on the sound signal, for example, using Equation 1 for each frame 1.
Here, w(t) is a window function, for example, a Hamming window. W is an integer indicating a window length. M represents a shift length, that is, the number of samples by which a frame to be processed is shifted at a time.
The frequency domain conversion unit 131 outputs the converted complex input spectrum Y(k, l) to the power calculating unit 132 and the subtraction unit 135.
The power calculating unit 132 calculates the power spectrum |Y(k, l)|2 of the complex input spectrum Y(k, l) input from the frequency domain conversion unit 131. Here, |AA| represents the absolute value of a complex number AA. The power calculating unit 132 outputs the calculated power spectrum |Y(k, l)|2 to the subtraction unit 135 and the noise estimating unit 133.
The noise estimating unit 133 includes a stationary noise estimating unit 1331, a template estimating unit 1332, and an addition unit 1333.
The stationary noise estimating unit 133,1 recursively averages the power spectrum |Y(k, l)|2 input from the power calculating unit 132. Accordingly, the stationary noise estimating unit 1331 calculates a power spectrum λSNE(k, l) of a stationary portion of noise.
In the following description, the power spectrum λSNE(k, l) may be referred to as a power spectrum λSNE(k, l) of a stationary portion or a stationary noise level. Here, the stationary noise estimating unit 1331 calculates a stationary noise level λSNE(k, l), for example, using an HRLE (Histogram-based Recursive Level Estimation) method. Through the use of the HRLE method, a histogram (frequency distribution) of the power spectrum |Y(k, l)|2 in a logarithmic domain is calculated and the stationary noise level λSNE(k, l) is calculated based on the calculated cumulative distribution and a predetermined cumulative frequency (percentile)×(for example, 50%). The process of calculating the stationary noise level λSNE(k, l) using the HRLE method will be described later.
The stationary noise estimating unit 1331 is not limited to the HRLE method, but may calculate the stationary noise level λSNE(k, l) using another method such as an MCRA (Minima-Controlled Recursive Average) method. The stationary noise estimating unit 1331 outputs the calculated stationary noise level λSNE(k, l) to the addition unit 1333.
The template estimating unit 1332 estimates a power spectrum λTE(k, l) of a non-stationary portion (non-stationary component) based on the motion signal input from the motion detecting unit 12 and outputs the estimated power spectrum λTE(k, l) of the non-stationary component to the addition unit 1333.
In the following description, the power spectrum λTE(k, l) of the non-stationary component may be referred to as anon-stationary noise level. Here, the template estimating unit 1332 selects a feature vector F′(l) stored in the template storage unit 134 based on the feature vector F(l) indicated by the input motion signal. The template storage unit 134 stores a feature vector F′(l) and a noise spectrum vector |N′n(k, l)|2 in correlation with each other as described later. In the following description, the set of the feature vector F′(l) and the noise spectrum vector |N′n(k,1)|2 corresponding thereto is referred to as a template. The process of selecting a feature vector F′(l) in the template estimating unit 1332 will be described later.
The template estimating unit 1332 may search for the feature vector F′(l) stored in the template storage unit 134 using an exhaustive key search method or a binary search method. When the binary search method is used, the feature vectors F′(l) construct a KD tree (K-Dimensional tree). The template estimating unit 1332 can reduce the amount of throughput more greatly using the binary search method than using the exhaustive key search method. The KD tree and the binary search method will be described later.
In order to select a feature vector F′(l) with the n-th smallest distance (where n is an integer greater than 1), the template estimating unit 1332 can perform the above-mentioned search with a feature vector F′(l) with the first to (n-1)-th smallest Euclidean distances excluded from the selection target.
A speech determination signal is input to the addition unit 1333 from the template creating unit 138. The speech determination signal is a signal indicating whether the input sound signal is a speech signal or a non-speech signal. When the sound determination signal indicates speech, the addition unit 1333 adds the stationary noise level λSNE(k, l) input from the stationary noise estimating unit 1331 and the non-stationary power spectrum λTE(k, l) input from the template estimating unit 1332. The addition unit 1333 outputs the noise power spectrum λtot(k, l), which is created by addition, to the subtraction unit 135.
When the sound determination signal indicates non-speech, the addition unit 1333 outputs the stationary noise level λSNE(k,1), which is input from the stationary noise estimating unit 1331, as the noise power spectrum λtot(k, l) to the subtraction unit 135.
The subtraction unit (sound feature value processing unit) 135 includes a gain calculating unit 1351 and a filter unit 1352. As described below, the subtraction unit 135 estimates a spectrum (estimated target spectrum) of a speech from which a noise component is removed by subtracting the noise power spectrum λtot(k, l) from the power spectrum |Y(k, l)|2.
The gain calculating unit 1351 calculates a gain GSS(k, l), for example, using Equation 2 based on the power spectrum |Y(k, l)|2 input from the power calculating unit 132 and the noise power spectrum λtot(k, l) input from the addition unit 1333.
In Equation 2, max(α, β) represents a function taking the larger of real numbers α and β. β is a flooring parameter indicating a predetermined minimum value. Here, the left side of the function max represents a square root of the ratio of a power spectrum from which noise is removed to a power spectrum from which noise is not removed, which is related to the frequency k in a frame 1. The gain calculating unit 1351 outputs the calculated gain GSS(k, l) to the filter unit 1352.
The filter unit 1352 multiplies the complex input spectrum Y(k, l) input from the frequency domain conversion unit 131 by the gain GSS(k, l) input from the gain calculating unit 1351 to calculate an estimated target spectrum X′(k, l). That is, the estimated target spectrum X′(k, l) represents a complex spectrum obtained by subtracting the noise spectrum from the input complex input spectrum Y(k, l). The filter unit 1352 outputs the calculated estimated target spectrum X′(k, l) to the time domain conversion unit 136 and the template creating unit 138.
The time domain conversion unit (speech calculating unit) 136 converts the estimated target spectrum X′(k, l) input from the filter unit 1352 into a target sound signal x′(t) in the time domain. Here, the time domain conversion unit 136 performs, for example, an inverse discrete Fourier transform (IDFT) on the estimated target spectrum X′(k, l) for each frame 1 to calculate a target sound signal x′(t). The time domain conversion unit 136 outputs the converted target sound signal x′(t) to the output unit 14. That is, the estimated target spectrum X′(k, l) is the spectrum of the target sound signal x′(t).
The output unit 14 outputs the target sound signal x′(t) input from the time domain conversion unit 135 to the outside of the sound processing device 1.
The template creating unit 138 includes a speech determining unit 1381, a power calculating unit 1382, and a template updating unit 1383.
The speech determining unit 1381 performs voice activity detection (VAD) on the sound signal y(t) input from the sound pickup unit 11. The speech determining unit 1381 performs the voice activity detection for each voice-active segment. The voice-active segment is an interval interposed between an onset and a decay of an amplitude of a sound signal. The onset is a portion in which the power of the sound signal becomes greater than a predetermined power after a silent segment. The decay is a portion in which the power of the sound signal becomes smaller than a predetermined power before a silent segment. The speech determining unit 1381 determines that it is an onset, for example, when a power value of a time interval (for example, 10 ms) is smaller than a predetermined power threshold immediately before and is greater than the power threshold at the present. On the contrary, the speech determining unit 1381 determines that it is a decay when the power value is greater than a predetermined threshold immediately before and smaller than the power threshold at the present.
The speech determining unit 1381 determines that it is a speech segment when the number of zero crossings per unit time (for example, 10 ms) is greater than a predetermined number. The number of zero crossings means the number of times in which the amplitude of a sound signal crosses zero, that is, in which the amplitude changes from a negative value to a positive value or changes from a positive value to a negative value. The speech determining unit 1381 determines that it is a non-speech segment when the number of zero crossings is less than a predetermined number. The speech determining unit 1381 creates a speech determination signal indicating a speech signal when determining that it is a speech segment. The speech determining unit 1381 creates a speech determination signal indicating a non-speech signal when it is determined that it is a non-speech segment. The speech determining unit 1381 outputs the created speech determination signal to the addition unit 1333 and the power calculating unit 1382. When it is determined that it is a non-speech segment, the sound signal picked up by the sound pickup unit 11 includes mainly an ego-noise component generated by the mechanical apparatus.
The speech determination signal from the speech determining unit 1381 and the estimated target spectrum X′(k, l) from the filter unit 1352 are input to the power calculating unit 1382. When the sound determination signal indicates a non-speech signal, the input estimated target spectrum X′(k, l) is a non-stationary component N′n(k, l) obtained by removing a stationary noise component from noise. In this case, the power calculating unit 1382 calculates the power spectrum |N′n(k, l)|2 of the non-stationary component N′n(k, l) and outputs the calculated power spectrum |N′n(k, l)|2 as the power spectrum λTE(k, l) of the non-stationary component to the template updating unit 1383.
The power calculating unit 1382 does not output the power spectrum |N′n(k, l)|2 when the sound determination signal input from the speech determining unit 1381 indicates speech.
The template updating unit 1383 updates the templates stored in the template storage unit 134 based on the motion signal input from the motion detecting unit 12 and the power spectrum λTE(k, l) of the non-stationary component input from the power calculating unit 1382. The process of updating the templates in the template updating unit 1383 will be described later.
The template reconstructing unit 139 reconstructs the KD tree every predetermined time interval τ for the feature vectors F′(l) for each template stored in the template storage unit 134. Through the use of this reconstruction, the recursive structure of the KD tree is restored, thereby preventing an increase in search time of the feature vectors F′(l). The reconstruction of the templates of the KD tree may be performed every frame 1, and τ may be a time interval, for example, 50 (ms) longer than the frame interval. Accordingly, it is possible to suppress an increase in processing load due to the updating of the templates. When the template estimating unit 1332 and the template updating unit 1383 search for the feature vectors F′(l), for example, in a round-robin manner without using the binary search method, the template reconstructing unit 139 may be skipped.
The process of calculating a stationary noise level λSNE(k, l) using the HRLE method in the stationary noise estimating unit 1331 will be described below.
(Step S101) The stationary noise estimating unit 1331 calculates a log spectrum YL(k, l) based on the power spectrum |Y(k, l)|2. Here, YL(k, l)=20 log10|Y(k, l)|. Thereafter, the flow of processes goes to step S102.
(Step S102) The stationary noise estimating unit 1331 determines a class (bin) Iy(k, l) to which the calculated log spectrum YL(k, l) belongs. Here, Iy(k, l)=floor(YL(k, 1)−Imin)/Lstep. The floor (BB) is a floor function taking the real number BB or the maximum integer less than the real number BB. Imin and Lstep represent a predetermined minimum level and the level width for each class. Thereafter, the flow of processes goes to step S103.
(Step S103) The stationary noise estimating unit 1331 accumulates the frequency N(k, l) of a class Iy(k, l) in the present frame 1. Here, N(k, l, i)=αN(k, l−1, i)+(1−α)δ(i−Iy(k, l)). α is a time decay parameter and satisfies α=1−1/(Tr·Fs). Tr is a predetermined time constant and Fs is a sampling frequency. δ( . . . ) is a Dirac's delta function. That is, the frequency N(k, l, i) is obtained adding 1−α to the value, which is obtained by multiplying the frequency N(k, l−1, i) of the class Iy(k, l) in the previous frame l−1 and decaying the resultant. Thereafter, the flow of processes goes to step S104.
(Step S104) The stationary noise estimating unit 1331 adds the frequencies N(k, l, i′) of the lowest class 0 to the class i to calculate the cumulative frequency S(k, l, i). Thereafter, the flow of processes goes to step S105.
(Step S105) The stationary noise estimating unit 1331 sets the parameter i providing the cumulative frequency S(k, l, i) closest to the cumulative frequency S(k, l, imax)·x/100 corresponding to the cumulative frequency x as an estimated parameter Ix(k, l). That is, the estimated parameter Ix(k, l) has the following relationship with the cumulative frequency S(k, l, i): Ix(k, l)=arg min1[S(k, l, Imax)·x/100−S(k, l, I)]. Thereafter, the flow of processes goes to step S106.
(Step S106) The stationary noise estimating unit 1331 converts the estimated parameter Ix(k, l) into a logarithmic level λHRLE(k, l). Here, λHRLE(k, l)=Lmin+Lstep·Ix(k, l) is satisfied. The logarithmic level λHRLE(k, l) is transformed to a linear domain to calculate the stationary noise level λSNE(k, l). That is, λSNE(k, l)=10(λSNE(k, l)/20) is satisfied. Thereafter, the flow of processes is ended.
The process of selecting a feature vector F′(l) in the template estimating unit 1332 will be described below.
The template estimating unit 1332 selects a feature vector F′(l), for example, using a nearest neighbor search algorithm. In the nearest neighbor search algorithm, an Euclidean distance d(F(l), F′(l)) is calculated as an index value indicating the degree of similarity between the input feature vector F(l) and the stored feature vector F′(l). The Euclidean distance d(F(l), F′(l)) is expressed by Equation 3.
In Equation 3, Fj(l) and F′j(l) represent the j-th element values of the feature vectors F(l) and F′(l). The template estimating unit 1332 selects the feature vector F′(l) with the minimum Euclidean distance d(F(l), F′(l)) and reads the noise spectrum vector |N′n(k, l)|2 corresponding to the selected feature vector F′(l) from the template storage unit 134. The template estimating unit 1332 outputs the read noise spectrum vector |N′n(k, l)|2 as the power spectrum λTE(k, l) of the non-stationary component to the addition unit 1333.
The template estimating unit 1332 may use, for example, a k-nearest neighbor algorithm (k-NN) to select the feature vector F′(l) stored in the template storage unit 134. Here, the template estimating unit 1332 calculates the Euclidean distance d(F(l), F′(l)) between the input feature vector F(l) and the stored feature vector F′(l). The template estimating unit 1332 selects the feature vector F′1(l) with the smallest Euclidean distance d(F(l), F′(l)) to the feature vector F′K(l) with the K-th smallest Euclidean distance d(F(l), F′(l)) (where K is an integer greater than 1). The template estimating unit 1332 calculates the power spectrums λ1TE to λKTE of the selected K feature vectors F′1(l) to F′K(l) as expressed by Equation 4 and calculates the weighted average value λ″TE(k, l) of the calculated power spectrums λ1TE to λKTE.
In Equation 4, wn is a weighting parameter of the n-th power spectrum λnTE. The weighting parameter wn is expressed by Equation 5.
That is, the weighting parameter wn is determined so that the total sum En=1Kwn of the reciprocals of the Euclidean distances d(F(l), F′(l)) related to the corresponding feature vectors F′n(l) is 1. The weighted average using the weighting parameter wn expressed by Equation 5 is referred to as an inverse distance weighted average (IDWA). Accordingly, a weighting parameter greater by the power spectrum λTE related to the feature vector F′(l) approximating to the input feature vector F(l) is given.
The template estimating unit 1332 outputs the calculated weighted average λ″TE(k, l) as the power spectrum λTE(k, l) of the non-stationary component to the addition unit 1333.
KD tree
The KD tree will be described below. The KD tree has a space-division data structure in which points (the feature vectors F′(l) in this example) in a multi-dimensional Euclidean space are classified. In the KD tree, for example, a median for each dimension of the feature vector F′(l) is selected and plane passing through the median and perpendicular to the coordinate axis of that dimension is defined as a divisional plane. That is, the KD tree has the following recursive structure.
(1) A feature vector F′(l) taking a median in a certain dimension n is defined as a root node (also referred to as a parent node). A feature vector F′(l) taking a value larger than the median in that dimension n and a feature vector F′(l) taking a value smaller than the median are classified as leaf nodes (also referred to as child nodes).
(2) A feature vector F′(l) taking a median in another dimension m′ (for example, a dimension m+1) is defined as a root node for candidates of the leaf node taking a value larger than the median and candidates of the leaf node taking a value smaller than the median. That is, the root node defined for the dimension m′ becomes a leaf node of the root node in the dimension n.
(3) Until the candidates of the leaf node do not remain, (1) and (2) are sequentially repeated while changing the dimension to be processed.
Therefore, the nodes from the root node (for example, a first dimension) as a start point to the leaf node of a terminal correspond to feature vectors F′(l), respectively. Any root node has two leaf nodes in principle. The leaf node of the terminal is a node not having a leaf node with respect to itself.
Structure information indicating indices indicating the feature vectors F′(l) corresponding to the root node as a start point and the root node and the leaf nodes of each dimension is stored as the information indicating the correspondence in the template storage unit 134.
The process of searching for a feature vector F′(l) using the binary search method in the template estimating unit 1332 will be described below.
(Step S201) The template estimating unit 1332 sets a root node as a predetermined start point. Thereafter, the flow of processes goes to step S202.
(Step S202) The template estimating unit 1332 calculates the Euclidean distance d(F(l), F′(l)) (hereinafter, simply referred to as a distance) related to the feature vector F′(l) of the root node. Thereafter, the flow of processes goes to step S203.
(Step S203) The template estimating unit 1332 calculates the distance of the leaf nodes from the root node. Thereafter, the flow of processes goes to step S204.
(Step S204) The template estimating unit 1332 selects a leaf node with a less distance and determines whether or not the selected leaf node is a leaf node of a terminal. When it is determined that the selected leaf node is the leaf node of a terminal (YES in step S204), the flow of processes goes to step S206. When it is determined that the selected leaf node is not the leaf node of a terminal (NO in step S204), the flow of processes goes to step S205.
(Step S205) The template estimating unit 1332 determines the selected leaf node as a root node. Thereafter, the flow of processes goes to step S202.
(Step S206) The template estimating unit 1332 determines whether or not the distance related to the root node is greater than the distance related to the leaf node. Accordingly, it is determined whether another leaf node should be excluded from search targets. When it is determined that the distance related to the leaf node is greater (YES in step S206), the template estimating unit 1332 determines that the root node as a leaf node and repeats the process of step S206. When it is determined that the distance related to the leaf node is less than or equal to the distance related to the root node (NO in step S206), the flow of processes goes to step S207.
(Step S207) The template estimating unit 1332 determines whether or not there is a non-processed leaf node as the other leaf node related to the root node. When it is determined that there is such a leaf node (YES in step S207), the flow of processes goes to step S208. When it is determined that there is not such a leaf node (NO in step S207), the flow of processes goes to step S209.
(Step S208) The template estimating unit 1332 determines the other leaf node as the root node which is a start point and the flow:of processes goes to step S202.
(Step S209) The template estimating unit 1332 selects the feature vector F′(l) having the calculated smallest distance. Thereafter, the flow of processes is ended.
The process of updating templates will be described below. The template updating unit 1383 selects a feature vector F′(l) stored in the template storage unit 134 based on the feature vector F(l) indicated by the input motion signal. Here, the template updating unit 1383 selects, for example, a feature vector F′(l) having the smallest Euclidean distance d(F(l), F′(l)) from the feature vector F(l) using the above-mentioned search method. Hereinafter, the Euclidean distance related to the selected feature vector F′(l) is referred to as the minimum distance dmin(F(l), F′(l)).
The template updating unit 1383 determines whether the minimum distance dmin(F(l), F′(l)) is greater than or equal to a predetermined threshold value T. When it is determined that the minimum distance dmin(F(l), F′(l)) is greater than or equal to the threshold value T, the template updating unit 1383 creates a new template to correspond to a set of the feature vector F(l) indicated by the input motion signal and the input power spectrum λTE(k, l). The template updating unit 1383 stores the created template in the template storage unit 134.
When it is determined that the minimum distance dmin(F(l), F′(l)) is smaller than the threshold value T, the template updating unit 1383 reads a power spectrum λ′TE(k, l−1) corresponding to the selected feature vector F′(l) from the template storage unit 134. Hereinafter, the read power spectrum λ′TE(k, l−1) may be referred to as a stored power spectrum λ′TE(k, l−1). The template updating unit 1383 weights the stored power spectrum λ′TE(k, l−1) and the input power spectrum λTE(k, l−1) with weighting parameters η and 1−η, respectively, and adds the resultants to calculate an updated power spectrum λTE(k, l). Accordingly, it is possible to balance adaptability such as learning quality and stability such as robustness against errors.
λTE(k, l)=η λ′TE(k, l−1)+(1−η)λTE(k, l) (6)
The parameter η is referred to as a forgetting parameter. The parameter η is a real number greater than 0 and less than 1, for example, 0.9. The template updating unit 1383 uses a smaller parameter η when the adaptability is preferred, and uses a larger parameter η when the stability is preferred. The template updating unit 1383 stores the calculated updated power spectrum λTE(k, l) in the template storage unit 134 in correlation with the feature vector F′(l) related to the read power spectrum λ′TE(k, l−1).
The template updating process according to this embodiment will be described below.
(Step S301) The frequency domain conversion unit 131 converts the sound signal y(t) input from the sound pickup unit 11 into a complex input spectrum Y(k, l) expressed in the frequency domain. The frequency domain conversion unit 131 outputs the converted complex input spectrum Y(k, l) to the power calculating unit 132 and the subtraction unit 135. Thereafter, the flow of processes goes to step S302.
(Step S302) The power calculating unit 132 calculates the power spectrum |Y(k, l)|2 of the complex input spectrum Y(k, l) input from the frequency domain conversion unit 131. The power calculating unit 132 outputs the calculated power spectrum |Y(k, l)|2 to the subtraction unit 135 and the stationary noise estimating unit 1331. Thereafter, the flow of processes goes to step S303.
(Step S303) The stationary noise estimating unit 1331 calculates the stationary noise level λSNE(k, l), for example, using the HRLE method based on the power spectrum |Y(k, l)|2 input from the power calculating unit 132. The stationary noise estimating unit 1331 outputs the calculated stationary noise level λSNE(k, l) to the addition unit 1333. Thereafter, the flow of processes goes to step S304.
(Step S304) The speech determining unit 1381 determines whether or not the sound signal y(t) input from the sound pickup unit 11 is in a speech segment. When it is determined that the sound signal is in the speech segment (YES in step S304), the speech determining unit 1381 creates a speech determination signal indicating speech and outputs the created speech determination signal to the addition unit 1333 and the power calculating unit 1382. Thereafter, the flow of processes goes to step S320. When it is determined that the sound signal is in a non-speech segment (NO in step S304), the speech determining unit 1381 creates a speech determination signal indicating the non-speech and outputs the created speech determining signal to the addition unit 1333 and the power calculating unit 1382. Thereafter, the flow of processes goes to step S305.
(Step S305) The gain calculating unit 1351 calculates a gain GSS(k, l), for example, using Equation 2 based on the power spectrum |Y(k, l)|2 input from the power calculating unit 132 and the noise power spectrum λtot(k, l) input from the addition unit 1333.
The gain calculating unit 1351 outputs the calculated gain GSS(k, l) to the filter unit 1352. Thereafter, the flow of processes goes to step S306.
(Step S306) The filter unit 1352 calculates an estimated target spectrum X′(k, l) by multiplying the complex input spectrum Y(k, l) input from the frequency domain conversion unit 131 by the gain GSS(k, l) input from the gain calculating unit 1351. The filter unit 1352 outputs the calculated estimated target spectrum X′(k, l) to the time domain conversion unit 136 and the power calculating unit 1382. Thereafter, the flow of processes goes to step S307.
(Step S307) The speech determination signal indicating a speech from the speech determining unit 1381 and the estimated target spectrum X′(k, l) from the filter unit 1352 are input to the power calculating unit 1382. The input estimated target spectrum X′(k, l) is a non-stationary component N′n(k,l) obtained by removing the stationary noise component from noise. The power calculating unit 1382 calculates the power spectrum |N′n(k, l)|2 of the non-stationary component N′n(k,l) and outputs the calculated power spectrum |N′n(k, l)|2 to the template updating unit 1383. Thereafter, the flow of processes goes to step S308.
(Step S308) The motion signal from the motion detecting unit 12 and the power spectrum |N′n(k, l)|2 as the power spectrum λTE(k,l) of the non-stationary component from the power calculating unit 1382 are input to the template updating unit 1383. The template updating unit 1383 searches for the feature vector F(l) taking the minimum distance dmin(F(l), F′(l)) based on the feature vector F(l) indicated by the input motion signal. Thereafter, the flow of processes goes to step S309.
(Step S309) The template updating unit'1383 determines whether the minimum distance dmin(F(l), F′(l)) is greater than or equal to a predetermined threshold value T. When it is determined that the minimum distance dmin(F(l), F′(l)) is greater than or equal to the threshold value T (YES in step S309), the flow of processes goes to step S310. When it is determined that the minimum distance dmin(F(l), F′(l)) is smaller than the threshold value T (NO in step S309), the flow of processes goes to step S311.
(Step S310) The template updating unit 1383 stores the template in which the feature vector F(l) indicated by the input motion signal and the input power spectrum λTE(k, l−1) are correlated with each other in the template storage unit 134 (addition of a template). Thereafter, the flow of processes goes to step S312.
(Step S311) The template updating unit 1383 reads the power spectrum λ′TE(k, l−1) corresponding to the selected feature vector F′(l) from the template storage unit 134. The template updating unit 1383 weights the stored power spectrum λ′TE(k, l−1) and the input power spectrum λTE(k, l−1) with weighting parameters η and 1−η, respectively, for example, using Equation 6 and adds the resultants to calculate an updated power spectrum λTE(k, l). The template updating unit 1383 stores the calculated updated power spectrum λTE(k, l) in the template storage unit 134 in correlation with the feature vector F′(l) related to the read power spectrum λ′TE(k, l−1) (updating of a template). Thereafter, the flow of processes goes to step S312.
(Step S312) The template reconstructing unit 139 determines whether or not the time passing from the time point at which the KD tree of the feature vectors F′(l) is reconstructed most recently is greater than a predetermined time interval τ. When it is determined that the elapsing time is greater than the time interval τ (YES in step S312), the flow of processes goes to step S313. When it is determined that the elapsing time is not greater than the time interval i (NO in step S312), the flow of processes is ended.
(Step S313) The template reconstructing unit 139 reconstructs the KD tree of the feature vectors F′(l) stored in the template storage unit 134. Thereafter, the flow of processes is ended.
(Step S320) The sound processing device 1 creates a target sound signal and then ends the flow of processes.
The process (step S320) of creating a target sound signal in the sound processing device 1 will be described below.
(Step S321) The speech determination signal indicating a speech from the speech determining unit 1381 is input to the addition unit 1333. The addition unit 1333 adds the stationary noise level (stationary component) λSNE(k, l) and the power spectrum λTE(k, l) of the non-stationary component. The addition unit 1333 outputs the created noise power spectrum λtot(k, l) to the gain calculating unit 1351.
The speech determination signal indicating a speech from the speech determining unit 1381 is also input to the power calculating unit 1382, but the power spectrum |N′n(k, l)|2 is not output to the template updating unit 1383. Accordingly, the processes of steps S308 to S311 are not performed.
Thereafter, the flow of processes goes to step S322.
(Step S322) The gain calculating unit 1351 calculates the gain GSS(k, l), for example, using Equation 2 based on the power spectrum |Y(k, l)|2 input from the power calculating unit 132 and the noise power spectrum λtot(k, l) input from the addition unit 1333. Thereafter, the flow of processes goes to step S323.
(Step S323) The filter unit 1352 calculates the estimated target spectrum X′(k, l) by multiplying the complex input spectrum Y(k, l) input from the frequency domain conversion unit 131 by the gain GSS(k, l) input from the gain calculating unit 1351. Accordingly, the noise power spectrum λtot(k, l) is subtracted from the power spectrum |Y(k, l)|2. The filter unit 1352 outputs the calculated estimated target spectrum X′(k, l) to the time domain conversion unit 136. Thereafter, the flow of processes goes to step S324.
(Step S324) The time domain conversion unit 136 converts the estimated target spectrum X′(k, l) input from the filter unit 1352 into a target sound signal x′(t) in the time domain and outputs the converted target sound signal x′(t) to the output unit 14. The output unit 14 outputs the target sound signal x′(t) input from the time domain conversion unit 136 to the outside of the sound processing device 1. Thereafter, the flow of processes is ended.
As described above, in this embodiment, when it is determined that the input sound signal is a non-speech signal, the power spectrum stored in the template storage unit 134 is updated based on the feature vector indicated by the input motion information and the power spectrum of the non-stationary noise component.
Accordingly, the power spectrum stored in the template storage unit 134 is updated to be adaptive to the non-stationariness of noise and the updated power spectrum is used for subtraction of the non-stationary noise. In this embodiment, the non-stationary noise is suppressed by using the updated power spectrum. In this embodiment, it is possible to effectively suppress noise, for example, even when the noise characteristics vary with the variation of a motor or an actuator with the lapse of time, without storing plural templates in the template storage unit 134 in the initial state.
A second embodiment of the invention will be described by referencing'the same elements or processes as in the above-mentioned embodiment by the same reference numerals.
The sound processing device 2 includes a sound pickup unit 11, a motion detecting unit 12, a frequency domain conversion unit 131, a power calculating unit 132, a noise estimating unit 233, a template storage unit 134, a subtraction unit 135, a time domain conversion unit 136, a template creating unit 238, and an output unit 14. That is, the sound processing device 2 includes the noise estimating unit 233 and the template creating unit 238 instead of the noise estimating unit 133 and the template creating unit 138 of the sound processing device 1 (see
The noise estimating unit 233 includes a stationary noise estimating unit 1331, a template estimating unit 2332, and an addition unit 1333. That is, the noise estimating unit 233 includes the template estimating unit 2332 instead of the template estimating unit 1332 (see
The template creating unit 238 includes a speech determining unit 1381, a power calculating unit 1382, and a template updating unit 2383. That is, the template creating unit 238 includes the template updating unit 2383 instead of the template updating unit 1383 of the template creating unit 138 (see
The template estimating unit 2332 and the template updating unit 2383 have the same configurations as the template estimating unit 1332 and the template updating unit 1383 and perform the same processes, respectively.
The template updating unit 2383 deletes the template not used for a predetermined time t′ out of the templates stored in the template storage unit 134. The template used by the template estimating unit 2332 is a template related to the feature vector F′(l) of which the Euclidean distance d(F(l), F′(l)) from the input feature vector F(l) is the minimum. When the template estimating unit 2332 employs the K-NN method, the templates related to the feature vectors F′(l) of which the Euclidean distance d(F(l), F′(l)) are the first to K-th smallest are the used templates.
Therefore, when storing an added or updated template in the template storage unit 134, the template updating unit 2383 stores time information indicating the time in correlation with the template.
On the other hand, when determining the feature vector F′(l) with the minimum Euclidean distance d(F(l), F′(l)), the template estimating unit 2332 creates time information indicating the time. The template estimating unit 2332 updates the time information stored in the template storage unit 134 in correlation with the template related to the feature vector F′(l) with the created time information. When the K-NN method is employed, the template estimating unit 2332 updates the time information corresponding to the template related to the feature vectors F′(l) with the first to K-th smallest Euclidean distances d(F(l), F′(l)) with the created time information.
The template updating unit 2383 searches for the template corresponding to the elapsing time of which the time from the time indicated by the time information stored in the template storage unit 134 to the present time is greater than the predetermined time t′ at a predetermined time interval (for example, a frame interval). When such a template is searched for, the template updating unit 2383 deletes the searched template from the template storage unit 134.
The template updating process according to this embodiment will be described below.
The template updating process according to this embodiment performs the processes of steps S414 to S416 after the processes of steps S301 to S311 and then performs the processes of steps S312 and S313.
(Step S414) The template updating unit 2383 stores the time information indicating the time of addition or update in the template storage unit 134 in correlation with the added or updated template. Thereafter, the flow of processes goes to step S415.
(Step S415) The template updating unit 2383 determines whether or not a template of which the elapsing time from the time indicated by the time information storage in the template storage unit 134 to the present time is greater than the predetermined time t′ is present. When it is determined that such a template is present (YES in step S415), the flow of processes goes to S416. When it is determined that such a template is not present (NO in step S415), the flow of processes goes to step S312.
(Step S416) The template updating unit 2383 deletes the template corresponding to the elapsing time greater than the predetermined time t′ from the template storage unit 134. Thereafter, the flow of processes goes to step S312.
Although it has been state that a sound feature value in which the non-used time is greater than a predetermined time out of the sound feature values stored in the storage unit, this embodiment is not limited to this example. In this embodiment, the sound feature value of which the number of used times is smaller than a predetermined number of times out of the sound feature values stored in the storage unit may be deleted.
As described above, in this embodiment, the sound feature value of which the use frequency is smaller than a predetermined frequency out of the sound feature values stored in the storage unit is deleted. Accordingly, it is possible to reduce the number of sound feature values to be searched for without degrading the noise suppressing performance and thus to reduce the amount of throughput associated with the search of the sound feature value.
A test example where the sound processing device 1 (see
The sampling frequency of a sound signal was set to 16 kHz and the frame shaft was set to 10 ms. The threshold value T of the Euclidean distance was 0.0001, the updating interval τ of the KD tree was set to 50 ms, and the forgetting parameter η was set to 0.9.
Before the test, the sound processing device was made to learn motor noise based on the motions of the robot and motion signals thereof for 200 seconds per 1 cycle. During the learning process, templates including a set of a feature vector based on the motion signal and a power spectrum based on the motor noise were created and the created templates were stored in the template storage unit 134. The learning process was repeated 20 times at most.
The learning quality in this embodiment will be described below. The estimation error and the number of templates were observed at the time of learning performed before the test as the index values of the leaning quality.
In
In Equation 7, |N(k, l)|2 represents the power spectrum of actual noise. |N′(k, l)|2 represents the power spectrum of the estimate noise in the embodiment or the related art. That is, the NNEE is a value obtained by normalizing the estimation error of the power spectrum of the noise with the power spectrum. As the NNEE decreases, the learning quality increases.
As shown in
In
The number of templates increases from 200 to 800 over the number of repetitions of 1 to 20 in this embodiment, but increases from 200 to 8,000 in the related art. Paying attention to the number of repetitions 20 the number of templates in this embodiment is 1/10 in the related art. In this embodiment, since the templates are updated depending on the surroundings, it is possible to suppress the unnecessary increases of the number of templates, thereby reducing the number of processes related to the search of templates.
The spectrogram of noise as a motion example will be described below for an original signal, stationary noise, noise estimated in the related art, and noise estimated in this embodiment.
In
In
In
In
The test method and conditions thereof will be described below. The test was carried out in a room with a length of 4.0 m, a width of 7.0 m, and a height of 3.0 m and with a reverberation time RT20 of 0.2 seconds. In the test, sets of motor noise and motion signals (three sets in total for 100 seconds) were used. When motor noise was generated, a participant uttered any of 236 words. In this test, background noise (BGN) was generated in addition to the motor noise and a human speech. In the following description, the test results under the following conditions (1) to (4) will be described. In the condition (1), the energy of background noise was kept constant and the S/N ratio (Signal-to-Noise ratio: SNR) of a speech was 3 dB. In the second condition (2), the energy of background noise was kept constant and the S/R ratio (SNR) of a speech was −3 dB. In the conditions and (4), Gaussian white noise in which the amplitude varies with the lapse of time was added to the condition (2). The Gaussian white noise is a sound source which simulates a non-stationary background noise. The average of the S/N ratios of speeches in the conditions (3) and (4) were −3.1 dB and −3.2 dB, respectively.
Hereinafter, a log-spectral distortion (LSD), a segmental SNR, and a word correct rate (WCR) were used as index values representing the test results.
The LSD is a value obtained by averaging the estimation errors of the estimated power spectrums |X′(k, l)| of sound signals over the overall frequency band with the number of frames L, as expressed by Equation 8.
In Equation 8, Lm{CC} is max(20 log10|X(k, l)|, δ), where δ=maxk,l{20 log10|X(k, l)|}−50. That is, Lm{CC} is a function of restricting the dynamic range of CC to a value between the maximum of 20 log10|X(k, l)| and a value smaller by 50 dB than the maximum. Accordingly, the smaller LSD means that it is more excellent.
The segmental SNR is a value obtained by averaging the ratios of an original sound signal to an estimation error within the number of frames L, as expressed by Equation 9. In the following description, the segmental SNR is simply referred to as SNR. Accordingly, the larger SNR means that it is more excellent.
The WCR is an accuracy rate of a word of the estimated target sound signal x′(t) recognized by the use of a speech recognition device. The number of words to be recognized was 236, and four males and four females uttered the words. The speech recognition device used in this test had a hidden Markov model (HMM) which is an acoustic model and a word dictionary. The speech recognition device was made to learn in advance by the use of Japanese newspaper article sentences (JNAS) corpus. The JNAS corpus included speech data of 60 hours uttered by 306 speakers. Accordingly, the words and the speakers were all unspecified. The sound feature values extracted from a sound signal by the use of the speech recognition device include 13 static Mel-scale log spectrum (MSLS), 13 delta MSLS, and one delta power. Accordingly, the higher WCR means that it is more excellent.
The rows in
In the condition (1), it could be seen that all the index values in this embodiment were the most excellent. In the condition (2), the NNEE, the LSD, and the WCR in this embodiment were the most excellent and the SNR was excellent next to the TE. Here, the SNR in the TE was 5.49 dB and the SNR in this embodiment was 5.24 dB, but the difference therebetween was merely 0.25 dB.
The rows in
In the conditions (3) and (4), it could be seen that all the index values in this embodiment were the most excellent. Accordingly, it could be seen from the result that this embodiment is more robust against the variation in noise than other methods.
Although it has been stated in the above-mentioned embodiment that the process (step S320) of creating a target sound signal x′(t) is performed when the speech determining unit 1381 determines that the input sound signal y(t) is in a non-speech segment (NO in step S304), this embodiment is not limited to this configuration. In this embodiment, the process (step S320) of creating a target sound signal x′(t) may be performed regardless of the result that the speech determining unit 1381 determines that the input sound signal y(t) is in the non-speech segment.
Although it has been stated in the above-mentioned embodiments that the motion detection unit 12 creates a motion signal of a mechanical apparatus equipped with the sound processing device 1 or 2, for example, a motion signal of a robot, the above-mentioned embodiments are not limited to this configuration. The motion detecting unit 12 is not particularly limited as long as it can operate while the sound processing device 1 processes the sound signal and can radiate motor noise to the surroundings. An example of such a mechanical apparatus is a vehicle equipped with an engine, a DVD player (Digital Versatile Disk Player), an HDD (Hard Disk Drive), and the like. That is, the sound processing device 1 may be mounted on a mechanical apparatus which is a motion control target and which cannot directly pick up sound generated due to the motion.
The motion detecting unit 12 may receive instruction signals (such as instruction data and commands) indicating instructions such as start and stop of a motion of such a mechanical apparatus and change of the motion pattern from the mechanical apparatus. In this case, the motion detecting unit 12 determines whether or not the input instruction signal is an instruction signal (ego-noise instruction signal) instructing the mechanical apparatus to create ego-noise. The motion detecting unit 12 outputs the motion signal to the template estimating unit 1332 or 2332 and the template updating unit 1383 or 2383, when it is determined that the input instruction signal is the ego-noise instruction signal.
Here, the motion detecting unit 12 stores the ego-noise instruction signal, for example, in a storage unit of the motion detecting unit 12 in advance. When an ego-noise instruction signal matched with the input instruction signal is stored in the storage unit, the motion detecting unit 12 determines that the input instruction signal is the ego-noise instruction signal. When an ego-noise instruction signal matched with the input instruction signal is not stored, the motion detecting unit 12 determines that the input instruction signal is an ego-noise instruction signal. For example, when the mechanical apparatus is a robot, examples of the ego-noise instruction signal include an instruction signal instructing the rotation of a motor driving a partial configuration or an instruction signal instructing the motion of a fan cooling the motor. That is, the motor noise generated with the rotation of the motor or the motion of the fan is considered as ego noise. For example, when the mechanical apparatus is a vehicle, examples of the ego-noise instruction signal include an instruction signal instructing the rotation or acceleration of an engine. That is, noise generated with the rotation of the engine or the driving of the vehicle or wind noise is considered as ego noise.
Accordingly, the template updating unit 1383 or 2383 performs the process of updating the template when it is determined that the input instruction signal is the ego-noise instruction signal. That is, the template updating unit 1383 or 2383 creates a template including the data based on the motion signal and the sound feature value based on the ego noise and stores the created template in the template storage unit 134. The template estimating unit 1332 or 2332 estimates sound feature values of components based on the ego noise using the created templates as search targets. Accordingly, the sound processing device 1 or 2 removes the sound feature values of the components based on the estimated ego noise from the sound feature values of the input sound signal.
A part of the sound processing devices 1 and 2 according to the above-mentioned embodiments, such as the frequency domain conversion unit 131, the power calculating unit 132, the noise estimating units 133 and 233, the subtraction unit 135, the gain calculating unit 1351, the filter unit 1352, the template creating units 138 and 238, and the template reconstructing unit 139, may be embodied by a computer. In this case, the various units may be embodied by recording a program for performing the control functions in a computer-readable recording medium and by causing a computer system to read and execute the program recorded in the recording medium. Here, the “computer system” is built in the sound processing devices 1 and 2, and includes an OS or hardware such as peripherals. Examples of the “computer-readable recording medium” include memory devices of portable mediums such as a flexible disk, a magneto-optical disc, a ROM, and a CD-ROM, a hard disk built in the computer system, and the like. The “computer-readable recording medium” may include a recording medium dynamically storing a program for a short time like a transmission medium when the program is transmitted via a network such as the Internet or a communication line such as a phone line and a recording medium storing a program for a predetermined time like a volatile memory in a computer system serving as a server or a client in that case. The program may embody a part of the above-mentioned functions. The program may embody the above-mentioned functions in cooperation with a program previously recorded in the computer system.
In addition, part or all of the sound processing devices 1 and 2 according to the above-mentioned embodiments may be embodied as an integrated circuit such as an LSI (Large Scale Integration). The functional blocks of the sound processing devices 1 and 2 may be individually formed into processors and a part or all thereof may be integrated as a single processor. The integration technique is not limited to the LSI, but they may be embodied as a dedicated circuit or a general-purpose processor. When an integration technique taking the place of the LSI appears with the development of semiconductor techniques, an integrated circuit based on the integration technique may be employed.
While an embodiment of the invention has been described in detail with reference to the drawings, practical configurations are not limited to the above-described embodiment, and design modifications can be made without departing from the scope of this invention.
This is a non-provisional patent application claiming benefit from U.S. provisional patent application Ser. No. 61/504,755, filed Jul. 6, 2011, the contents of which are entirely incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61504755 | Jul 2011 | US |