WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

logarithmische Achseneinteilung bei pcolor

 

tommy0078

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 10.08.2015, 14:23     Titel: logarithmische Achseneinteilung bei pcolor
  Antworten mit Zitat      
Hallo Zusammen,

da mir hier schonmal so nett geholfen wurde, wende ich mich erneut mit einer Frage an euch:
Ich habe 2 verschiedene Messwerte vorliegen, die ich mit hist3 und pcolor in ein 2d-Koordinatensystem eintrage und die Häufigkeit der vorhandenen Messwerte durch farbliche "Kästen" darstelle. Das klappt soweit prima! Sowohl die Messwerte der x-Achse, als auch die Messwerte der y-Achse sind sowohl positiv als auch negativ. Aufgrund des Wertebereiches der Messwerte der x-Achse (-3*10^7 bis 3*10^7) möchte ich die Achse logarithmisch skalieren, damit man Werte um 0 besser erkennen kann. Da auch negative Werte vorkommen, klappt das natürlich nicht direkt mit dem Befehl in Matlab, da der log nur positiv definiert ist.

Mein Code sieht wie folgt aus (siehe unten):
Ich habe vermutlich schon hinbekommen, dass die Werte logarithmisch richtig dargestellt werden oder? Wenn ja, wie kann ich jetzt dazu passend die Achse skalieren? Wenn nein, wie kann ich denn mein Ziel, eine logarithmische Darstellung mit passend skalierte x-Achse zu erhalten, erreichen?

Noch ein kurzer Hinweis: Das Auskommentierte im Code ist die Lösung, wenn alle Achsen linear dargestellt werden sollen und funktioniert soweit. Wenn ich bei xb statt dem linspace ein logspace einsetze, wird die x-Achse von 0 bis 1 skaliert. Das verstehe ich nicht so ganz...

Vielen Dank bereits jetzt für die Hilfe!

Code:
groesse = 50;
figure('name','Schräglage über Kurvenradius');
    temp = sign(Messdaten_Matfile(:,5)).*log10(abs(Messdaten_Matfile(:,5)));
%     r_k__gamma = [Messdaten_Matfile(:,5) Messdaten_Matfile(:,2)];
    r_k__gamma = [temp Messdaten_Matfile(:,2)];
    n = hist3(r_k__gamma,[groesse, groesse]);
    n1 = n';
    n1(size(n,1) + 1, size(n,2) + 1) = 0;
   
%     xb = linspace(min(r_k__gamma(:,1)),max(r_k__gamma(:,1)),size(n,1)+1);
    xb = linspace(min(Messdaten_Matfile(:,5)),max(Messdaten_Matfile(:,5)),size(n,1)+1);
    yb = linspace(min(r_k__gamma(:,2)),max(r_k__gamma(:,2)),size(n,1)+1);
   
    h = pcolor(xb,yb,n1);
    shading flat; % do not interpolate pixels
    colorbar % add colorbar
       
    title(Titel)
    xlabel('Kurvenradius R in m')
    ylabel('Schräglage \gamma in Grad')
    cb = colorbar('vert');
    zlab = get(cb,'ylabel');
    set(zlab,'String','Absolute Anzahl');
    set(findall(gcf,'type','text'),'FontSize',14)
    set(findall(gca,'type','axes'),'FontSize',14)


Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

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
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2025 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

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.