Hallo,
ich bin mal so frei und veröffentliche einen Beitrag von Sco unter den Tutorials. Ich hoffe du hast nichts dagegen Sco.
(Quelle: http://www.gomatlab.de/matrix-farbig-plotten-t17565.html)
___________________________________________________
Der erste Teil des Codes zeigt eine Lösung am einfachen Beispiel, der 2. Teil eine Lösung für eine beliebige Matrix. Die Matrix habe ich nach dem Schema des Threadopeners erstellt, d.h. 1. Spalte = Farbindex, 2. Spalte = x-Werte, 3. Spalte = y-Werte.
mat = round(rand(5,3).*5); % Erzugt Matrix (1. Spalte=Farbindex, 2.=x, 3.=y) % diese Matrix kann bis zu 6 verschiedene Farben beihnalten (Werte von 0 bis 5 --> 6 Farben)
mat(:,2) = 1:5; % setze x von 1 bis 5
cmap = [100;010; 001;000; 101;011]; % colormap mit den 6 Farben (rot,grün,blau,schwarz,rosa,cyan)
% Visualisierung mit dem Befehl plot for k = 1:length(mat(:,2)) plot(mat(k,2),mat(k,3),'o','Markeredgecolor',cmap(mat(k,1)+1,:),'Markersize',10);
end
% Visualisierung mit Hilfe des Befehls scatter
scatter_cmap = zeros(length(mat(:,1)),3); %
for n = 1:(length(mat(:,1)))
scatter_cmap(n,:) = cmap(mat(n,1)+1,:); % Erzeugt eine Farbe für jeden Punkt und speichert % sie in einer Mx3 Matrix (M = Anzahl der Punkte) end
mat = round(rand(10,3).*50); % Erzugt Matrix mit 50 möglichen Farben
mat(:,2) = 1:10; % setze x von 1 bis 10
[uniqElements junk uniqIDX] = unique(mat(:,1));
numColors = length(uniqElements); % Anzahl der benötigten Farben (=unterschiedliche Werte in der 1. Spalte)
% automatische Erstellung einer colormap für beliebige Matrix (mat) while1
cmap = rand(numColors,3); % Erzeuge zufällige colormap mit Anzahl der benötigten Farben
cmap = round(cmap.*100)./100;
ifisequal(length(unique(cmap,'rows')),numColors)% prüfe ob zufällig 2 gleiche Farben erzeugt wurden break; % wenn keine redundante Farben-->verlasse while Schleife end end
% Visualisierung mit dem Befehl plot for k = 1:length(mat(:,2)) plot(mat(k,2),mat(k,3),'o','Markeredgecolor',cmap(uniqIDX(k),:),'Markersize',10);
end
% Visualisierung mit Hilfe des Befehls scatter
scatter_cmap = zeros(length(mat(:,1)),3);
for n = 1:(length(mat(:,1)))
scatter_cmap(n,:) = cmap(uniqIDX(n),:); % Erzeugt eine Farbe für jeden Punkt und speichert % sie in einer Mx3 Matrix (M = Anzahl der Punkte) end
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.