Sinc interpolation in spatial domainInterpolation vs Interpolation Filter?sinc interpolation using fftSinc...

Church Booleans

Is it safe to remove the bottom chords of a series of garage roof trusses?

Why does my house heat up, even when it's cool outside?

Is it insecure to have an ansible user with passwordless sudo?

How does turbine efficiency compare with internal combustion engines if all the turbine power is converted to mechanical energy?

Is a butterfly one or two animals?

Why we don't have vaccination against all diseases which are caused by microbes?

Why doesn't mathematics collapse even though humans quite often make mistakes in their proofs?

How to organize ideas to start writing a novel?

Can pay be witheld for hours cleaning up after closing time?

Why is 日本 read as "nihon" but not "nitsuhon"?

The sound of thunder's like a whip

In an emergency, how do I find and share my position?

How to specify and fit a hybrid machine learning - linear model

The logic of invoking virtual functions is not clear (or it is method hiding?)

Is "stainless" a bulk or a surface property of stainless steel?

Efficiently pathfinding many flocking enemies around obstacles

Why were movies shot on film shot at 24 frames per second?

Can you grapple/shove with the Hunter Ranger's Whirlwind Attack?

Was Tuvok bluffing when he said that Voyager's transporters rendered the Kazon weapons useless?

Is it appropriate for a prospective landlord to ask me for my credit report?

Can my boyfriend, who lives in the UK and has a Polish passport, visit me in the USA?

Overwrite file only if data

How to avoid using System.String with Rfc2898DeriveBytes in C#



Sinc interpolation in spatial domain


Interpolation vs Interpolation Filter?sinc interpolation using fftSinc interpolation looks weirdInterpolation based on sinc functiondifficulties implementing windowed sinc interpolation (C++)Absolute convergence of periodic sinc interpolationSinc interpolation of pure sine wave sampled just at Nyquist frequencyFrequency Domain Interpolation: Convolution with Sinc Function






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ margin-bottom:0;
}







2












$begingroup$


I have tried to perform sinc interpolation (in 1D) with the following Matlab code:



Fs=8;
T=1/Fs;
t=0:T:(1-T);
f=1;
x=sin(2*pi*f*t);

up_factor=2;

%% Deduce sinc from Fourier domain

xp=[zeros(1,5) x zeros(1,5)];

Xp=fft(xp);

door1D=abs(xp>0);
sinc1D=fftshift(abs(fft(door1D)));

%plot(door1D);hold on;plot(fftshift(abs(sinc1D)))



%% Interp with sinc in spatial domain
x_up=upsample(x,2);
%plot(x,'b*');hold on;plot(x_up,'r*');
x_up_interp=conv2(x_up,sinc1D,'same');

figure;
plot(x_up_interp./up_factor);
hold on;
plot(x);
hold on;
plot(x_up,'r+');


It seems to work (except for ripples due to the Gibbs phenomenon I guess?). However, I worked this out in a "deductive" manner and I dont completely understand the parameters (period/frequency) of the sinc. The approach was to extract the sinc from the fft of the door function. Then use that sinc as if I had computed it beforehand and convolve the upsampled (not yet interpolated) 1D signal with it.



Can someone help me understand it better? How would I built this sinc ? e.g. from the sinc() function of Matlab. And for it to work, I have convolved with abs of sinc cf. conv2(x_up,sinc1D,'same'); , but this seems strange... can someone explain/develop/correct this ?



REM.:also it is probably badly scaled, but that is another detail










share|improve this question









$endgroup$














  • $begingroup$
    please help! :)
    $endgroup$
    – Machupicchu
    2 days ago


















2












$begingroup$


I have tried to perform sinc interpolation (in 1D) with the following Matlab code:



Fs=8;
T=1/Fs;
t=0:T:(1-T);
f=1;
x=sin(2*pi*f*t);

up_factor=2;

%% Deduce sinc from Fourier domain

xp=[zeros(1,5) x zeros(1,5)];

Xp=fft(xp);

door1D=abs(xp>0);
sinc1D=fftshift(abs(fft(door1D)));

%plot(door1D);hold on;plot(fftshift(abs(sinc1D)))



%% Interp with sinc in spatial domain
x_up=upsample(x,2);
%plot(x,'b*');hold on;plot(x_up,'r*');
x_up_interp=conv2(x_up,sinc1D,'same');

