Verfasst am: 10.09.2011, 19:54
Titel: Werte in Vektor paarweise mitteln
Liebe Leute,
ich hänge hier schon länger, wahrscheinlich ist es voll einfach, aber naja:
Ich bekomme von einer function als Ergebnis einen Vektor, der die Werte in der Mitte verschiedener Schichten berechnet. Ich möchte aber die Werte an den Schichträndern, und dachte mir die bekomme ich indem ich den Mittelpunkt zwischen den Werten ausrechne.
Ich möchte also, dass immer von 2 werten dieses Vektors der Mittelwert gebildet wird, also der neue Vektor soll so aussehen:
Wert 2 von A_neu=((Alter_Wert1+alter_Wert2)/2)
Wert 3 von A_neu=((Alter_Wert2+alter_Wert3)/2)
Wert 4 von A_neu=((Alter_Wert3+alter_Wert4)/2)
.....
Nun verliere ich ja einen Wert, nämlich Wert 1, da ich mittle - und da habe ich mir folgendes überlegt: ich weiß wie weit die einzelnen Werte auseinander liegen, also kann ich den Gradient g zwischen Alter_Wert1 und Alter_Wert 2 ermitteln (also die zu- bzw. Abnahme mit der Höhe) und sage dann einfach:
Wert 1 von A_neu= (Wert 2 von A_neu)+g*halbe_Höhe
So, nur wie sage ich das Matlab? Ich bin für jede Hilfe dankbar!! Lg salas
dort gibt es Einsteigertutorials. Deine Frage "wie sage ich das MATLAB" ist sehr allgemein gehalten, sofern du keine Programmierkenntnisse hast. Du benötigst für dein Vorhaben allerdings nicht viel mehr als eine for-Schleife.
salas
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 10.09.2011, 21:03
Titel:
Eine for-Schleife? Hm, also ich habe es erst so versucht:
Aber anscheinend mache ich hier etwas falsch, denn ohne diese "Berichtigung" meiner Werte funktioniert alles tadellos, und dann plötzlich findet matlab in allen functions Fehler...
Habe ich einen eingebaut? Irgendeine Konvention nicht eingehalten?
Was für ein Fehler kommt denn? Ein Fehler taucht immer nur 1x auf, denn dann wird der Code gestoppt (also nicht in "allen functions").
salas
Gast
Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
Verfasst am: 11.09.2011, 12:02
Titel:
Ok, also das ist mein Hauptprogramm das verschiedene function aufruft, die verschiedene Dinge berechnen sollen:
Code:
global g Schichtdicke c_p Zeit Gammagamma H Zellmittelpunkte Hoehe T_0 p_0 R Anzahl_Schichten R
%@comment Ich definiere weitere Variablen die ich im Laufe des Programms brauchen werde
H=8000;
Schichtdicke = 100;
g = 9.81;
c_p = 1005;
Zeit = 3600:3600:86400;
Waermefluss_nachts = 30;
Zellmittelpunkte=Schichtdicke/2:Schichtdicke:H;
Zellmittelpunkte=Zellmittelpunkte'
Abstand_Zellmittelpunkte=Schichtdicke/2:Schichtdicke:H;
Gamma=-0.0098;
gamma=-0.0065;
%@comment Ich lasse mir den Tagesgang fuer den Waermestrom berechnen
Waermestrom = Tagesgang_Waermestrom(Waermefluss_nachts);
%@comment Temperaturprofil fuer eine Standartatmosphaere
T_standart=T_0+gamma.*Hoehe;
T = T_0 + gamma*Zellmittelpunkte;
%@comment Hier beginne ich meine "große" Schleife: In jeden Durchlauf wird
%das entsprechende Element für den Waermestrom zu dieser Stunde und die
%Zeit gewaehlt, und alle anderen Parameter damit neu berechnet. Beim ersten
%Durchlauf ist die Temperatur noch gleich dem Profil fuer die
%Standartatmosphaere, da wir noch kein dT haben, aber ab dem 2ten Durchlauf
%wird vom "aktuellen" Temperaturprofil ausgegangen.
for w=1:24
%@comment Ich berechne die Druecke an den Schichtgrenzen
p = Druck_Barometrische_HF(T_standart)
%@comment Ich berechne die Temperaturaenderung
dT=Temperaturaenderung_berechnen(Waermestrom,Zeit,p,w)
%@comment Nun berechne ich die Masse
Masse=Masse_berechnen(p);
%@comment Ich ueberpruefe auf eventuell vorhandene Ueberadiabasien und
%lasse diese gegebenenfalls abbauen
[dT_Zelle_ausgeglichen] = Temperaturausgleich_vertikal(1,dT,Masse,Zellmittelpunkte)
%@comment Neues Temperatur-Profil nach jedem Durchlauf, mit dem jeder Durchlauf wieder starten soll
T_Profil=T+dT_Zelle_ausgeglichen;
%@comment Ich bekomme die Werte in der Mitte der Schichten als Ergebnis, brauche für die Druckberechnung aber die Werte an den Schichträndern, und
%die bekomme ich indem ich den Mittelpunkt zwischen den Werten ausrechne. Nun verliere ich ja einen Wert, nämlich den Bodenwert, da ich mittle -
%und da habe ich mir folgendes überlegt: ich weiß wie weit die einzelnen Werte auseinander liegen, also kann ich den Gradient gamma_neu zwischen der
%Obergrenze der untersten Schicht und ihrem Mittelwert ermitteln (also die zu- bzw. Abnahme mit der Höhe) und so durch Multiplikation mit der halben
%Schichthöhe quasi zurückrechnen:
%@comment Ich benenne diesen neuen Vektor wieder T_standart, damit der
%oben definierte gleichnamige Vektor mit diesem überschrieben wird
T_standart(1)=T_Profil(1)-gamma_unten*(Schichtdicke/2);
%@comment Ich benenne diesen neuen Vektor wieder T_standart, damit der
%oben definierte gleichnamige Vektor mit diesem überschrieben wird
T_standart(1)=T_Profil(1)-gamma_unten*(Schichtdicke/2);
wird mein Vektor mit den Zellmittelpunkten plötzlich eine 1x0 Matrix, damit wird auch alles andere falsch. Warum? Sieht jemand den Fehler? Ich wollte dass unten der Vektor T_standar imer neu berechnet wird, und eben immer neu überschrieben! Ich glaube das funktioniert nicht, weiß jemand wieso?
Und noch etwas: Wie schaffe ich es dass ich nicht 24 figures bekomme, sondern alle in einem plott landen? Ich habe gelesen das funktioniert wenn ich vor dem end der Schleife hold on schreibe..? Und wie mache ich es, dass jede neu eingetragene Linie eine andere Farbe bekommt?
Die Frage ist nicht klar.
Wo fügst Du den zusätzlichen Code denn ein?
Er verändert die Variable "Zellmittelpunkte" gar nicht, wieso nimmst du also an, dass die Auswirkungen daher kommen? Immerhin ist "Zellmittelpunkte" eine globale Variable und könnte von überall her geändert werden!
Das "%@comment" mach den Code ziemlich unübersichtlich.
Zitat:
Wie schaffe ich es dass ich nicht 24 figures bekomme, sondern alle in einem plott landen? Ich habe gelesen das funktioniert wenn ich vor dem end der Schleife hold on schreibe..? Und wie mache ich es, dass jede neu eingetragene Linie eine andere Farbe bekommt?
Neue Frage, neuer Thread. Siehe: "hold all".
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.