Interpolation using two variables

4 visualizaciones (últimos 30 días)
Sanket Gaikwad
Sanket Gaikwad el 24 de Jul. de 2020
Respondida: Image Analyst el 26 de Jul. de 2020
Hi,
I have two variables accelerator pedal and vehicle speed and corresponding value for Z.
I want a solution which will give me Z value if i give any random acc pedal and vehicle speed value.
Max value of Z can be 10, not more than that.
Thanks

Respuestas (3)

Rik
Rik el 24 de Jul. de 2020
  4 comentarios
Sanket Gaikwad
Sanket Gaikwad el 26 de Jul. de 2020
I didn't get any errors. In the documentation they are using meshgrid function. That's the part that I didn't understand. I don't know how to convert my data similar to what they are using for interp2 functions input. Also my data has different interval for acc pedal and vehicle speed, I don't know how to include this information in interp2.
Rik
Rik el 26 de Jul. de 2020
You have 2 vectors that determine the x and y values. What code did you try with meshgrid?

Iniciar sesión para comentar.


Image Analyst
Image Analyst el 26 de Jul. de 2020
Editada: Image Analyst el 26 de Jul. de 2020
Here is a demo for scatteredInterpolant. But if you can't understand interp2() you probably won't understand this either.
Give us code to create your table if you need more help. Make it easy for us to help you, not hard.

Image Analyst
Image Analyst el 26 de Jul. de 2020
Sanket, try this demo of interp2(). Adapt as needed, like using your own matrix instead of my "myMatrix".
clc; % Clear the command window.
close all; % Close all figures (except those of imtool.)
clear; % Erase all existing variables. Or clearvars if you want.
workspace; % Make sure the workspace panel is showing.
format short g;
format compact;
fontSize = 18;
fprintf('Beginning to run %s.m ...\n', mfilename);
% Create a sample matrix using the MATLAB peaks logo function.
myMatrix = peaks(11)
% Scale it so that it's in the range 0-10.
myMatrix = rescale(myMatrix, 0, 10)
% Plot it as a surface so we can visualize it.
surf(myMatrix)
% Add axes labels.
xlabel('Vehicle Speed', 'FontSize', fontSize);
ylabel('Acc Pedal', 'FontSize', fontSize);
zlabel('Z', 'FontSize', fontSize);
% Find out what the value is at x=6.5 and y=7.5
xq = 6.5;
yq = 7.5;
z = interp2(myMatrix, xq, yq)
% Plot that point on the surface as a red dot.
hold on;
plot3(xq, yq, z, 'r.', 'MarkerSize', 30);
caption = sprintf('Z = %.2f at (%.1f, %.1f)', z, xq, yq);
title(caption, 'FontSize', fontSize);
fprintf('Doe running %s.m ...\n', mfilename);

Categorías

Más información sobre Surface and Mesh Plots en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2015b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by