figure;
plot(x_up_interp./up_factor);
hold on;
plot(x);
hold on;
plot(x_up,'r+');


It seems to work (except for ripples due to the Gibbs phenomenon I guess?). However, I worked this out in a "deductive" manner and I dont completely understand the parameters (period/frequency) of the sinc. The approach was to extract the sinc from the fft of the door function. Then use that sinc as if I had computed it beforehand and convolve the upsampled (not yet interpolated) 1D signal with it.



Can someone help me understand it better? How would I built this sinc ? e.g. from the sinc() function of Matlab. And for it to work, I have convolved with abs of sinc cf. conv2(x_up,sinc1D,'same'); , but this seems strange... can someone explain/develop/correct this ?



REM.:also it is probably badly scaled, but that is another detail










share|improve this question









$endgroup$














  • $begingroup$
    please help! :)
    $endgroup$
    – Machupicchu
    2 days ago














2












2








2





$begingroup$


I have tried to perform sinc interpolation (in 1D) with the following Matlab code:



Fs=8;
T=1/Fs;
t=0:T:(1-T);
f=1;
x=sin(2*pi*f*t);

up_factor=2;

%% Deduce sinc from Fourier domain

xp=[zeros(1,5) x zeros(1,5)];

Xp=fft(xp);

door1D=abs(xp>0);
sinc1D=fftshift(abs(fft(door1D)));

%plot(door1D);hold on;plot(fftshift(abs(sinc1D)))



%% Interp with sinc in spatial domain
x_up=upsample(x,2);
%plot(x,'b*');hold on;plot(x_up,'r*');
x_up_interp=conv2(x_up,sinc1D,'same');

figure;
plot(x_up_interp./up_factor);
hold on;
plot(x);
hold on;
plot(x_up,'r+');


It seems to work (except for ripples due to the Gibbs phenomenon I guess?). However, I worked this out in a "deductive" manner and I dont completely understand the parameters (period/frequency) of the sinc. The approach was to extract the sinc from the fft of the door function. Then use that sinc as if I had computed it beforehand and convolve the upsampled (not yet interpolated) 1D signal with it.



Can someone help me understand it better? How would I built this sinc ? e.g. from the sinc() function of Matlab. And for it to work, I have convolved with abs of sinc cf. conv2(x_up,sinc1D,'same'); , but this seems strange... can someone explain/develop/correct this ?



REM.:also it is probably badly scaled, but that is another detail










share|improve this question









$endgroup$




I have tried to perform sinc interpolation (in 1D) with the following Matlab code:



Fs=8;
T=1/Fs;
t=0:T:(1-T);
f=1;
x=sin(2*pi*f*t);

up_factor=2;

%% Deduce sinc from Fourier domain

xp=[zeros(1,5) x zeros(1,5)];

Xp=fft(xp);

door1D=abs(xp>0);
sinc1D=fftshift(abs(fft(door1D)));

%plot(door1D);hold on;plot(fftshift(abs(sinc1D)))



%% Interp with sinc in spatial domain
x_up=upsample(x,2);
%plot(x,'b*');hold on;plot(x_up,'r*');
x_up_interp=conv2(x_up,sinc1D,'same');

figure;
plot(x_up_interp./up_factor);
hold on;
plot(x);
hold on;
plot(x_up,'r+');


It seems to work (except for ripples due to the Gibbs phenomenon I guess?). However, I worked this out in a "deductive" manner and I dont completely understand the parameters (period/frequency) of the sinc. The approach was to extract the sinc from the fft of the door function. Then use that sinc as if I had computed it beforehand and convolve the upsampled (not yet interpolated) 1D signal with it.



Can someone help me understand it better? How would I built this sinc ? e.g. from the sinc() function of Matlab. And for it to work, I have convolved with abs of sinc cf. conv2(x_up,sinc1D,'same'); , but this seems strange... can someone explain/develop/correct this ?



REM.:also it is probably badly scaled, but that is another detail







fourier-transform interpolation






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked 2 days ago









MachupicchuMachupicchu

1191 silver badge11 bronze badges




1191 silver badge11 bronze badges















  • $begingroup$
    please help! :)
    $endgroup$
    – Machupicchu
    2 days ago


















  • $begingroup$
    please help! :)
    $endgroup$
    – Machupicchu
    2 days ago
















