У меня есть текстовый файл, из которого я должен получить данные и построить график, который будет выглядеть так. Я хочу построить график, по которому машина имела статус = "включено". Я попытался найти индексы, по которым машина находилась в состоянии «включено».
Что я наделал:
fid=fopen('power.txt');
line=fgetl(fid);
data=textscan(fid,'%d %f %s');
fclose(fid);
time=data{1};
power=data{2};
status=data{3};
status_on=strcmp(data{3},'on');
indices=find(status_on==0);
start_indices=indices+1;
%adding the first index where the status is on
start_indices=[1; start_indices];
%removing the last element as the last index will always have the value off
start_indices(end)=[];
end_indices=indices-1;
%Plotting Graph
plot(time,power,'-r');
xlabel('Time (s)');
ylabel('Power (W)');
title('Sonications over time');
Этот график просто дает мне простой график, но мне нужно, чтобы мой график выглядел так. Также я искал об использовании маркеров, мне нужно сделать специальный код, чтобы получить эти маркеры, или есть функции Matlab по умолчанию?
неплохо подмечено. Но мне нужно, чтобы мой график был пустым, когда он выключен, и чтобы была линия только тогда, когда она есть, где мне нужна помощь.
Вы можете использовать цикл и добавлять маркеры с помощью другого вызова plot
и сохранять текущий график при добавлении новых графиков с помощью hold on
.
NaN
Вы можете заполнить индексы, соответствующие тому, что машина «ВЫКЛЮЧЕНА», до NaN
(не число), и они будут игнорироваться при построении графика. Нахождение локальных максимумов и минимумов с помощью функций islocalmin()
и islocalmax()
позволит построить маркеры на основе индекса.
fid=fopen('power.txt');
line=fgetl(fid);
data=textscan(fid,'%d %f %s');
fclose(fid);
time=data{1};
power=data{2};
status=data{3};
status_on=strcmp(data{3},'on');
Off_Status = find(status == "off");
power(Off_Status) = "NaN";
Local_Minimum_Indices = islocalmin(power);
Local_Minimum_Indices(end-1) = 1;
Local_Maximum_Indices = islocalmax(power);
Local_Maximum_Indices(1) = 1;
%Plotting Graph
clf;
plot(time,power,'-r');
hold on
plot(time(Local_Maximum_Indices),power(Local_Maximum_Indices),'x','MarkerSize',10,'color','b');
plot(time(Local_Minimum_Indices),power(Local_Minimum_Indices),'s','MarkerSize',10,'color','g');
xlabel('Time (s)');
ylabel('Power (W)');
title('Sonications over time');
ylim([0 max(power)+2]);
Выполнено с использованием MATLAB R2019b
Спасибо, ваш код работает. Есть ли какая-либо функция по умолчанию, которую я мог бы добавить, чтобы получить эти конкретные маркеры в этих конкретных точках?
Почти использование функций islocalmin()
и islocalmax()
позволит вам найти индексы, в которых необходимо нанести маркеры. Я отредактировал свой ответ, чтобы учесть это.
По-видимому, когда степень
status
равнаOFF
, во втором столбце (power
) отображается-1
, поэтому ищите это значение во втором столбце, и все, что не-1
, тогда равноON
.