Hallo,
ich habe einen Datensatz und möchte den Fehlerbereich (der Werte auf der y-Achse) als farbigen Bereich darstellen. Hierfür habe ich die Daten geplottet und wollte mit area, fill oder patch den Bereich zwischen den zwei Funktionen (Daten + bzw. - Fehlerbereich) füllen. Hierbei treten verschiedene Probleme auf.
Bei area wird bei einer Verteilung um x=0 zusätzlich auch alles bis zur x-Achse ausgefüllt (area_um0.jpg). Wenn die Daten nicht um null liegen, geschieht das selbe nur sieht dies natürlich noch schlechter aus, da sich ein großer farbiger Kasten ergibt (area_nichtum0.jpg).
Bei fill sieht es hingegen aus als ob zwei Geraden +/-Fehlerbereich in dem plot liegen (fill_um0.jpg, fill_nichtum0.jpg).
Ich habe im Forum schon gesucht, das Problem aber nicht beheben können. Ich bin für jeden Tipp und jede Hilfe dabkbar. Viele Grüße und danke schon mal.
%% Versuch mit area % YX-Plot figure() area(x1, y1,'FaceColor',[0.80.80.8],'edgecolor', [0.80.80.8],'FaceAlpha',0.5) hold on
area(x1, y2,'FaceColor',[0.80.80.8],'edgecolor', [0.80.80.8],'FaceAlpha',0.5) hold on
p1 = plot(x1, data(:,1), '-+k') hold on
% YZ-Plot figure() area(x1, z1,'FaceColor',[0.80.80.8],'edgecolor', [0.80.80.8],'FaceAlpha',0.5) hold on
area(x1, z2,'FaceColor',[0.80.80.8],'edgecolor', [0.80.80.8],'FaceAlpha',0.5) hold on
p1 = plot(x1, data(:,3), '-+k') hold on
%% Versuch mit fill oder patch % YX-Plot figure() plot(x1, y1, x2, y2);
hold on;
filler = fill([x1; x2],[y1; y2], [0.80.80.8],'edgecolor', [0.80.80.8]);
hold on
p1 = plot(data(:, 2), data(:, 1), '-+k');
% YZ-Plot figure() plot(x1, z1, x2, z2);
hold on;
% 'patch' macht das gleiche
filler = fill([x1; x2],[z1; z2], [0.80.80.8],'edgecolor', [0.80.80.8]);
hold on
p1 = plot(data(:, 2), data(:, 3), '-+k');
1.) Ask MATLAB Documentation
2.) Search gomatlab.de, google.de or MATLAB Answers
3.) Ask Technical Support of MathWorks
4.) Go mad, your problem is unsolvable ;)
NinaAbbi
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 25.03.2020, 10:49
Titel:
Vielen Dank für die schnelle Rückmeldung. Leider löst das mein Problem nicht oder ioch bekomme es damit nicht hin. Hat noch jemand eine andere Idee. Das wäre mir eine große Hilfe.
Leider löst das mein Problem nicht oder ioch bekomme es damit nicht hin.
Das ist nicht sehr aussagekräftig. Je konkreter du sagst, was du weiter versucht hast und welche Probleme dabei aufgetreten sind, desto eher kann man dir helfen.
Wenn du dann noch einen Beispieldatensatz zur Verfügung stellst, kann man dir noch besser helfen.
Grüße,
Harald
_________________
1.) Ask MATLAB Documentation
2.) Search gomatlab.de, google.de or MATLAB Answers
3.) Ask Technical Support of MathWorks
4.) Go mad, your problem is unsolvable ;)
NinaAbbi
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 25.03.2020, 13:56
Titel:
Hier die Testdaten (testdata2.txt), das hatte ich in der Tat schon beim ersten post vergessen. Sorry.
Nun noch was ich versucht habe.
Code:
% neuer Versuch mit area
Y1 = [(data(:, 1) - 0.007), data(:, 1) , (data(:, 1)+0.007);];
figure
a = area(x1, Y1);
a(1).FaceColor = 'none';
hold on
p1 = plot(x1, data(:,1), '-+b');
Y2 = [z1, data(:, 3) , z2;];
figure
a = area(x1, Y2);
a(1).FaceColor = 'none';
hold on
p1 = plot(x1, data(:,3), '-+b');
1.) Ask MATLAB Documentation
2.) Search gomatlab.de, google.de or MATLAB Answers
3.) Ask Technical Support of MathWorks
4.) Go mad, your problem is unsolvable ;)
Einstellungen und Berechtigungen
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.