The invention relates to a method and to an apparatus for frequency domain watermark processing a multi-channel audio signal in real-time, wherein enough processing power is not available in any case for watermark processing all channels of a current input section of the audio signal, and wherein for the watermark processing the audio signal is processed per channel in an overlap/add manner.
Digital audio signal watermarking in real-time is difficult in an environment that has limited processing power. This is for example the case on an embedded platform in which due to cost, heat and loudness reasons usually low power processing units are used, or in a server in which a powerful processor has to watermark in real-time several data streams in parallel.
Usually audio watermarking systems are operating in a block based manner where the watermark (WM) embedder gets a block of N input signal samples, WM processes this block and returns a block of N modified output signal samples. Real-time means that the time period available for WM processing of a signal data block is shorter than the time period used to get the next signal data block. If the WM processing time is longer, the real-time constraint is violated and a buffer overflow at the input of the embedder will occur, which leads to dropping of samples and audible artifacts and degradation of the audio quality.
In addition, the processing time required for watermark embedding is often audio signal content-dependent.
It is therefore important to ensure watermarking processing for an audio data stream without violating the real-time constraint. On one hand this means that in most cases not all channels in a multi-channel data stream can be marked. On the other hand, it is advantageous to watermark as many channels of an audio data stream as possible in order to increase robustness and security of the watermark. In 5.1 channel audio, for example, the WM robustness and security decreases a lot if only the centre channel is watermarked instead of the left, centre and right channels or all six channels.
In order to guarantee real-time processing in the above-mentioned restricted environment, a worst-case input signal has to be found for which the watermark embedder will need the longest processing time. Based on such time period the maximum number of channels, which can be marked in real-time, can be calculated. However, the disadvantage of such solution is that most input signals can be processed faster than the above-mentioned worst-case input signal, and that most of the time the embedder watermarks less channels than possible, which decreases robustness and security.
A problem to be solved by the invention is to provide a watermark processing with real-time constraint in which as many audio input signal channels as possible can be watermarked.
According to the invention, the channels in a data block-based audio multi-channel signal are prioritized with respect to watermarking importance, whereby the channel priority can change for different input signal data blocks. For a current input signal block, the most important channel is watermarked, for example the centre channel in a 5.1 setting, and the required processing time is determined. If this required processing time is shorter than a predefined application-dependent threshold, the next most important channel (for example the left channel) is marked and the additionally required processing time is determined. In this way, the channels in decreasing importance are successively marked for the current input signal block until the totally required processing time is longer than a predefined processing time threshold. Thereafter the remaining channels are not watermarked, but only the necessary audio processing is performed, so that no blocking artifacts will occur. Such ‘anti-blocking processing’ (cf. description below) is usually much faster than the full WM embedding processing and therefore this way of procedure will guarantee the adherence of the real-time constraint.
Due to the block-based nature of audio coding and watermarking and due to the sensitivity of the resulting audio quality against blocking artifacts, several problems have to be solved in order to lead to acceptable performance and quality.
The invention optimizes the trade-off between WM robustness and security on one hand and the real-time processing constraint on the other hand.
In principle, the inventive method is suited for frequency domain watermark processing a multi-channel audio signal in real-time, wherein enough processing power is not available in any case for watermark processing all channels of a current input section of said audio signal, and wherein for said watermark processing said audio signal is processed per channel in an overlap/add manner for the current input section of said audio signal and the following input section of said audio signal, said method including the steps:
In principle the inventive apparatus is suited for frequency domain watermark processing a multi-channel audio signal in real-time, wherein enough processing power is not available in any case for watermark processing all channels of a current input section of said audio signal, and wherein for said watermark processing said audio signal is processed per channel in an overlap/add manner for the current input section of said audio signal and the following input section of said audio signal, said apparatus including means being adapted for:
Exemplary embodiments of the invention are described with reference to the accompanying drawings, which show in:
Most audio processing algorithms, be it audio coding or audio watermarking, are block based, in which a block of N input signal samples is processed at the same time and generates N output samples. The reason for such block based processing is that part of the processing is carried out in frequency domain while the input samples are in time domain, wherein typically a block of N time domain samples is trans-formed with the fast Fourier transform (FFT) or the modified discrete cosine transform (MDCT) and is processed in frequency domain and is transformed back to time domain using the corresponding inverse transform. Because such transforms are very efficient for a power-of-two length, a size of 512 or 1024 samples is mostly used.
A straight-forward way of block based audio processing would be to generate from the kth input block Ik of size N, containing input samples k*N to (k+1)*N−1 directly the kth output block Ok of size N containing output samples k*N to (k+1)*N−1. However, the input audio signal is continuous at block boundaries, i.e. at the border between input blocks Ik and Ik+1, and if the content of blocks Ik and Ik+1 is processed independently it will happen that the transition between the output blocks Ok and Ok+1 is not continuous, resulting in audible clicking artifacts. The well-known solution for this problem is to use weighted overlap-add (WOLA) transforms in which original audio signal input blocks are weighted and overlapped, transformed, inverse transformed, and are weighted and added when forming the output signal, cf. J. B. Allen, “Short Term Spectral Analysis, Synthesis, and Modification by Discrete Fourier Transform”, IEEE Trans-actions on Acoustics, Speech, and Signal Processing, vol. ASSP-25, no. 3, pp. 235-238, June 1977.
Instead of concatenating complete blocks of length N, half blocks of length N/2 can be concatenated in a successive manner (e.g. the second half of block Jk with the first half of block Jk+1, the first half of block Jk+1 with the second half of block Jk+1, the second half of block Jk+1 with the first half of block Jk+2, and so on), and the corresponding overlapping is N/2.
In step or stage WTk block Ik in principle is amplitude weighted and transformed, watermark modification k is applied within the frequency domain, and the resulting block is inversely transformed, producing an output block Ok of size 2N.
The transform can be an FFT, which generates from every 2N input values 2N transformed output values, and the corresponding inverse transform IFFT generates from every 2N input values 2N inversely transformed output values, or the trans-form can be an MDCT, which generates from every 2N input values N transformed output values, and the corresponding inverse transform IMDCT generates from every N input values 2N inversely transformed output values.
The first block Ok of the current output block pair Ok/Ok+1 and the second block Ok of the previous output block pair Ok−1/Ok are amplitude weighted and added in step or stage WA to produce a final output block Pk of size N. Both amplitude weightings of both blocks, at the input of WTk and in WA, are carried out such that there is an overall flat response. For example, the amplitude weighting uses sine and cosine functions so that sin2+cos2=constant, e.g. 1. The first original input block J0 of the audio data stream does not produce an output block according to the above-described processing. Instead, the first final output block P0 is a combination of the first output block O0 and original input block J0. This means that the final output blocks Pk are delayed by one block relative to the corresponding input blocks Jk:
As mentioned above, in some applications there is not enough processing power available for watermarking all channels of a multi-channel audio data stream in real-time. This happens for example on embedded platforms like set-top boxes for TV signal reception, but also on a large server that is processing many data streams at the same time. In addition, a processor charged with performing the watermarking may also carry out other tasks like audio coding, and therefore the current load of that processor can vary over time.
Not marking all channels may degrade the security of the watermarking (WM) system because it may be possible to remove the watermarked channel without degrading too much the user experience. If for example in a 5.1 audio data stream only the left channel is marked, dependent on the content it may be possible to generate a new 2.1 audio data stream based on all channels except the left channel. Of course, in such stream no watermark can be detected.
Not marking all channels will also degrade the robustness against unauthorized microphone capture of the WM system audio output e.g. in a cinema because at the microphone stage all channels are automatically mixed together. Usually all channels are marked in the same way, which means that in this mix the watermark is added up. If, on the other hand, some channels are not marked, they simply can act as additional noise to the WM detector, which may result in non-detectability of the watermark.
The fact that the time needed for embedding the watermark is often content-dependent complicates the situation even more, as shown in
The inventive dynamic channel marking provides an optimal trade-off between real-time requirements, robustness and security. As mentioned above, in some applications it is not possible to watermark all channels of an audio data stream. Therefore the channels are prioritized. On a 5.1 setting for example, most of the audio signal content or energy is in the left, right and/or centre channels. The low-frequency effects (LFE) channel and the surround channels usually do not carry a significant amount of information. Therefore the priorities for a 5.1 audio data stream can be set to: 1. Centre, 2. Left, 3. Right, 4. Left surround, 5. Right surround, 6. LFE.
For each successive signal input block in the dynamic channel marking as many channels as possible in decreasing priority are watermarked, without violating the real-time processing power constraint and without harming audio quality due to block artifacts.
Three states of the inventive watermarking process of an audio channel are defined:
INIT is the state for the processing of the first block of the audio data stream (block J0 in
PROCESS is the normal processing operation state (blocks J1, J2 and J3 in
In the state PASSTHROUGH no watermarking processing is performed, but only a corresponding input block (blocks Jk and Jk+1 in
In the
If currently remaining processing power is available for watermarking processing, current audio channel m of the priority list is watermarked in step 35 and the priority list channel number m is incremented by ‘1’ in step 36, i.e. m+1. If not true, the current audio channel m is not watermarked in step 39 and the channel priority list number m is incremented by ‘1’ in step 36.
Step 37 checks whether there are more remaining channels in the channel priority list. If true, the next audio channel m of the audio channel priority list is selected in step 38, the current timer value in step 33 is read and the processing continues as described before. If not true, the watermarking processing for the current audio signal block or section is finished and the processing continues for the first priority list channel for the following audio signal block or section.
The channel counter m is increased independently of whether or not a current channel is watermarked. This ensures that the same modification (or a similar one because the modification may be content-dependent) is applied to all channels of one audio signal block or section, independently of whether or not some channels have been in status PASSTHROUGH.
More detailed flow charts for the MarkCannel step 35 and the NotMarkChannel step 39 of
In
In case there is no watermarking processing power left for further channels of the current audio signal block or section, the watermarking processing state changes for remaining channels from state PROCESS to state PASSTHROUGH as depicted in
In case during the processing of a current input signal block or section there is unexpectedly watermarking processing power left for further channels of the current audio signal block or section (for instance due to less processor power being required for a different task), the watermarking processing state can change for remaining channels of the current audio signal block or section from state PASSTHROUGH to state PROCESS as depicted in
Advantageously, the prioritization of the channels needs not be constant over time. For example, if in a 5.1 setting only two channels are watermarked, whereby the most important channel is the centre channel, left and right may be equally important. To make the life of an attacker more difficult it is advantageous to mark in such case the centre and left channels for a first time period and thereafter the centre and right channels for a second time period, and to repeat this alternation until the end of the audio data stream.
Number | Date | Country | Kind |
---|---|---|---|
11306062.8 | Aug 2011 | EP | regional |