how to create a look up table to use in simulink from a 2D array of doubles

28 次查看(过去 30 天)
I have a simple 2 day array that is 40x2
I want to make it a look up table for simulink.
it needs to be interpolated not a direct.
So i want simulink to scan the first column and find the value closed to the one im inputting and them pump out the value in the second column that corresponds to the input found in column one.
This should be really simple. Can someone lend a hand?
thanks

采纳的回答

Paul
Paul 2023-12-15
编辑:Paul 2023-12-15
Assuming your 40x2 array is stored in a workspace varaiable named data.
Set the Table Data parameter to data(:,2)
Set the Breakpoints parameter to data(:,1)
Set the Interpolation Method to Nearest.
Depending on the structure of data(:,1) make sure to check into the following block parameters: Index search method, and Begin index search using previous index result
I think this addresses the problem as stated in the question. But the question also mentioned interpolation, and there is no interpolation happening here.
  8 个评论
madhan ravi
madhan ravi 2023-12-15
Paul you could show the picture of Table and breakpoints field so that it is clear for OP how to define them in Simulink.
Robert Scott
Robert Scott 2023-12-15
Wow im an idiot.
I figured it out.
I guess i did not understand what the meaning of break point is.
Why dont they just call it data in and data out..... (headbang!)
Thank you guys for help so much! Great support great community. Im just a goober.
Happy Holidays folks

请先登录,再进行评论。

更多回答(2 个)

Andy Bartlett
Andy Bartlett 2023-12-14
编辑:Andy Bartlett 2023-12-14
To create a Simulink 1D Lookup Table block using the data from your 2D matrix variable,
modify this script to meet your needs and run it.
% fake creation of data
%
npts = 5;
x = linspace(0.1,1,npts).';
y = exp(1.234*x);
data2D = [x, y];
% Create model containing 1D LUT block
%
rand_trailing_string = dec2hex( randi([0,2^32-1],1,1), 8 );
mdl = sprintf('myRandModelName_%s',rand_trailing_string);
sourceLUT1 = sprintf('simulink/Lookup\nTables/1-D Lookup\nTable');
destinationLUT1 = [mdl,'/LUT'];
new_system(mdl);
open_system(mdl);
add_block( sourceLUT1, destinationLUT1)
dataConnectionApproach = 'inline';
switch dataConnectionApproach
case 'inline'
% explicitly inline the data values
% Hint: mat2str is super helpful here
%
stringForBreakpoints = mat2str(data2D(:,1),17,'class');
stringForTableData = mat2str(data2D(:,2),17,'class');
otherwise
% Reference data in workspace by variable name
% Note: data must always be defined before model is used
% in the future
%
stringForBreakpoints = 'data2D(:,1)';
stringForTableData ='data2D(:,2)';
end
set_param(destinationLUT1, 'BreakpointsForDimension1', stringForBreakpoints);
set_param(destinationLUT1, 'Table', stringForTableData );
% Make additional changes to LUT as desired
% Either
% Manually
% or
% use set_param
%
% Hint to see names of parameters to use with set_param do
%
% get_param(gcb,'DialogParameters')
%
open_system(destinationLUT1) % open for manual changes
  1 个评论
Robert Scott
Robert Scott 2023-12-15
This is not working.
I got the table working but the output valuesa are no where near where they should be.
It looks up a value of lets say 4, the corresponding value in the table is about .85
Instead the table pumps out .5
So i dont know how its doing this interpolation but its pretty far off

请先登录,再进行评论。


Robert Scott
Robert Scott 2023-12-15
You guys are putting in great effort here to help.
Thank you!
For the life of me i cant make this work. I got rid of all the complicated code as you did and it still wont work. Here is a screen shot
  1 个评论
Robert Scott
Robert Scott 2023-12-15
Wow im an idiot.
I figured it out.
I guess i did not understand what the meaning of break point is.
Why dont they just call it data in and data out..... (headbang!)
Thank you guys for help so much! Great support great community. Im just a goober.
Happy Holidays folks

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Simulink 的更多信息

产品


版本

R2022b

Community Treasure Hunt

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

Start Hunting!

Translated by