Determine driving styles of a driver
    2 visualizzazioni (ultimi 30 giorni)
  
       Mostra commenti meno recenti
    

ZERO     = 0
ECONOMIC    = 1
NORMAL      = 2
AGGRESSIVE  = 3
ds_mapping= [ZERO,ECONOMIC,NORMAL,AGGRESSIVE]
for r=0:length(Acceleration)
    if(abs(Acceleration(r))<=0.7),
        fprintf('\n\tAcceleration = %5.2f m/sec^2:\t Driving Style: ZERO\tCLASS: %d',Acceleration(r),ds_mapping(0))
    end
    for r=1:length(Acceleration)
        if(abs(Acceleration(r))>=0.7),
            fprintf('\n\tAcceleration = %5.2f m/sec^2:\t Driving Style: ECONOMIC\tCLASS: %d',Acceleration(r),ds_mapping(1))
        end
        if(abs(Acceleration(r))>2.79 &&  Acceleration (r) <= 3.30),
            fprintf('\n\tAcceleration = %5.2f m/sec^2:\t Driving Style: NORMAL:\t\tCLASS: %d',Acceleration(r),ds_mapping(2))
        end
        if(abs(Acceleration (r))>3.63),
            fprintf('\n\tAcceleration = %5.2f m/sec^2:\t Driving Style: AGGRESSIVE:\tCLASS: %d', Acceleration(r),ds_mapping(3))
        end
    end
    fprintf('\n\n')
8 Commenti
Risposte (1)
  Aman
      
 il 6 Feb 2024
        Hi Ben,
As per my understanding, you want to classify the driving system based on the acceleration and the mapping table shared and are facing issues while doing so.
You can achieve the same using the code below, where I'm populating the "ds_mapping" based on the mapping table and then creating a line plot with two different variables on both y-axes of the plot. Please not, as the actual acceleration array was not present, so I have created a random acceleration array.
a = -6.5;
b = 6.5;
timeInterval = 1800;
acceleration = a + (b-a) * rand(1,timeInterval);
ds_mapping = [];
for i=1:timeInterval
    if(abs(acceleration(i))<0.7)
        ds_mapping = [ds_mapping,0];
    elseif(abs(acceleration(i))>=0.7 && abs(acceleration(i))<2.79)
        ds_mapping = [ds_mapping,1];
    elseif(abs(acceleration(i))>=2.79 && abs(acceleration(i))<3.64)
        ds_mapping = [ds_mapping,2];
    elseif(abs(acceleration(i))>=3.64)
        ds_mapping = [ds_mapping,3];
    end
end
figure;
hold on;
title("Acceleration and Driving Style classification");
xlabel("Time(s)");
yyaxis left;
plot(1:timeInterval,acceleration,"Color","blue");
ylabel("Acceleration(ms^2)");
ylim([-6.5 6.5]);
yyaxis right;
plot(1:timeInterval,ds_mapping,"Color","cyan");
ylabel("Driving Style");
ylim([0 3]);
hold off;
I hope it helps!
0 Commenti
Vedere anche
Categorie
				Scopri di più su Environment and Settings in Help Center e File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!






