How to speed up a 2D interpolation in MATLAB?
19 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Jack Smith
el 25 de En. de 2023
Comentada: Jack Smith
el 30 de En. de 2023
I am reading a table from excel which I am using as the basis for a 2D interpolation, I've included an image of the table with the x, y and output variables shown with the sensitive data omitted for reference.
I have sensor data for position and velocity, with the variable names Raw_Position and Raw_Velocity respetively, that are used to interpolate the Output0 value at a given positon and velocity. The sensor data is in the format of n rows and m columns.
Currently I am achieving this using two interp1 functions inside nested for loops that repeat the calculation for every row and column of the sensor data but this is very slow and my script is taking several minutes to run for a large data set. Is there a way to speed up this process with the interp2 function or something similar?
0 comentarios
Respuesta aceptada
Paul
el 25 de En. de 2023
Position0 = 1:4;
Velocity0 = 1:5;
Output0 = Position0.' + Velocity0;
RawPosition =[1 2;3 4;1 2]; RawVelocity = [2 3;4 5;1 2];
Output = interp2(Velocity0,Position0,Output0,RawVelocity,RawPosition)
% check
RawPosition + RawVelocity
3 comentarios
Paul
el 25 de En. de 2023
Hi Jack,
As I showed, the RawPosition and RawVelocity inputs to interp2 can be arrays. In my example they were both 3 x 2, as was the output.
Also, according to our sketch Position0 corresponds to rows of Output0 and Velocity0 corresponds to the columns of Output0. In interp2, the x-coordinate corresponds to the columns and the y-coordinate the rows, which is why in my example I had Velocity as x and Postion as y.
Más respuestas (0)
Ver también
Categorías
Más información sobre Logical en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!