1. Technical Field
The present invention relates to an oversampling system, a decoding LSI chip, and an oversampling method for decoding and then oversampling digital audio compressed in units of frames. More specifically, the present invention relates to an oversampling system, a decoding LSI chip, and an oversampling method capable of decreasing the memory capacity of an output buffer used to oversample decoded data.
2. Related Art
Recently, the digital audio technology often uses the MPEG2 AAC (Advanced Audio Coding) 5.1 channel as MPEG audio. Reproduction of its contents needs to decode MPEG audio data. Decoding the MPEG audio data generates PCM audio data. In many cases, after oversampling the PCM audio data, DA conversion of the oversampled data is performed.
In
The AAC decoder 101 performs frame-based decoding and temporarily writes data of 1,024 words (samples) per channel to the output buffer 110. The oversampling section 102 double oversamples the decoded data (PCM audio data) of 1,024 samples per channel that is decoded by the AAC decoder 101, and is temporarily written to the output buffer 110. The oversampling section 102 writes the data as PCM audio data of 2,048 words per frame to the output buffer 110.
The output buffer 110 is provided with an output buffer area A and an output buffer area B. Accordingly, the output buffer 110 contains:
“a number of decoded output samples×2 (areas A and B)×2 (double oversampling)” per channel. In the case of 5.1 channels, the output buffer 110 has the memory capacity of:
“6 (channels)×1,024 (the number of samples)×2 (areas A and B)×2 (double oversampling)=24,576 words”.
At the beginning of processing a current frame N as shown in
In
The above-mentioned procedure is repeated to sequentially output data for frames N, N+1, N+2, and so on to the outside.
FIGS. 7(c) and 7(d) show timings for decoding and oversampling. As shown in
There has been described the conventional AAC decoding and oversampling processes using the dedicated LSI chip. According to the conventional example, however, each channel requires the buffer memory capacity four times as much as the number of data samples.
A conventional-art document (e.g., see patent document 1) related to the present invention discloses the following configuration. That is, a DSP processing result is written to a double-buffered output buffer that cyclically changes write and read modes. The DSP processing result is read at a specified sampling cycle and is output to the outside.
[Patent document 1]
Japanese Patent Application Laid-Open Publication No. 2004-12967
The present invention has been made in consideration of the foregoing. It is therefore an object of the present invention to provide an oversampling system (oversampling apparatus), a decoding LSI chip, and an oversampling method capable of decreasing the memory capacity of an output buffer used to oversample and output decoded data for digital audio. It should be noted that the present invention aims at decreasing the output buffer's memory capacity needed for oversampling and therefore the invention differs from the prior art disclosed in the patent document 1 as to its premise, objects, and configurations.
The present invention has been made in consideration of the foregoing. An oversampling apparatus according to the present invention is designed for oversampling decoded data a frame by frame basis at an oversampling ratio of α, and outputting the oversampled data a frame by frame basis. The inventive oversampling apparatus comprises: an output buffer that has a memory capacity α+1 times as much as one frame of the decoded data, such that the output buffer is divided into memory areas 1, 2, . . . , α and α+1 in ascending order of addresses for use; a first portion that operates during a first time slot sharing (α−1)/α of a time length of a current frame N for writing decoded data of the current frame N into the memory area α+1, and for allowing the output buffer to output a first part of oversampled data of a preceding frame N−1 which has been previously written in the memory areas 1 to α−1 so that the memory areas 1 to α−1 are made free; a second portion that operates during a second time slot sharing 1/α of the time length of the current frame N for reading the decoded data of the current frame N written in the memory area α+1 of the output buffer so that the memory area α+1 is made free and the read data of the current frame N is oversampled, and writing the oversampled data of the current frame N into the free memory area α+1 and the free memory areas 1 to α−1, and further allowing the output buffer to output a second part of the oversampled data of the preceding frame N−1 which has been previously written in the memory area α, so that the memory area α is made free for writing of decoded data of a succeeding frame N+1; and a third portion that controls the output buffer to shift the addresses of the memory areas 1 to α+1 in cyclic manner while the first and second portions sequentially repeat writing and reading of the decoded data, writing of the oversampled data, and outputting of the oversampled data from the output buffer with respect to the succeeding frames N+1, N+2, and so on.
In this manner, the output buffer can be efficiently used. It is possible to decrease the memory capacity of the output buffer used to oversample the decoded data in digital audio. During double oversampling (α=2), for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
Another oversampling apparatus according to the present invention is designed for oversampling decoded data composed of a plurality of channels, a frame by frame basis, at an oversampling ratio of α, and outputting the oversampled data composed of the plurality of the channels, a frame by frame basis. The inventive oversampling apparatus comprises: an output buffer that has a memory capacity α+1 times as much as one frame of the decoded data composed of the plurality of the channels, such that the output buffer is divided into a plurality of memory areas which are sequentially allocated to the plurality of the channels, and that each memory area of each channel is divided into sub memory areas 1, 2, . . . , α and α+1 in ascending order of addresses for use; a first portion that operates during a first time slot sharing (α−1)/α of a time length of a current frame N for writing decoded data of each channel of the current frame N into the sub memory area α+1 of each channel, and for allowing the output buffer to output a first part of oversampled data of each channel of a preceding frame N−1 which has been previously written in the sub memory areas 1 to α−1 of each channel so that the sub memory areas 1 to α−1 are made free; a second portion that operates during a second time slot sharing 1/α of the time length of the current frame N for reading the decoded data of each channel of the current frame N written in the sub memory area α+1 of each channel of the output buffer so that the sub memory area α+1 is made free and the read data of each channel of the current frame N is oversampled, and writing the oversampled data of each channel of the current frame N into the free sub memory area α+1 of each channel and the free sub memory areas 1 to α−1 of each channel, and further allowing the output buffer to output a second part of the oversampled data of each channel of the preceding frame N−1 which has been previously written in the sub memory area α of each channel, so that the sub memory area α is made free for writing of decoded data of a succeeding frame N+1; and a third portion that controls the output buffer to shift the addresses of the plurality of the memory areas in cyclic manner while the first and second portions sequentially repeat writing and reading of the decoded data, writing of the oversampled data, and outputting of the oversampled data from the output buffer with respect to the succeeding frames N+1, N+2, and so on.
In this manner, the output buffer can be efficiently used even when oversampling multi-channel decoded data. It is possible to decrease the memory capacity of the output buffer used to oversample decoded data. During double oversampling, for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
A decoding LSI chip according to the present invention comprises a semiconductor chip and integrates a circuit of the oversampling apparatus as defined above.
Accordingly, it is possible to decrease the memory capacity needed for oversampling in the decoding LSI chip.
An oversampling method according to the present invention is provided for oversampling decoded data a frame by frame basis at an oversampling ratio of α, and outputting the oversampled data a frame by frame basis from an output buffer which has a memory capacity α+1 times as much as one frame of the decoded data, such that the output buffer is divided into memory areas 1, 2, . . . , α and α+1 in ascending order of addresses for use. The inventive oversampling method comprises: a first process that is performed during a first time slot sharing (α−1)/α of a time length of a current frame N for writing decoded data of the current frame N into the memory area α+1, and for allowing the output buffer to output a first part of oversampled data of a preceding frame N−1 which has been previously written in the memory areas 1 to α−1 so that the memory areas 1 to α−1 are made free; a second process that is performed during a second time slot sharing 1/α of the time length of the current frame N for reading the decoded data of the current frame N written in the memory area α+1 of the output buffer so that the memory area α+1 is made free and the read data of the current frame N is oversampled, and writing the oversampled data of the current frame N into the free memory area α+1 and the free memory areas 1 to α−1, and further allowing the output buffer to output a second part of the oversampled data of the preceding frame N−1 which has been previously written in the memory area α, so that the memory area α is made free for writing of decoded data of a succeeding frame N+1; and a third process that is performed to control the output buffer to shift the addresses of the memory areas 1 to α+1 in cyclic manner while the first and second processes are sequentially performed to repeat writing and reading of the decoded data, writing of the oversampled data, and outputting of the oversampled data from the output buffer with respect to the succeeding frames N+1, N+2, and so on.
In this manner, the output buffer can be efficiently used. It is possible to decrease the memory capacity of the output buffer used to oversample decoded data in digital audio. During double oversampling, for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
Another oversampling method according to the present invention is provided for oversampling decoded data composed of a plurality of channels, a frame by frame basis, at an oversampling ratio of α, and outputting the oversampled data composed of the plurality of the channels, a frame by frame basis, from an output buffer which has a memory capacity α+1 times as much as one frame of the decoded data composed of the plurality of the channels, such that the output buffer is divided into a plurality of memory areas which are sequentially allocated to the plurality of the channels, and that each memory area of each channel is divided into sub memory areas 1, 2, . . . , α and α+1 in ascending order of addresses for use. The inventive oversampling method comprises: a first process that is performed during a first time slot sharing (α−1)/α of a time length of a current frame N for writing decoded data of each channel of the current frame N into the sub memory area α+1 of each channel, and for allowing the output buffer to output a first part of oversampled data of each channel of a preceding frame N−1 which has been previously written in the sub memory areas 1 to α−1 of each channel so that the sub memory areas 1 to α−1 are made free; a second process that is performed during a second time slot sharing 1/α of the time length of the current frame N for reading the decoded data of each channel of the current frame N written in the sub memory area α+1 of each channel of the output buffer so that the sub memory area α+1 is made free and the read data of each channel of the current frame N is oversampled, and writing the oversampled data of each channel of the current frame N into the free sub memory area α+1 of each channel and the free sub memory areas 1 to α−1 of each channel, and further allowing the output buffer to output a second part of the oversampled data of each channel of the preceding frame N−1 which has been previously written in the sub memory area α of each channel, so that the sub memory area α is made free for writing of decoded data of a succeeding frame N+1; and a third process that is performed to control the output buffer to shift the addresses of the plurality of the memory areas in cyclic manner while the first and second possesses are sequentially performed to repeat writing and reading of the decoded data, writing of the oversampled data, and outputting of the oversampled data from the output buffer with respect to the succeeding frames N+1, N+2, and so on.
In this manner, it is possible to decrease the memory capacity of the output buffer used to oversample decoded data even when oversampling multi-channel decoded data. During double oversampling, for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
The oversampling apparatus and the oversampling method according to the present invention make it possible to effectively use the output buffer. It is possible to decrease the memory capacity of the output buffer used to oversample decoded data in digital audio. During double oversampling, for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
The oversampling apparatus and the oversampling method according to the present invention make it possible to decrease the memory capacity of the output buffer used to oversample decoded data even when oversampling multi-channel decoded data. During double oversampling, for example, the output buffer∝s memory capacity can be saved 25% compared to conventional examples.
The decoding LSI chip according to the present invention is provided with any one of the above-mentioned oversampling systems. It is possible to decrease the. memory capacity needed for oversampling in the decoding LSI chip.
FIGS. 3(a) and 3(b) are an explanatory diagram of an output buffer.
FIGS. 5(a) and 5(b) are a diagram showing output buffer states for triple and quadruple oversampling, respectively.
The best mode for carrying out the present invention will be described in further detail with reference to the accompanying drawings.
[Configuration of an Oversampling System (Oversampling Apparatus)]
In
At the input side, an input stream signal Din is a bit stream signal obtained by sampling a 5.1-channel audio signal and encoding it according to MPEG2 AAC. Input stream signal Din contains time-divisional data for each channel. Input word clock signal f determines the sampling cycle of input stream signal Din. Input bit clock signal CKout determines the position of each bit in the input stream signal Din.
At the output side, an output PCM signal Dout is generated by oversampling decoded data (a signal obtained by decoding the MPEG2 AAC signal) and outputting the resulting data as an audio PCM signal. Output word clock fo determines the sampling cycle of output PCM signal Dout. The cycle of Output word clock fo is formulated as input word clock signal f×α (oversampling ratio). Output bit clock signal CKout determines the position of each bit in output PCM signal Dout.
In the above-mentioned configuration of the decoding LSI chip 1 according to the present invention, the input I/F 2 receives external input signals Din, CKin, and f and supplies these signals to the input buffer 3 and the sample counter 4. The input buffer 3 receives the input stream signal Din from the input I/F 2, and converts this signal into parallel data in units of frames and temporarily stores this data.
The sample counter 4 generates sampling timing from input word clock signal f and supplies the DSP 10 with information such as frame time (F) and half frame time (F/2).
The output buffer 5 stores the oversampled data and decoded data. The oversampled data stored in the output buffer 5 is output to the outside via the output I/F 6.
The output buffer 5 is provided with buffer areas A and B for each channel. The output buffer 5 as a whole constitutes a cyclic buffer or ring buffer. During double oversampling (α=2), for example, the output buffer 5 allows the read start position to shift so as to be configured as shown in
The memory capacity and specific operation examples of the output buffer 5 will be described later.
The decoding section 11 in the DSP 10 reads and decodes frame-based data recorded in the input buffer 3 to generate decoded data and supplies this data to the oversampling section 12.
The decoded data writing section 13 in the oversampling section 12 receives the decoded data from the decoding section 11 and (temporarily) outputs it to the output buffer 5 during the first half of frame N. In this case, the decoded data is stored in the buffer area B corresponding to each channel during the first half of the frame N as shown in
The oversampling data writing section 14 in the oversampling section 12 reads decoded data saved in the buffer area B of the output buffer 5, oversamples the data, and finally outputs it to the output buffer 5. In this case, the oversampled data is stored in the buffer area B during the second half of frame N as shown in
The output I/F 6 is provided with operation timing from the output word clock signal fo and outputs the oversampled signal recorded in the output buffer 5 as the output PCM signal Dout to the outside at a sampling cycle.
[Specific Operation Example]
With reference to
In this case, the capacity of the output buffer 5 is calculated as follows according to “the number of channels×the number of decoded output samples×(1+α)”.
5.1 channels×1,024×(1+2)=18,432 words (samples)
The output buffer 5 is provided with buffer areas A and B for each channel. The output buffer 5 as a whole constitutes a cyclic buffer. During double sampling (α=2), as shown in
For the first half time slot of the time length of a current frame N as shown in
When the system outputs data of 1,024 words for the first half part of the output buffer area A, the first half of the buffer area A for 1,024 words/channel becomes empty and made free. This free area is used as buffer area B for the second half time slot of the frame N. During the second half time slot of frame N, the output buffer 5 maintains a state as shown in
During the second half time slot of frame N as shown in
According to the example shown in
As mentioned above, when the decoded data oversampling system according to the present invention performs double oversampling after MPEG2 AAC 5.1-channel decoding, the capacity of the output buffer 5 requires “5.1 channels×1,024×(1+2)=18.432 words (samples)” according to “the number of channels×the number of decoded output samples×(1+α)”. This saves the memory capacity 25% compared to 24,576 words of the conventional-example. Further increasing the sampling ratio α more decreases the memory capacity.
First, it is determined to process data in current frame N (step S1).
The process starts for the first half time spot of frame N (step S2). During the first half time slot of frame N, the process writes a decoding result (1,024 words of decoded data) to output buffer area B (1,024 words/channel) (step S3).
The process outputs a first half part of the result of the previous frame N−1 (1,024 words equivalent to the first half of 2,048 words/channel) from output buffer area A to the outside of the decoding LSI chip (step S4).
The process then starts for the second half time slot of frame N (step S5).
For the second half time slot of frame N, the process reads the decoded data (1,024 words) recorded at step S3 from buffer area B (step S6).
The process oversamples this decoded data (step S7). The process writes the oversampling result to output buffer B (2,048 words/channel) (step S8).
The process outputs the remaining second half part of the result of the previous frame N−1 (1,024 words equivalent to the second half of 2,048 words/channel) from the output buffer area A to the outside of the decoding LSI chip.
The process updates frame N to frame N+1 to repeat the above-mentioned steps.
When a is greater than or equal to 3, as shown in
Namely, the inventive oversampling method is designed for oversampling decoded data composed of a plurality of channels, a frame by frame basis, at an oversampling ratio of α, and outputting the oversampled data composed of the plurality of the channels, a frame by frame basis, from an output buffer which has a memory capacity α+1 times as much as one frame of the decoded data composed of the plurality of the channels, such that the output buffer is divided into a plurality of memory areas which are sequentially allocated to the plurality of the channels, and that each memory area of each channel is divided into sub memory areas 1, 2, . . . , α and α+1 in ascending order of addresses for use.
First, second and third processes are performed according to the inventive oversampling method. Namely, the first process is performed during a first time slot sharing (α−1)/α of a time length of a current frame N for writing decoded data of each channel of the current frame N into the sub memory area α+1 of each channel, and for allowing the output buffer to output a first part of oversampled data of each channel of a preceding frame N−1 which has been previously written in the sub memory areas 1 to α−1 of each channel so that the sub memory areas 1 to α−1 are made free. The second process is performed during a second time slot sharing 1/α of the time length of the current frame N for reading the decoded data of each channel of the current frame N written in the sub memory area α+1 of each channel of the output buffer so that the sub memory area α+1 is made free and the read data of each channel of the current frame N is oversampled, and writing the oversampled data of each channel of the current frame N into the free sub memory area α+1 of each channel and the free sub memory areas 1 to α−1 of each channel, and further allowing the output buffer to output a second part of the oversampled data of each channel of the preceding frame N−1 which has been previously written in the sub memory area α of each channel, so that the sub memory area α is made free for writing of decoded data of a succeeding frame N+1. The third process is performed to control the output buffer to shift the addresses of the plurality of the memory areas in cyclic manner while the first and second possesses are sequentially performed to repeat writing and reading of the decoded data, writing of the oversampled data, and outputting of the oversampled data from the output buffer with respect to the succeeding frames N+1, N+2, and so on.
While there has been described the embodiment of the present invention, it is to be distinctly understood that the oversampling system (oversampling apparatus) of the present invention is not limited to the above-mentioned examples but may be otherwise variously modified within the spirit and scope of the invention.
The present invention provides the effect capable of decreasing the memory capacity of the output buffer used to oversample decoded data in units of frames. Accordingly, the present invention is useful for oversampling systems, decoding LSI chips, and oversampling methods of audio signals.
Number | Date | Country | Kind |
---|---|---|---|
2004-305572 | Oct 2004 | JP | national |