2.74 MATLAB code for Interface to Nucleo

Experiment_Example_MATLAB.m

Committer:
elijahsj
Date:
2020-09-12
Revision:
9:3d6b58589448
Parent:
8:58d93d7564ed

File content as of revision 9:3d6b58589448:

function output_data = Experiment_Example_MATLAB()
    figure(1);  clf;       % Create an empty figure to update later
    subplot(311)
    h1 = plot([0],[0]);
    h1.XData = []; h1.YData = [];
    ylabel('Position');
    
    subplot(312)
    h2 = plot([0],[0]);
    h2.XData = []; h2.YData = [];
    ylabel('Velocity');
    
    subplot(313)
    h3 = plot([0],[0]);
    h3.XData = []; h3.YData = [];
    ylabel('Current (Amps)');
    
    % This function will get called any time there is new data from
    % the FRDM board. Data comes in blocks, rather than one at a time.
    function my_callback(new_data)
        t = new_data(:,1);   % time
        pos = new_data(:,2); % position
        vel = new_data(:,3); % velocity
        curr = new_data(:,4); %current
        N = length(pos);
        
        h1.XData(end+1:end+N) = t;   % Update subplot 1
        h1.YData(end+1:end+N) = pos;
        h2.XData(end+1:end+N) = t;   % Update subplot 2
        h2.YData(end+1:end+N) = vel;
        h3.XData(end+1:end+N) = t;   % Update subplot 2
        h3.YData(end+1:end+N) = curr;
    end
    
    frdm_ip  = '192.168.1.100';     % Nucleo board ip
    frdm_port= 11223;               % Nucleo board port  
    params.callback = @my_callback; % callback function
    params.timeout  = 2;            % end of experiment timeout
    
    % The example program provided takes two arguments
    d1 = 0.5;           % pwm duty cycle applied for first second 
    d2 = 0;             % pwm duty cycle applied for second second
    input = [d1 d2];    % input sent to Nucleo board
    output_size = 4;    % number of outputs expected
   
    output_data = RunExperiment(frdm_ip,frdm_port,input,output_size,params);
    
end