Aspects of the present disclosure relate to digital signal processing methods and, more particularly, to a system, method, apparatus, and computer program product for calculating a sampled signal, including calculation of a sampled signal for an arbitrary variation of sampling rate, without the use of polyphase filters.
A continuous signal may be represented as discrete samples for digital processing, transmission, etc. If the original signal x(t) has a bounded spectrum with a maximum frequency F/2, then, according to Kotelnikov (Nyquist-Shannon) theorem, it can be unambiguously, and without loss, restored over its discrete samples taken with a frequency strictly greater than F. More particularly, if the samples are taken with a period
then the following expression is true:
Despite the fact that the theorem implies an infinite sum, in practice it appears reasonable to pick out a sufficiently large window size, and the larger the window size, the closer the result to the theoretical value.
In some instances, it may be desirable to vary the sampling frequency though, for convenience, the period may be used for illustration rather than the frequency. The original sampling period may be denoted by Ts, thus the signal values may be known at instants of time Ts·k,k∈Z. The sampling period, which is to be obtained, may be denoted by Td, i.e. the signal values x(t) at instants of time Td·n,n∈Z are to be calculated.
With decreasing the frequency (increasing the period), it may be necessary to ensure that the signal spectrum still satisfies the conditions of the theorem for the new sampling frequency. Therefore, low frequencies should be filtered. Fortunately, sinc-function is a low-pass filter. So, for example, in order to decrease the sampling frequency (accordingly, increase the period, Td>Ts), it may be sufficient to calculate (1) in points Td·n by substituting
for the multiplier
For practical implementation, equation (1) may be rewritten in the approximate form:
{circumflex over (x)}(t)=Σk=−N/2N/2x(k·Ts)·sinc(K·(t−k·Ts)) (3)
where
The resulting signal {circumflex over (x)}(t) is marked with a “hat” in equation (3) as it still is different from the original signal, i.e. samples of which are available. This difference is dictated, in one instance, by filtering and, in another instance, by inevitable distortions that are introduced by the finite sum. A smoothing window can also be applied, if desired.
One shortcoming of resampling may be solved, in some instances, using equation (3). However, if a sufficiently large N is taken, this convolution will be very resource-intensive. Firstly, it will require N multiplications by each sample and, secondly, the values of sinc-function will have to be computed, at worst, for each calculated sample. Efficient computation is possible only if the convolution kernels are computed in advance, and the convolutions themselves are optimized, for example, in accordance with the properties of the Fourier transform.
With certain ratios of sampling frequencies (periods), the number of convolution kernels can be reduced. For example, if it is necessary to obtain the frequency Fd, given the initial frequency Fs, and the ratio Q=Fs/Fd is an integer, one kernel can be needed and it can be calculated once. The resulting samples will be Q times less in number and they can be normally calculated using equation (3) for each t=Q*Ts*n. In practice, it may be easier to perform convolution for each original sample, using the properties of fast Fourier transform (FFT), and then take every Qth sample, i.e. perform decimation. In doing so, the convolution kernel is calculated only once. Increasing the frequency by an integer number of times is not likely to present any difficulties.
With a rational frequency ratio, i.e. when the initial Fs and final Fd frequencies are integers, but not multiples of each other, it may be possible to perform a two-pass resampling. First, the frequency must be increased until the frequency, which is the greatest common multiple of Fs and Fd, is achieved, and then reduced to the required value. Each of these operations changes the frequency by a factor of an integer. One disadvantage of this approach is that the least common multiple can be very large and, therefore, huge amounts of data will have to be processed.
For rational frequency ratios, the so-called polyphase filters can also be used. Technical implementations may vary, so presented herein is the basic concept. Looking at the argument of sinc-function in equation (3), it may be apparent that the fractional part
is repeated. Thus, kernels may be calculated for all possible phases and then new samples computed using equation (3). However, this process may be difficult, and may not be versatile. In addition, the properties of FFT cannot always be used efficiently, since most of the calculated data is lost during decimation.
There are also methods of signal approximation in the areas corresponding to the new samples. Farrow filters can be used, as an example. However, such methods, though computationally simple, may give a very inaccurate result.
It is emphasized that all of the above methods are not universal or do not, in principle, provide an exact calculation. Versatile and precise methods may be achieved, for example, only through direct implementation of equation (3). Accordingly, there exists a need for a relatively simple, but versatile and precise, method for resampling of a signal.
The above and other needs are met by aspects of the present disclosure, wherein one such aspect relates to a method which allows the original signal to be calculated over discrete samples with arbitrary accuracy (provided the conditions of Kotelnikov theorem are fulfilled). Polyphase filtering is not used in such a method in accordance with various example embodiments disclosed herein. In some example implementations disclosed herein, such a method may be used for arbitrary (including irrational) variation of sampling rate of the signal with a bounded spectrum. Direct application of Kotelnikov (Nyquist-Shannon) theorem may also provide similar results. However, with a large window being required for a qualitative result through direct application of the Kotelnikov theorem, aspects of the disclosed methods allow much faster calculation than provided by previous approaches.
In some instances, the calculation may be performed according to the Kotelnikov theorem but, instead of discrete signal convolutions with kernels having different phases, a function series expansion, such as a Taylor expansion, may be used. Fast operation may be achieved in such example embodiments using a small number of filters, whose kernels can be computed at the beginning of the process, and effective use of the properties of FFT, since no subsequent decimation is required. As an example in accordance with some example embodiments, let the initial sampling period be a time unit, then, after calculating the signal derivatives at each integer point, it becomes possible to perform Taylor expansion in the neighborhood of each integer point. Thus, in accordance with such example embodiments, for any point in time, the nearest integer point may be found and the value calculated with any given accuracy.
In a first example embodiment, a method for calculating a sampled signal is provided. The method of this example embodiment may include determining a plurality of discrete samples of a continuous signal having a finite spectrum. The method of this example embodiment may further include using a function series expansion to calculate at least a portion of the continuous signal over the plurality of discrete samples.
In a second example embodiment, an apparatus comprising processing circuitry is provided. The processing circuitry of this example embodiment may be configured to control the apparatus to determine a plurality of discrete samples of a continuous signal having a finite spectrum. The processing circuitry of this example embodiment may be further configured to control the apparatus to use a function series expansion to calculate at least a portion of the continuous signal over the plurality of discrete samples.
In a third example embodiment, a computer program product comprising at least one non-transitory computer readable storage medium having computer program code stored thereon. The program code of this embodiment may include program code for determining a plurality of discrete samples of a continuous signal having a finite spectrum. The program code of this embodiment may further include program code for using a function series expansion to calculate at least a portion of the continuous signal over the plurality of discrete samples.
In a fourth example embodiment, an apparatus is provided. The apparatus of this example embodiment may include means for determining a plurality of discrete samples of a continuous signal having a finite spectrum. The apparatus of this example embodiment may further include means for using a function series expansion to calculate at least a portion of the continuous signal over the plurality of discrete samples.
Aspects of the present disclosure thus address the identified needs and provide other advantages as otherwise detailed herein. It will be appreciated that the above summary is provided merely for purposes of summarizing some example embodiments so as to provide a basic understanding of some aspects of the disclosure. As such, it will be appreciated that the above described example embodiments are merely examples and should not be construed to narrow the scope or spirit of the disclosure in any way. It will be appreciated that the scope of the disclosure encompasses many potential embodiments, some of which will be further described below, in addition to those here summarized.
Having thus described the disclosure in general terms, reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:
The present disclosure now will be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all aspects of the disclosure are shown. Indeed, the disclosure may be embodied in many different forms and should not be construed as limited to the aspects set forth herein; rather, these aspects are provided so that this disclosure will satisfy applicable legal requirements. Like numbers refer to like elements throughout.
Aspects of the present disclosure are generally directed to apparatuses and methods for calculating signal values at instants of time Td·n given the values Ts·k (with possible filtering, at lowering the frequencies). Without loss of generality, the initial period may be assumed as Ts=1. Hereinafter, the time may be measured in the initial sampling periods Ts (see, e.g.,
In
Since we assume that the original signal x(t) (as well as filtered {circumflex over (x)}(t)) satisfies the Kotelnikov theorem and has a finite spectrum, it is an infinitely differentiable function. Therefore, the original signal can be expanded using a function series expansion. For example, we can expand the Taylor series of the original signal in the neighborhood of any point with the known derivatives:
If we take the nearest known point, in whose neighborhood lies the calculated point, as the origin of coordinates, then the expansion will be in the neighborhood of zero.
To perform the expansion, the derivatives of the calculated signal should be computable. To calculate the signal itself (perhaps, with filtering), using equation (3), it is necessary to perform convolution of the sampled version with sinc-function. Let * denote convolution, D—differentiation. According to the properties of the convolution, the following equation is true:
D(f*g)=D(f)*g=f*D(g) (6)
Note that sinc-function is an infinitely differentiable function. Consider some of its derivatives:
etc. In order not to complicate the equation, the value is not explicitly defined at 0, though it may be assumed that the function may be continued by continuity at 0.
From equations (3) and (6), the calculation of the derivatives follows. Convolving a sampled signal with the derivatives of sinc-function, the derivatives of the original continuous signal x(t) (or, more exactly, {circumflex over (x)}(t) since a finite sum is present and filtering might have been performed) may be obtained.
In calculation, the values of the function and its derivatives taken only at the integer points are required, so equation (3) can be rewritten as follows:
{circumflex over (x)}
(m)(n)=Σk=N/2N/2x(k)·sinc(m)(−K·(n−k)) (7)
As in choosing the window size in equations (3) or (7), the infinite series may be bound by a partial sum. Then, equation (5) can be written as follows:
In practice, when choosing M, account can be taken of the accuracy of the implemented calculations as well as the efficiency/quality ratio (which is often subjective). In this regard, in some example embodiments, M may be selected based at least in part on one or more of a desired threshold accuracy level or a harmonic complexity of the signal.
Since the derivative values are required only at integer points, and the phases of convolution kernels do not depend on the initial and final sampling rates, it may be unnecessary to calculate a large number of nearly identical kernels, differing only in phase. In accordance with some example embodiments, the convolution kernels may be the same at any increase in the frequency, and with lowering the frequency the convolution kernels may differ only due to the need of filtering. Such example embodiments can provide several benefits, including that the convolution kernels are few in number, do not change during resampling of the entire signal, and no subsequent decimation of the results of convolution optimized with FFT is required. In some instances, the M convolution kernels may be pre-calculated (according to the number of used coefficients of the series). In the course of operation, the convolutions may be computed using FFT, thus giving the derivatives directly in N integer points (e.g., the size of the FFT window), and then the values of samples may be calculated by series summation. Each individual sample requires only M multiplications and additions (hereinafter, operations).
In some aspects, a more accurate formula describing the total computational costs per sample obtained may be derived. The initial and final frequencies may be denoted as Fs and Fd, respectively. If the signal is processed as pieces, N samples each, then each such piece will result in N*Fd/Fs resampled samples. Calculation of one derivative for N initial samples may cost approximately N+N*log2(N) operations (point-wise multiplication, inverse FFT). Since M derivatives may be used, as well as calculation of the direct FFT from the source signal, computation of the same for N points may cost N*log2(N)+(N+N*log2(N))*M operations. Altogether, for only one point the following operations may be consumed:
In experiments with some example embodiment, M=9 appeared enough for the result to be better than that of the known sound editors (pure, in terms of spectrum reflection). In these experiments, the convolution window was taken as 8192. It will be appreciated, however, that other values of M and/or other convolution windows may be used in various example embodiments. For example, M may be selected in various implementations based at least in part on a desired threshold accuracy level, a harmonic complexity of the signal, and/or other factors. In using equation (3) directly, N operations per each sample will be required for the convolution only, in addition to the need to calculate sinc-functions. Optimization of the convolution due to the properties of FFT may not work in the general case, as the kernels may be unique for each sample.
Note that aspects of the method of some example embodiments allow both decreasing and increasing the sampling frequency. For such variation of the sampling frequency, consideration may be taken to account for correct assignment of the coefficient K that is responsible for low-pass filtering. Note that aspects of the method of some example embodiments allow both decreasing and increasing the sampling frequency. For such variation of the sampling frequency, consideration may be taken to account for correct assignment of the coefficient K that is responsible for low-pass filtering. K can, for example, be defined in accordance with equation (4). As can be seen from equation (4), K can differ when decreasing and increasing the sampling rate. If the sampling rate is increased, then there may not be any risk of aliasing, and the current frequency can be taken for the Nyquist frequency. If, however, the sampling rate is reduced, it may be necessary to remove the high frequencies that cannot be transferred at the new (lower) sampling rate. The ratio of Ts/Td describes how many times the Nyquist frequency will change. When reducing the sampling rate, filtering may be needed. Therefore, the sinc-function may be “stretched” over time by a factor of Ts/Td. Thus, the coefficient K may be used to regulate the frequency range to be resampled, adjusting the frequency range to the new Nyquist frequency.
When calculating K according to equation (4), the result may be the Kotelnikov (Nyquist) theorem, per se, with increasing sampling rate, whereas decreasing the sampling rate may cause low-pass filtering down to the new Nyquist frequency. If the lower value of K is selected, then the high frequencies that are possible to transfer with the new sampling rate may be removed from signal. In this regard, data loss may occur. If the higher value of K is selected, then spectrum reflection may occur. As an example, consider a signal with a sampling rate of 22,050 Hz. If the sampling rate is lowered to 12,000 Hz, elimination of frequencies above 6,000 Hz may be desired. If the coefficient K is assigned incorrectly and remains equal to π, spectrum reflection may occur.
If N=8192 and M=9 are substituted in equation (9) and Fd/Fs assumed to be close to unity, then 148 operations per sample are obtained. In some aspects, practical applications may allow less accuracy, and may be considered the least optimal option. In some cases it may be possible to reduce computations without calculating obvious null terms of series.
With decreasing the frequency by a multiple number of times
only the 0th term of the series will be nonzero, so in this case the operation can be quickened without calculating higher derivatives. Also, with greater decrease in the frequency (more than twofold), in terms of efficiency it appears reasonable to perform two-pass resampling. On the first pass, the frequency decreases by a maximum integer number of times until the frequency higher than the final frequency is achieved. In doing so, the calculation of derivatives is not required, and the whole operation runs almost M times faster than during complete decomposition. The second pass may be used to perform resampling with all its derivatives, but in that case, the initial data is already substantially reduced. For instance, in order to convert the frequency of 44100 to 8000, the amount of data should first be reduced five-fold by lowering the frequency from 44100 to 8820.
Once the Fourier transforms for the convolution kernels have been calculated, the derivatives of the signal itself can be computed, as shown in
To calculate each new sample, its time relative to the beginning of the block may be determined with the calculated derivatives in the initial periods. If the time is greater than the calculated block, the next 2*N derivatives may then be computed. If the current sample falls within the calculated block, the point in whose neighborhood lies the present sample may be found and calculated according to equation (8).
With reference to
In some example embodiments, the sampling frequency of a primary grid of the discrete samples may be varied, such as with an arbitrary, including irrational, ratio of frequencies. However, the same set of M convolution kernels initialized in operation 500 may be used for resampling of the entirety of the at least a portion of the continuous signal regardless of the variation of sampling frequency.
It will be understood that each block of the flowcharts in
In some example embodiments, the apparatus 600 may include processing circuitry 610 that is configurable to perform actions in accordance with one or more example embodiments disclosed herein. In this regard, the processing circuitry 610 may be configured to perform and/or control performance of one or more functionalities of apparatus 600 in accordance with various example embodiments. Thus, the processing circuitry 610 may be configured to perform data processing, application execution and/or other processing and management services according to one or more example embodiments. As such, the processing circuitry 610 may provide means for performing resampling and signal calculation methods in accordance with various example embodiments. For example, the processing circuitry 610 and/or one or more other components of the apparatus 600 may provide means for performing one or more of the operations illustrated in and described with respect to
In some embodiments, the apparatus 600 or a portion(s) or component(s) thereof, such as the processing circuitry 610, may include one or more chipsets, which may each include one or more chips. The processing circuitry 610 and/or one or more further components of the apparatus 600 may therefore, in some instances, be configured to implement an embodiment on a chipset. For example, the apparatus 600, or portion thereof, may be implemented on a sound card, analog-to-digital audio converter, audio processor, or the like.
In some example embodiments, the processing circuitry 610 may include a processor 612 and, in some embodiments, such as that illustrated in
The processor 612 may be embodied in a variety of forms. For example, the processor 612 may be embodied as various processing means such as a microprocessor, a coprocessor, a controller or various other computing or processing devices including integrated circuits such as, for example, an ASIC (application specific integrated circuit), an FPGA (field programmable gate array), some combination thereof, or the like. Although illustrated as a single processor, it will be appreciated that the processor 612 may comprise a plurality of processors. The plurality of processors may be in operative communication with each other and may be collectively configured to perform one or more functionalities of the apparatus 600. In embodiments including a plurality of processors, the processors may be implemented on a single computing device, or may be distributed across a plurality of computing devices that may be collectively configured to provide functionality of the apparatus 600 in accordance with some example embodiments. In some example embodiments, the processor 612 may be configured to execute instructions that may be stored in the memory 614 or that may be otherwise accessible to the processor 612. As such, whether configured by hardware or by a combination of hardware and software, the processor 612 capable of performing operations according to various embodiments while configured accordingly.
In some example embodiments, the memory 614 may include one or more memory devices. In embodiments including multiple memory devices, the memory devices may be implemented on a single computing device, or may be distributed across a plurality of computing devices that may be collectively configured to provide functionality of the apparatus 600 in accordance with some example embodiments. Memory 614 may include fixed and/or removable memory devices. In some embodiments, the memory 614 may provide a non-transitory computer-readable storage medium that may store computer program instructions that may be executed by the processor 612. In this regard, the memory 614 may be configured to store information, data, applications, instructions and/or the like for enabling the apparatus 600 to carry out various functions in accordance with one or more example embodiments. In some embodiments, the memory 614 may be in communication with one or more of the processor 612, communication interface 616, or signal processing module 618 via a bus(es) for passing information among components of the apparatus 600.
The apparatus 600 may further include a communication interface 616. The communication interface 616 may enable the apparatus 600 to receive a signal that may be sent by another computing device, such as over a network. In this regard, the communication interface 616 may include one or more interface mechanisms for enabling communication with other devices and/or networks. As such, the communication interface 616 may include, for example, an antenna (or multiple antennas) and supporting hardware and/or software for enabling communications with a wireless communication network (e.g., a cellular network, WLAN, and/or the like) and/or a communication modem or other hardware/software for supporting communication via cable, digital subscriber line (DSL), USB, FireWire, Ethernet or other wireline networking methods.
The apparatus 600 may further include signal processing module 618. The signal processing module 618 may be embodied as various means, such as circuitry, hardware, a computer program product comprising computer readable program instructions stored on a computer readable medium (for example, the memory 614) and executed by a processing device (for example, the processor 612), or some combination thereof. In some embodiments, the processor 612 (or the processing circuitry 610) may include, or otherwise control the signal processing module 618. The signal processing module 618 may be configured to use a function series expansion to calculate at least a portion of a continuous signal in accordance with various embodiments. Thus, for example, the signal processing module 618 may be configured to perform one or more operations illustrated in and described with respect to
The signal source apparatus 704 may comprise a server or other computing device that may be configured to send a signal to the receiving apparatus 702 over the network 706. For example, the signal source apparatus 704 may stream digital audio to the receiving apparatus 702. The receiving apparatus 702 may comprise any computing device configured to receive a signal sent by the signal source apparatus 704. By way of non-limiting example, the receiving apparatus 702 may be embodied as a desktop computer, laptop computer, or a mobile computing device, such as a smart phone, tablet computing device, or other wireless mobile computing device.
In some example embodiments, the apparatus 600 may be implemented on the receiving apparatus 702. As such, the receiving apparatus 702 may be configured to perform resampling and signal determination operations for a signal received from the signal source apparatus 704 in accordance with various example embodiments. In embodiments in which the receiving apparatus 702 is implemented as a mobile computing device or other computing device that may be power constrained and/or processing power constrained, such as due to size limitations, a finite battery life, and/or other factors, the receiving apparatus 702 may benefit from the technical effect of the computational efficiency provided by various example embodiments. In this regard, the reduced computational complexity provided by some example embodiments may reduce power consumption by such a device. Further, the reduced computational complexity provided by some example embodiments may enable faster, more accurate signal resampling to be performed on mobile devices having relatively limited processing power.
Many modifications and other embodiments of the inventions set forth herein will come to mind to one skilled in the art to which these inventions pertain having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the embodiments of the invention are not to be limited to the specific embodiments disclosed and that modifications and other embodiments are intended to be included within the scope of the invention. Moreover, although the foregoing descriptions and the associated drawings describe example embodiments in the context of certain example combinations of elements and/or functions, it should be appreciated that different combinations of elements and/or functions may be provided by alternative embodiments without departing from the scope of the invention. In this regard, for example, different combinations of elements and/or functions than those explicitly described above are also contemplated within the scope of the invention. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
This application is a continuation of U.S. application Ser. No. 14/255,177, filed Apr. 17, 2014, which is a continuation of International Application No. PCT/CA2012/050744, filed Oct. 18, 2012, which International Application was published by the International Bureau in English on Apr. 25, 2013, and claims priority to U.S. Provisional Application No. 61/548,396, filed Oct. 18, 2011, all of which are incorporated herein by reference in their respective entireties and for all purposes.
Number | Date | Country | |
---|---|---|---|
61548396 | Oct 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14255177 | Apr 2014 | US |
Child | 15824067 | US | |
Parent | PCT/CA2012/050744 | Oct 2012 | US |
Child | 14255177 | US |