$begingroup$
please help! :)
$endgroup$
– Machupicchu
2 days ago




$begingroup$
please help! :)
$endgroup$
– Machupicchu
2 days ago










2 Answers
2






active

oldest

votes


















2












$begingroup$

The sinc function actually represents an ideal (brickwall) lowpass filter that's used to complete the interpolation process after the data has been expanded (zero stuffed) properly. So let me outline the time domain approach here:



Assume you have data samples $x[n]$ of length $N$, and you want to upsample this by the integer factor of $L$, yielding a new interpolated data $y[n]$ of length $M = L times N $ samples.



The first stage is to zero stuff the input $x[n]$; i.e., expand it by $L$ by the expander block :



$$ x[n] longrightarrow boxed{ uparrow L } longrightarrow x_e[n] $$



where $x_e[n]$ is related to $x[n]$ by the following:



$$ x_e[n] = begin{cases} { x[n] ~~~,~~~ n = 0, pm L, pm 2L... \ ~~~ 0 ~~ ~~~,~~~text{otherwise} } end{cases} $$



Then, to complete the interpolation process and fill in the empty (zeroed) samples of $x_e[n]$, one has to lowpass filter $x_e[n]$ by an ideal lowpass filter $h[n]$ with the following frequency domain definition $H(omega)$ :



$$ H(omega) = begin{cases} { ~ L ~ ~~~,~~~ |omega| < frac{pi}{L} \ ~ 0 ~ ~~~,~~~text{otherwise} } end{cases} $$



The impulse response $h[n]$ of this ideal filter is computed by the inverse discrete-time Fourier transform of $H(omega)$ and is given by



$$ h[n] = L frac{ sin( frac{pi}{L} n) } {pi n} $$



