Verfasst am: 11.11.2012, 20:55
Titel: Daten in struct array speichern
Hallo,
ich möchte mir bilddatein ins matlab importieren und den namen und verschiedenen feature vektoren in ein struct array speichern?
wie gehe ich da am besten vor. Was ich weiß ist wie ich die bilder reinlade also mit "dir" bzw. wie ich mir die features extrahiere aber wie bekommen ich den namen der files und die daten ins struct array?
Bitte poste den relevanten Teil des bisherigen Codes, so dass wir die Änderungen einfügen können. Andernfalls ist es unwahrscheinlich, dass unsere Vorschläge zu Deinem Programm passen.
okey hier der code. ich lade mir aus dem ordner leavs_mixed die daten. dann kommt die For Schleife wo ich mir name und die farbhistogramme auslesen will. Die namen sollen in L gespeichert werden! Bei den histogrammen funkioniert es, dass alle werte untereinander eingetragen werden. Bei den namen bleibt aber nur der letzt eingelesene in einer 1x1 matrix stehen!
Bzw. wäre es am besten wenn mir werte und name der dateien in einer matrix abgespeichert werden würden. halt name, werte und dann in der nächsten zeile die nächste datei.
Ich kann Dir nicht folgen.
Das Lesen fällt übrigens leichter, wenn Du die Standard-Groß/Klein-Schreibung verwendest.
Welchen Type soll "L" denn haben? Möchtest Du ein Cell- oder Struct-Array?
Ich finde es verblüffend, dass Du in IMHIST(I, i) mit dem Index i der Fileliste aufrufst. Die Reihenfolge der Ausgabe von DIR ist nicht dokumentiert. Bist Du sicher, dass das i.te File mit i Bins berechnet werden soll?
Zitat:
Bei den histogrammen funkioniert es, dass alle werte untereinander eingetragen werden.
Funktioniert dies wirklich? Immerhin überschreibst Du gHist, bHist und rHist in jeder Iteration.
Ich rate mal:
Code:
Folder = fullfile(cd, 'leaves_mixed'); % Relative path names are a source of errors
D = dir(fullfile(Folder, '*.*'));
FileList = {D([D.isdir]).name};
k = 0;
for ii = 1:numel(D)% Do not shadow the imaginary unit "i"
FileName = FileList{ii};
ifstrcmp('g', FileName(end))
k = k + 1;
disp(FileName);
Img = imread(fullfile(Folder, FileName));
L{ii} = FileName;
gHist{ii} = imhist(I(:,:,2), ii);
bHist{ii} = imhist(I(:,:,3), ii);
rHist{ii} = imhist(I(:,:,1), ii);
end 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.