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

Abbruch in verschachtelter for-Schleife

 

aniara

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 18.02.2011, 11:28     Titel: Abbruch in verschachtelter for-Schleife
  Antworten mit Zitat      
Hallo an alle,

ich habe ein kleines problem mit einem Abbruch einer for-Schleife. Die Lösung ist bestimmt sehr leicht, aber ich seh sie einfach nicht.

Also ich habe mehrere for-Schleifen in einander verschachtelt (könnte man bestimmt auch einfacher schreiben, aber so geübt bin ich noch nicht) und möchte jetzt, dass ALLE Schleifen abbrechen wenn möglich.

Mein Programm durchläuft zwar die if-Anweisung mit dem break-Befehl, stoppt dann aber nicht sondern läuft die for-schleifen weiter durch.

Hier der Code:
Code:

for r = 50:55
    y_mu = zeros(1,n-r+1);
    for a = 1:(n-r+1)
        y = 0;
        for b = a:(a+r-1)
            y = y + X(b);
        end;
        y_mu(a) = 1/r * y;
    end;
    figure
    plot(y_mu)
    for m = 1:(n-r+1)
        for l = 1:(n-r+1)
            if y_mu(m) - y_mu(l) > s/r;
                break;
            end;
        end;
    end;
end;
 


Ich hoffe ihr könnt mir helfen. Und vielen Dank schonmal im voraus.
gruß aniara


Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 18.02.2011, 17:40     Titel: Re: Abbruch in verschachtelter for-Schleife
  Antworten mit Zitat      
Hallo aniara,

Eine Möglichkeit wäre es, das Programm in eine eigene Funktion zu packen und diese per RETURN zu verlassen.
Eine weitere Methode wäre die Vektorisierung der beiden Schleifen:
Code:
for r = 50:55
    y_mu = zeros(1,n-r+1);
    for a = 1:(n-r+1)
        y = 0;
        for b = a:(a+r-1)
            y = y + X(b);
        end;
        y_mu(a) = 1/r * y;
    end;
    figure
    plot(y_mu)
   
    tmp = bsxfun(@minus, y_mu, transpose(y_mu));
    if any(tmp > s/r)
       break;
    end
end

Gruß, Jan
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.