Verfasst am: 25.07.2017, 16:59
Titel: Schleife zum Beschreiben einer Matrix
Guten Abend zusammen.
Folgende Situation:
Ich habe 2 cells. Die eine heisst GivenData und die andere heisst GivenDB.
die 2. Spalte der GivenDB besteht aus Datumsangaben. Die 1 Spalte von GivenDB besteht ebenfalls aus Datumsangaben.
Meiner Matrix GivenDB habe ich bereits im Vorfeld weitere Zellen hinzugefügt. Ich möchte nun, dass die Daten Zeilenweise chronologisch in GivenDB ergänzt werden. Ich habe auc bereits einen versuch unternommen, allerdings werden keine Einträge gemacht.
Code:
L_alt=2;
for k=2:size(GivenData,1) for L=2:size(GivenDB,1)
t=datetime(GivenData(k,2),'InputFormat','dd.MM.yy_HH:mm:ss');
tlower= datetime(GivenDB(L_alt,2),'InputFormat','dd.MM.yyyy HH:mm:ss.SSSSSS');
tupper= datetime(GivenDB(L_alt+1,2),'InputFormat','dd.MM.yyyy HH:mm:ss.SSSSSS');
if(isbetween(t,tlower,tupper)==1) for m=3:size(GivenData,2)
GivenDB(L_alt:L,m)= GivenData(k,m);
end
L_alt=L;
break end end end
Ich verstehe nicht so recht das Problem. ich definiere k für die relevanten Zeilen meiner Daten, die ich einfügen möchte. L sind die Zeilen der Datenbank, in die ich schreibe möchte. t ist das Datum was sortiert werden soll und ich verlgeiche mit tlower und tupper aus GivenDB. Wenn mein t nun da zwischen liegt soll die gesamte Zeile aus GivenData in die letzten Spalten von GivenDB geschrieben werden.
Würde gerne nochmal etwas Aufmerksamkeit auf mein Problem lenken. Suche da immer noch dringend nach Hilfe. (Ich hoffe es verstößt nicht gegen die Regeln hier) Bin auch bereit für die Dienstleistung zu bezahlen. Wenn mehr Infos notwendig sind, versuche ich das Problem gerne nochmal genauer zu beschreiben.
ist es beachsichtig damit ta und tlower/tupper unterschiedlich genau angegeben werden? (also s und msec)
Kommt bei dir eine Fehlermeldung oder führt des alles durch und füllt nur die Zeilen nicht? Hast du mal mit Debugging versuch dir die schleife anzuschauen ob es die werte nach jeder Wiederholung überschreibt?
_________________
zum Organisieren solcher Daten bieten sich Tables an. Bei den neuen Timetables (ab R2016b) gibt es die Funktion synchronize, die Daten mit unterschiedlichen Zeitstempeln zusammenführt.
Das ist nicht logisch. Einerseits ist "numel(5:10)" seltsam, denn das ist einfach 6. Andererseits Überschreibst Du die Daten immer wieder: Wenn N von L bis M läuft, ist (N:M) mehrfach bei den gleichen Werten und in jeder Iteration wird der Index M überschrieben - mit den gleichen Werten.
Code wird oft viel übersichtlicher, wenn man kurze Variablen-Namen verwendet: "Data" und "DB" würden es hier auch tun.
Gruß, Jan
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.