This is an infitely long and non-causal filter, and thus cannot be implemented in this form. (See Hilmar's comments) Practically it's truncated and weighted by a window function, for example by a Hamming or Kaiser window.



The following MATLAB / OCTAVE code represents designing the filter and applying it into data in time domain:



L = 5;      % interpolation factor
N = 500; % data length

x = hamming(N)'.*randn(1,N); % generate bandlimited data...

% expanded signal
xe = zeros(1,N*L);
xe(1:L:end) = x; % generate th expanded signal

% interpolation sinc filter
n = -32:32; % timing index
h = L*sin(pi*n/L)./(pi*n); % ideal lowpass filter
h(33) = L; % fill in the zero divison sample
h = hamming(65)'.*h; % apply weighting window on h[n]

% interpolate:
y = filter(h,1,xe); % y[n] is the interpolated signal





share|improve this answer









$endgroup$















  • $begingroup$
    great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    also, why did you choose -32:32 for sinc? Is is arbitrary?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
    $endgroup$
    – Fat32
    2 days ago



















1












$begingroup$

Sinc() interpolation looks nice on paper or in text books but in practice it's rarely a good solution. The main problem is that the sinc() impulse response is infinitely long and it's not causal. Not only does it have infinite length, but it also decays only very slowly with time, so you typically need a large number of samples to get a decent accuracy.



This, in turn, results in long latency, high computational cost and fairly large "transition" areas at the beginning and end of the output.






share|improve this answer









$endgroup$















  • $begingroup$
    i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
    $endgroup$
    – robert bristow-johnson
    2 days ago










  • $begingroup$
    so the choice by @Fat32 range of -32 to 32 is arbitrary ?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
    $endgroup$
    – robert bristow-johnson
    2 days ago














Your Answer








StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "295"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
noCode: true, onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdsp.stackexchange.com%2fquestions%2f60179%2fsinc-interpolation-in-spatial-domain%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























2 Answers
2






active

oldest

votes








2 Answers
2






active

oldest

votes









active

oldest

votes






active

oldest

votes









2












$begingroup$

The sinc function actually represents an ideal (brickwall) lowpass filter that's used to complete the interpolation process after the data has been expanded (zero stuffed) properly. So let me outline the time domain approach here:



Assume you have data samples $x[n]$ of length $N$, and you want to upsample this by the integer factor of $L$, yielding a new interpolated data $y[n]$ of length $M = L times N $ samples.



The first stage is to zero stuff the input $x[n]$; i.e., expand it by $L$ by the expander block :



$$ x[n] longrightarrow boxed{ uparrow L } longrightarrow x_e[n] $$



where $x_e[n]$ is related to $x[n]$ by the following:



$$ x_e[n] = begin{cases} { x[n] ~~~,~~~ n = 0, pm L, pm 2L... \ ~~~ 0 ~~ ~~~,~~~text{otherwise} } end{cases} $$



Then, to complete the interpolation process and fill in the empty (zeroed) samples of $x_e[n]$, one has to lowpass filter $x_e[n]$ by an ideal lowpass filter $h[n]$ with the following frequency domain definition $H(omega)$ :



$$ H(omega) = begin{cases} { ~ L ~ ~~~,~~~ |omega| < frac{pi}{L} \ ~ 0 ~ ~~~,~~~text{otherwise} } end{cases} $$



The impulse response $h[n]$ of this ideal filter is computed by the inverse discrete-time Fourier transform of $H(omega)$ and is given by



$$ h[n] = L frac{ sin( frac{pi}{L} n) } {pi n} $$



This is an infitely long and non-causal filter, and thus cannot be implemented in this form. (See Hilmar's comments) Practically it's truncated and weighted by a window function, for example by a Hamming or Kaiser window.



The following MATLAB / OCTAVE code represents designing the filter and applying it into data in time domain:



L = 5;      % interpolation factor
N = 500; % data length

x = hamming(N)'.*randn(1,N); % generate bandlimited data...

% expanded signal
xe = zeros(1,N*L);
xe(1:L:end) = x; % generate th expanded signal

% interpolation sinc filter
n = -32:32; % timing index
h = L*sin(pi*n/L)./(pi*n); % ideal lowpass filter
h(33) = L; % fill in the zero divison sample
h = hamming(65)'.*h; % apply weighting window on h[n]

% interpolate:
y = filter(h,1,xe); % y[n] is the interpolated signal





share|improve this answer









$endgroup$















  • $begingroup$
    great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    also, why did you choose -32:32 for sinc? Is is arbitrary?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
    $endgroup$
    – Fat32
    2 days ago
















2












$begingroup$

The sinc function actually represents an ideal (brickwall) lowpass filter that's used to complete the interpolation process after the data has been expanded (zero stuffed) properly. So let me outline the time domain approach here:



Assume you have data samples $x[n]$ of length $N$, and you want to upsample this by the integer factor of $L$, yielding a new interpolated data $y[n]$ of length $M = L times N $ samples.



The first stage is to zero stuff the input $x[n]$; i.e., expand it by $L$ by the expander block :



$$ x[n] longrightarrow boxed{ uparrow L } longrightarrow x_e[n] $$



where $x_e[n]$ is related to $x[n]$ by the following:



$$ x_e[n] = begin{cases} { x[n] ~~~,~~~ n = 0, pm L, pm 2L... \ ~~~ 0 ~~ ~~~,~~~text{otherwise} } end{cases} $$



Then, to complete the interpolation process and fill in the empty (zeroed) samples of $x_e[n]$, one has to lowpass filter $x_e[n]$ by an ideal lowpass filter $h[n]$ with the following frequency domain definition $H(omega)$ :



$$ H(omega) = begin{cases} { ~ L ~ ~~~,~~~ |omega| < frac{pi}{L} \ ~ 0 ~ ~~~,~~~text{otherwise} } end{cases} $$



The impulse response $h[n]$ of this ideal filter is computed by the inverse discrete-time Fourier transform of $H(omega)$ and is given by



$$ h[n] = L frac{ sin( frac{pi}{L} n) } {pi n} $$



This is an infitely long and non-causal filter, and thus cannot be implemented in this form. (See Hilmar's comments) Practically it's truncated and weighted by a window function, for example by a Hamming or Kaiser window.



The following MATLAB / OCTAVE code represents designing the filter and applying it into data in time domain:



L = 5;      % interpolation factor
N = 500; % data length

x = hamming(N)'.*randn(1,N); % generate bandlimited data...

% expanded signal
xe = zeros(1,N*L);
xe(1:L:end) = x; % generate th expanded signal

% interpolation sinc filter
n = -32:32; % timing index
h = L*sin(pi*n/L)./(pi*n); % ideal lowpass filter
h(33) = L; % fill in the zero divison sample
h = hamming(65)'.*h; % apply weighting window on h[n]

% interpolate:
y = filter(h,1,xe); % y[n] is the interpolated signal





share|improve this answer









$endgroup$















  • $begingroup$
    great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    also, why did you choose -32:32 for sinc? Is is arbitrary?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
    $endgroup$
    – Fat32
    2 days ago














2












2








2





$begingroup$

The sinc function actually represents an ideal (brickwall) lowpass filter that's used to complete the interpolation process after the data has been expanded (zero stuffed) properly. So let me outline the time domain approach here:



Assume you have data samples $x[n]$ of length $N$, and you want to upsample this by the integer factor of $L$, yielding a new interpolated data $y[n]$ of length $M = L times N $ samples.



The first stage is to zero stuff the input $x[n]$; i.e., expand it by $L$ by the expander block :



$$ x[n] longrightarrow boxed{ uparrow L } longrightarrow x_e[n] $$



where $x_e[n]$ is related to $x[n]$ by the following:



$$ x_e[n] = begin{cases} { x[n] ~~~,~~~ n = 0, pm L, pm 2L... \ ~~~ 0 ~~ ~~~,~~~text{otherwise} } end{cases} $$



Then, to complete the interpolation process and fill in the empty (zeroed) samples of $x_e[n]$, one has to lowpass filter $x_e[n]$ by an ideal lowpass filter $h[n]$ with the following frequency domain definition $H(omega)$ :



$$ H(omega) = begin{cases} { ~ L ~ ~~~,~~~ |omega| < frac{pi}{L} \ ~ 0 ~ ~~~,~~~text{otherwise} } end{cases} $$



The impulse response $h[n]$ of this ideal filter is computed by the inverse discrete-time Fourier transform of $H(omega)$ and is given by



$$ h[n] = L frac{ sin( frac{pi}{L} n) } {pi n} $$



This is an infitely long and non-causal filter, and thus cannot be implemented in this form. (See Hilmar's comments) Practically it's truncated and weighted by a window function, for example by a Hamming or Kaiser window.



The following MATLAB / OCTAVE code represents designing the filter and applying it into data in time domain:



L = 5;      % interpolation factor
N = 500; % data length

x = hamming(N)'.*randn(1,N); % generate bandlimited data...

% expanded signal
xe = zeros(1,N*L);
xe(1:L:end) = x; % generate th expanded signal

% interpolation sinc filter
n = -32:32; % timing index
h = L*sin(pi*n/L)./(pi*n); % ideal lowpass filter
h(33) = L; % fill in the zero divison sample
h = hamming(65)'.*h; % apply weighting window on h[n]

% interpolate:
y = filter(h,1,xe); % y[n] is the interpolated signal





share|improve this answer









$endgroup$



The sinc function actually represents an ideal (brickwall) lowpass filter that's used to complete the interpolation process after the data has been expanded (zero stuffed) properly. So let me outline the time domain approach here:



Assume you have data samples $x[n]$ of length $N$, and you want to upsample this by the integer factor of $L$, yielding a new interpolated data $y[n]$ of length $M = L times N $ samples.



The first stage is to zero stuff the input $x[n]$; i.e., expand it by $L$ by the expander block :



$$ x[n] longrightarrow boxed{ uparrow L } longrightarrow x_e[n] $$



where $x_e[n]$ is related to $x[n]$ by the following:



$$ x_e[n] = begin{cases} { x[n] ~~~,~~~ n = 0, pm L, pm 2L... \ ~~~ 0 ~~ ~~~,~~~text{otherwise} } end{cases} $$



Then, to complete the interpolation process and fill in the empty (zeroed) samples of $x_e[n]$, one has to lowpass filter $x_e[n]$ by an ideal lowpass filter $h[n]$ with the following frequency domain definition $H(omega)$ :



$$ H(omega) = begin{cases} { ~ L ~ ~~~,~~~ |omega| < frac{pi}{L} \ ~ 0 ~ ~~~,~~~text{otherwise} } end{cases} $$



The impulse response $h[n]$ of this ideal filter is computed by the inverse discrete-time Fourier transform of $H(omega)$ and is given by



$$ h[n] = L frac{ sin( frac{pi}{L} n) } {pi n} $$



This is an infitely long and non-causal filter, and thus cannot be implemented in this form. (See Hilmar's comments) Practically it's truncated and weighted by a window function, for example by a Hamming or Kaiser window.



The following MATLAB / OCTAVE code represents designing the filter and applying it into data in time domain:



L = 5;      % interpolation factor
N = 500; % data length

x = hamming(N)'.*randn(1,N); % generate bandlimited data...

% expanded signal
xe = zeros(1,N*L);
xe(1:L:end) = x; % generate th expanded signal

% interpolation sinc filter
n = -32:32; % timing index
h = L*sin(pi*n/L)./(pi*n); % ideal lowpass filter
h(33) = L; % fill in the zero divison sample
h = hamming(65)'.*h; % apply weighting window on h[n]

% interpolate:
y = filter(h,1,xe); % y[n] is the interpolated signal






share|improve this answer












share|improve this answer



share|improve this answer










answered 2 days ago









Fat32Fat32

17.7k3 gold badges14 silver badges34 bronze badges




17.7k3 gold badges14 silver badges34 bronze badges















  • $begingroup$
    great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    also, why did you choose -32:32 for sinc? Is is arbitrary?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
    $endgroup$
    – Fat32
    2 days ago


















  • $begingroup$
    great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
    $endgroup$
    – Machupicchu
    2 days ago












  • $begingroup$
    also, why did you choose -32:32 for sinc? Is is arbitrary?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
    $endgroup$
    – Fat32
    2 days ago
















$begingroup$
great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
$endgroup$
– Machupicchu
2 days ago






$begingroup$
great answer, thanks. This is exactly what I was looking for, and I think it will be useful to many.
$endgroup$
– Machupicchu
2 days ago














$begingroup$
So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
$endgroup$
– Machupicchu
2 days ago






$begingroup$
So the lowpass filter is needed because the "useful" spectrum of xis shrinked when comparing x and xe (from an img proc lecture), and aliases apprear around it. (not sure I express myself correctly?). What is exactly this shinking factor ?
$endgroup$
– Machupicchu
2 days ago














$begingroup$
also, why did you choose -32:32 for sinc? Is is arbitrary?
$endgroup$
– Machupicchu
2 days ago




$begingroup$
also, why did you choose -32:32 for sinc? Is is arbitrary?
$endgroup$
– Machupicchu
2 days ago












$begingroup$
last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
$endgroup$
– Machupicchu
2 days ago




$begingroup$
last question, also would it be possible for you to say intuitively why the sinc interpolation is the ideal one? ( I remember as you just mentioned that the ideal lowpass filter is a brickwall to cut all freq outside it, in Fourier domain, and therefore a convolution with sinc in time/spatial domain, but "intuitively" compared to nearest neighbor interp for example why is is so much better?
$endgroup$
– Machupicchu
2 days ago












$begingroup$
yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
$endgroup$
– Fat32
2 days ago




$begingroup$
yes, yes&no and yes. 1- As a technical terminology, the spectrum of $x_e[n]$ contains images rather than aliases and the lowpass filter removes all the images outside the frequency band $|omega| < pi/L$; the shrinking factor is $L$. 2-Length of the filter is arbitrary but not so, to get a better approximation it must be long enough. 3- Sinc() interpolator is the ideal one because it corresponds to the impulse response of the perfect interpolation filter and derived based on inverse Fourier transform it. Nearest neighbor is not a perfect interpolator by definition.
$endgroup$
– Fat32
2 days ago













1












$begingroup$

Sinc() interpolation looks nice on paper or in text books but in practice it's rarely a good solution. The main problem is that the sinc() impulse response is infinitely long and it's not causal. Not only does it have infinite length, but it also decays only very slowly with time, so you typically need a large number of samples to get a decent accuracy.



This, in turn, results in long latency, high computational cost and fairly large "transition" areas at the beginning and end of the output.






share|improve this answer









$endgroup$















  • $begingroup$
    i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
    $endgroup$
    – robert bristow-johnson
    2 days ago










  • $begingroup$
    so the choice by @Fat32 range of -32 to 32 is arbitrary ?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
    $endgroup$
    – robert bristow-johnson
    2 days ago
















1












$begingroup$

Sinc() interpolation looks nice on paper or in text books but in practice it's rarely a good solution. The main problem is that the sinc() impulse response is infinitely long and it's not causal. Not only does it have infinite length, but it also decays only very slowly with time, so you typically need a large number of samples to get a decent accuracy.



This, in turn, results in long latency, high computational cost and fairly large "transition" areas at the beginning and end of the output.






share|improve this answer









$endgroup$















  • $begingroup$
    i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
    $endgroup$
    – robert bristow-johnson
    2 days ago










  • $begingroup$
    so the choice by @Fat32 range of -32 to 32 is arbitrary ?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
    $endgroup$
    – robert bristow-johnson
    2 days ago














1












1








1





$begingroup$

Sinc() interpolation looks nice on paper or in text books but in practice it's rarely a good solution. The main problem is that the sinc() impulse response is infinitely long and it's not causal. Not only does it have infinite length, but it also decays only very slowly with time, so you typically need a large number of samples to get a decent accuracy.



This, in turn, results in long latency, high computational cost and fairly large "transition" areas at the beginning and end of the output.






share|improve this answer









$endgroup$



Sinc() interpolation looks nice on paper or in text books but in practice it's rarely a good solution. The main problem is that the sinc() impulse response is infinitely long and it's not causal. Not only does it have infinite length, but it also decays only very slowly with time, so you typically need a large number of samples to get a decent accuracy.



This, in turn, results in long latency, high computational cost and fairly large "transition" areas at the beginning and end of the output.







share|improve this answer












share|improve this answer



share|improve this answer










answered 2 days ago









HilmarHilmar

11.8k1 gold badge12 silver badges18 bronze badges




11.8k1 gold badge12 silver badges18 bronze badges















  • $begingroup$
    i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
    $endgroup$
    – robert bristow-johnson
    2 days ago










  • $begingroup$
    so the choice by @Fat32 range of -32 to 32 is arbitrary ?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
    $endgroup$
    – robert bristow-johnson
    2 days ago


















  • $begingroup$
    i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
    $endgroup$
    – robert bristow-johnson
    2 days ago










  • $begingroup$
    so the choice by @Fat32 range of -32 to 32 is arbitrary ?
    $endgroup$
    – Machupicchu
    2 days ago










  • $begingroup$
    not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
    $endgroup$
    – robert bristow-johnson
    2 days ago
















$begingroup$
i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
$endgroup$
– robert bristow-johnson
2 days ago




$begingroup$
i think, in practice, a Kaiser-windowed sinc() interpolation can be very good. nearly always, not rarely. nearly as good as Parks-McClellan (firpm()) or Least Squares (firls()) and sometimes better, if you compare apples to apples. also sometimes firpm() chokes for kernels bigger than 2048 and firls() chokes for kernels bigger than 4096. but the kernal size is the product of the number of phases (sometimes i like that as high as 512) and the number of FIR taps (like 32 or 64). but you can make it as big as you want with kaiser() and sinc().
$endgroup$
– robert bristow-johnson
2 days ago












$begingroup$
so the choice by @Fat32 range of -32 to 32 is arbitrary ?
$endgroup$
– Machupicchu
2 days ago




$begingroup$
so the choice by @Fat32 range of -32 to 32 is arbitrary ?
$endgroup$
– Machupicchu
2 days ago












$begingroup$
not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
$endgroup$
– robert bristow-johnson
2 days ago




$begingroup$
not arbitrary, it's just that we know from FIR filter design that we will need about 32 taps (which means you're looking at 16 samples on the left and 16 samples on the right) to do a decent job of high-quality interpolation of audio. but to do a really good job of it, you might need 64 taps. the number of FIR taps times the number of phases in the polyphase FIR filter is the total length of the the FIR that you would need to design using tools like firpm() or firls() in MATLAB.
$endgroup$
– robert bristow-johnson
2 days ago


















draft saved

draft discarded




















































Thanks for contributing an answer to Signal Processing Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


Use MathJax to format equations. MathJax reference.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdsp.stackexchange.com%2fquestions%2f60179%2fsinc-interpolation-in-spatial-domain%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Taj Mahal Inhaltsverzeichnis Aufbau | Geschichte | 350-Jahr-Feier | Heutige Bedeutung | Siehe auch |...

Baia Sprie Cuprins Etimologie | Istorie | Demografie | Politică și administrație | Arii naturale...

Ciclooctatetraenă Vezi și | Bibliografie | Meniu de navigare637866text4148569-500570979m