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

zusammenführung von automatischem import und Funktionen

 

waba
Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 14.02.14
Wohnort: Dresden
Version: R2014a
     Beitrag Verfasst am: 18.02.2014, 15:20     Titel: zusammenführung von automatischem import und Funktionen
  Antworten mit Zitat      
Hallo zusammen,

ich böntige mal eure Hilfe.
Und zwar habe ich mehere *.asc-Dateien mithilfe dieses Codes eingelesen:

Code:
pathname = uigetdir('', 'Verzeichnis wählen');
if pathname == 0
return
end

Mdir = dir(pathname);
nbentries = size(Mdir, 1);
Mfiles = [];
for entry_i = 1:nbentries
if Mdir(entry_i).isdir == false

filename = Mdir(entry_i).name;
if filename(1) ~= '.'
[p, n, ext] = fileparts(filename);
if strcmpi(ext, '.asc')
Mfiles = strvcat(Mfiles, filename);
end
end
end
end
nbfiles = size(Mfiles, 1);


In den ursprünglichen *.asc-Dateien sind Tabellen mit 6 Spalten enthalten. Davon benötige ich die ersten drei Spalten (x-, y- und z-Koordinaten).
Beispielhalber habe ich im Vorfeld an einer Datei herum probiert. Ich habe sie mittels Import Data importiert und folgendermaßen weiter bearbeitet:

Code:
importfile('D:\Pfad\blabla.asc');

XYZ=blabla(1:60:end,1:3); %Reduzierung der Rohdaten
X=XYZ(:,1)/10+50; %Verschiebung der x-Achse
Y=XYZ(:,2)*5/10; %Umrechnung der Rohdaten auf Zentimeter
Z=(XYZ(:,3)-min(XYZ(:,3)))/10;


Das selbe möchte ich nun mit allen importierten Datein machen. Wie kann ich dies denn am sinnvollsten umsetzen wenn ich in x-Richtung jeweils unterschiedliche Zahlen hinzu addieren möchte (50, 60, 70 usw.)?

Viele Grüße
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 18.02.2014, 21:31     Titel:
  Antworten mit Zitat      
Hallo,

was soll der erste Code denn genau machen?
Auf den ersten Blick wirkt es auf mich, als ob man ebenso
Code:
pathname = uigetdir('', 'Verzeichnis wählen');
if pathname == 0
return
end

Mdir = dir(fullfile(pathname, '*.asc');
Mfiles = {Mdir.name};
nbfiles = size(Mfiles, 1);

verwenden könnte.

Zitat:
Das selbe möchte ich nun mit allen importierten Datein machen. Wie kann ich dies denn am sinnvollsten umsetzen wenn ich in x-Richtung jeweils unterschiedliche Zahlen hinzu addieren möchte (50, 60, 70 usw.)?

Also eine for-Schleife über alle Dateien.
Wie ergeben sich denn die Zahlen, die du hinzu addieren möchtest? Die müsstest du wohl irgendwie aus den jeweiligen Dateiinhalten erschließen.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
waba
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 14.02.14
Wohnort: Dresden
Version: R2014a
     Beitrag Verfasst am: 19.02.2014, 10:36     Titel:
  Antworten mit Zitat      
Hallo Harald,

ja da hab ich es mir wohl schwerer gemacht als nötig...
Danke für den Tip. Bringt genau das was ich wollte.

Die Messstreifen sind 10cm breit und wurden alle nebeneinander aufgezeichnet bzw. in x-Richtung immer um 10cm verschoben.
Der erste Messstreifen wurde bei 50cm aufgezeichnet, dann bei 60cm usw..
Im Dateinamen sind diese Werte enthalten, sodass sie mittels textscan ausgelesen werden können. Zumindest war das so der Grundgedanke...

Nun möchte ich zu den x-Koordinaten diesen Wert hinzu addieren, damit ich am Ende irgendwann z.B. mit surf eine Höhenprofil erstellen kann.

Viele Grüße
Private Nachricht senden Benutzer-Profile anzeigen
 
waba
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 14.02.14
Wohnort: Dresden
Version: R2014a
     Beitrag Verfasst am: 19.02.2014, 12:01     Titel:
  Antworten mit Zitat      
Nachtrag,

visualisieren wollte ich das ganze dann ungefähr so:

Code:
F = TriScatteredInterp(X,Y,Z,'nearest');
tx = ((min(X)):1:(max(X)));
ty = ((min(Y)):1:(max(Y)));
[qx,qy] = meshgrid(tx,ty);
qz = F(qx,qy);
imagesc(qz);
surf(qz);


Grüße
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 19.02.2014, 21:12     Titel:
  Antworten mit Zitat      
Hallo,

Zitat:
Im Dateinamen sind diese Werte enthalten, sodass sie mittels textscan ausgelesen werden können. Zumindest war das so der Grundgedanke...

Entweder so oder vielleicht auch per schlichter Indizierung. Das hängt vom Aufbau der Dateinamen ab.

Zu den verbleibenden Schritten müsstest du wenn konkrete Fragen stellen - ich weiß jedenfalls nicht, wie ich dir da weiterhelfen könnte.

Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
waba
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 29
Anmeldedatum: 14.02.14
Wohnort: Dresden
Version: R2014a
     Beitrag Verfasst am: 20.02.2014, 15:08     Titel:
  Antworten mit Zitat      
Danke für die Hilfe!
Ich tüftle jetzt erst einmal selber weiter und melde mich wenn die Fragen wieder konkreter werden.
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.