Interpolating/crossfading a stack of matrices

raphael at mameghani.de raphael at mameghani.de
Fri Jan 11 13:20:10 CET 2013


>> Hi,
>>
>> I want to interpolate (with quadratic splines) a stack of 2D-arrays/matrices
>> y1, y2, y3, ... in a third dimension (which I call x) e.g. for crossfading 
>> images. I already have a working code which unfortunately still contains two 
>> explicit loops over the rows and colums of the matrices. Inside these loops I 
>> simply use 'interp1d' from scipy suitable for 1D-interpolations. Is anybody 
>> here aware of a better, more efficient solution of my problem? Maybe 
>> somewhere out there a compiled routine for my problem already exists in a 
>> python library... :-) 

> Since numpy arrays make it so easy to form linear combinations of
> arrays without loops I would probably eliminate the loops and just 
> form the appropriate combinations of the image arrays. For example, to 
> use linear interpolation you could do:
> 
> 
> 
> def interp_frames_linear(times, frames, t):
> 
>     '''times is a vector of floats
> 
>     frames is a 3D array whose nth page is the image for time t[n]
> 
>     t is the time to interpolate for
> 
>     '''
> 
>     # Find the two frames to interpolate between
> 
>     # Probably a better way of doing this
> 
>     for n in range(len(t)-1):
> 
>         if times[n] <= t < times[n+1]:
> 
>             break
> 
>     else:
> 
>         raise OutOfBoundsError
> 
> 
> 
>     # Interpolate between the two images
> 
>     alpha = (t - times[n]) / (times[n+1] - times[n])
> 
>     return (1 - alpha) * frames[:, :, n] + alpha * frames[:, :, n+1]
> 
> 
> 
> I'm not really sure how quadratic interpolation is supposed to work
> (I've only ever used linear and cubic) but you should be able to do
> the same sort of thing.
> 
> Oscar

Indeed, the 'manual' reimplementation of the interpolation formula using numpy arrays significantly sped up the code. The numexpr package made it even faster. Thanks a lot for your advice!

Raphael



More information about the Python-list mailing list