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

3D Kreisfläche

 

MrSnoot
Forum-Anfänger

Forum-Anfänger



Beiträge: 17
Anmeldedatum: 16.02.09
Wohnort: Dresden
Version: R2007b
     Beitrag Verfasst am: 16.02.2009, 20:47     Titel: 3D Kreisfläche
  Antworten mit Zitat      
Hi,

ich habe eine Kreisfläche (x und y von -150 bis 150) und 17 z-Werte, die ich gerne als 3D-Fläche darstellen würde.

Ist es möglich, dass Matlab:

a) mir eine x-y-Kreisfläche mit Radius = 150 anzeigt
b) mir an 17 beliebigen Koordinaten die z-Werte anzeigt
c) die Zwischenwerte interpoliert?

Denn sonst sieht das recht blöd aus Wink

oberflaeche.png
 Beschreibung:

Download
 Dateiname:  oberflaeche.png
 Dateigröße:  19.41 KB
 Heruntergeladen:  768 mal
Private Nachricht senden Benutzer-Profile anzeigen


Bijick
Ehrenmitglied

Ehrenmitglied



Beiträge: 914
Anmeldedatum: 18.06.07
Wohnort: Nürnberg
Version: R2006b, R2008b
     Beitrag Verfasst am: 17.02.2009, 10:28     Titel:
  Antworten mit Zitat      
Hallo MrSnoot,

ich habe den Teil b) mal so interpretiert, dass die 17 Werte im Kreis liegen, aber das spielt eigentlich keine Rolle. Mein Vorschlag wäre:

Code:
% Beispieldaten
t = 0:0.1:2*pi;
r = 150*rand(17,1);
phi = 2*pi*rand(17,1);
x = r.*sin(phi);
y = r.*cos(phi);
z = 70*abs(randn(17,1));

% Triangulierung der 17 x- und y-Koordinaten
tri = delaunay(x,y);

% Visualisierung
hold on
fill3(150*sin(t),150*cos(t),zeros(length(t)),'r')   % Kreis
trisurf(tri,x,y,z)   % Interpolierte z-Daten


Hast Du es Dir so etwa vorgestellt?

Herzliche Grüße
Bijick
_________________

>> why
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
Bijick
Ehrenmitglied

Ehrenmitglied



Beiträge: 914
Anmeldedatum: 18.06.07
Wohnort: Nürnberg
Version: R2006b, R2008b
     Beitrag Verfasst am: 17.02.2009, 12:22     Titel:
  Antworten mit Zitat      
Hallo MrSnoot,

zweiter Vorschlag mit griddata:

Code:
% Beispieldaten
t=0:0.1:2*pi;
r=150*rand(17,1);
phi=2*pi*rand(17,1);
x = r.*sin(phi);
y = r.*cos(phi);
z=70*abs(randn(17,1));

% Interpolation
xlin = linspace(min(x),max(x),33);
ylin = linspace(min(y),max(y),33);
[X,Y] = meshgrid(xlin,ylin);
Z = griddata(x,y,z,X,Y,'cubic');

% Visualisierung
hold on
fill3(150*sin(t),150*cos(t),zeros(length(t)),'r') % Kreis
surf(X,Y,Z) % Interpolierte z-Daten


Herzliche Grüße
Bijick
_________________

>> why
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
MrSnoot
Themenstarter

Forum-Anfänger

Forum-Anfänger



Beiträge: 17
Anmeldedatum: 16.02.09
Wohnort: Dresden
Version: R2007b
     Beitrag Verfasst am: 17.02.2009, 19:13     Titel:
  Antworten mit Zitat      
Hey vielen Dank, das ist beides perfekt Smile

Den Kreis selbst (fill3(...)) brauche ich gar nicht, ich wollte nur einfach keine quadratische Grundfläche die ich erhalte, wenn ich mit meinen x-y-z-Werte eine 9x9-Matrix bastle (siehe Bild im ersten Post).


Mit deinen Codes sieht das aber genau richtig aus. Jetzt muss ich mir nur noch eine Schleife basteln, weil ich insgesamt 3500 mal 17 z-Werte habe Smile


Also nochmals vielen Dank, besser könnts nicht sein!

trisurf.jpg
 Beschreibung:
trisurf

Download
 Dateiname:  trisurf.jpg
 Dateigröße:  49.29 KB
 Heruntergeladen:  784 mal
griddata.jpg
 Beschreibung:
griddata

Download
 Dateiname:  griddata.jpg
 Dateigröße:  77.68 KB
 Heruntergeladen:  774 mal
Private Nachricht senden Benutzer-Profile anzeigen
 
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.