В этом примере показано, как оптимизировать класс диаграммы для отображения переменного числа строк. Он повторно использует существующие объекты-строки, что может повысить производительность диаграммы, особенно если количество строк не изменяется часто. Более простую версию этой диаграммы без оптимизации см. в разделе Класс диаграммы с переменным количеством строк.
Диаграмма отображает столько строк, сколько столбцов в YData матрица, с круговыми маркерами в локальных экстремумах. Следующий код демонстрирует, как:
Определение двух свойств с именем PlotLineArray и ExtremaLine которые хранят объекты для линий и маркеров соответственно.
Реализация setup метод, инициализирующий ExtremaLine объект.
Реализация update метод, который получает размер PlotLineArray, а затем добавляет или вычитает объекты из этого массива в соответствии с количеством столбцов в YData.
Чтобы определить класс, скопируйте этот код в редактор и сохраните его с именем OptimLocalExtremaChart.m в доступной для записи папке.
classdef OptimLocalExtremaChart < matlab.graphics.chartcontainer.ChartContainer % c = OptimLocalExtremaChart('XData',X,'YData',Y,Name,Value,...) % plots one line with markers at local extrema for every column of matrix Y. % You can also specify the additonal name-value arguments, 'MarkerColor' % and 'MarkerSize'. properties XData (:,1) double = NaN YData (:,:) double = NaN MarkerColor {validatecolor} = [1 0 0] MarkerSize (1,1) double = 5 end properties(Access = private,Transient,NonCopyable) PlotLineArray (:,1) matlab.graphics.chart.primitive.Line ExtremaLine (:,1) matlab.graphics.chart.primitive.Line end methods(Access = protected) function setup(obj) obj.ExtremaLine = matlab.graphics.chart.primitive.Line(... 'Parent', obj.getAxes(), 'Marker', 'o', ... 'MarkerEdgeColor', 'none', 'LineStyle',' none'); end function update(obj) % Get the axes ax = getAxes(obj); % Create extra lines as needed p = obj.PlotLineArray; nPlotLinesNeeded = size(obj.YData, 2); nPlotLinesHave = numel(p); for n = nPlotLinesHave+1:nPlotLinesNeeded p(n) = matlab.graphics.chart.primitive.Line('Parent', ax, ... 'SeriesIndex', n, 'LineWidth', 2); end % Update the lines for n = 1:nPlotLinesNeeded p(n).XData = obj.XData; p(n).YData = obj.YData(:,n); end % Delete unneeded lines delete(p((nPlotLinesNeeded+1):numel(p))) obj.PlotLineArray = p(1:nPlotLinesNeeded); % Replicate x-coordinate vectors to match size of YData newx = repmat(obj.XData(:),1,size(obj.YData,2)); % Find local minima and maxima and plot markers tfmin = islocalmin(obj.YData,1); tfmax = islocalmax(obj.YData,1); obj.ExtremaLine.XData = [newx(tfmin); newx(tfmax)]; obj.ExtremaLine.YData = [obj.YData(tfmin); obj.YData(tfmax)]; obj.ExtremaLine.MarkerFaceColor = obj.MarkerColor; obj.ExtremaLine.MarkerSize = obj.MarkerSize; % Make sure the extrema are on top uistack(obj.ExtremaLine, 'top'); end end end
После сохранения файла класса можно создать экземпляр диаграммы. Например:
x = linspace(0,2)'; y = cos(5*x)./(1+x.^2); c = OptimLocalExtremaChart('XData',x,'YData',y);

Теперь создайте for цикл, добавляющий дополнительную линию в график при каждой итерации. Объект диаграммы сохраняет все существующие строки и добавляет одну дополнительную строку для каждой i.
for i=1:10 y = cos(5*x+i)./(1+x.^2); c.YData = [c.YData y]; end
