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

Einhüllende

 

victor
Forum-Anfänger

Forum-Anfänger


Beiträge: 44
Anmeldedatum: 25.08.08
Wohnort: Maastricht
Version: R2007b
     Beitrag Verfasst am: 10.09.2008, 17:15     Titel: Einhüllende
  Antworten mit Zitat      
Hallo Zusammen!

Ich versuche zurzeit über einen Graphen eine einhüllende Kurve zu legen. Mit der Hilbert-Transformation klappt dass nicht so gut, da mein Graph leider "zick-zack" hoch und runter geht. Shocked

Ich versuch zurzeit über die Werte des Graphen zu interpolieren, leider blicke ich da auch nicht ganz durch Embarassed Es wäre gut, über die Spitzen des Signals eine Einhüllende zu legen um einen schönen Verlauf einer Linie zu bekommen.

Hat da jemand vielleicht ne Idee??
victor

graf.jpg
 Beschreibung:

Download
 Dateiname:  graf.jpg
 Dateigröße:  21.18 KB
 Heruntergeladen:  1141 mal
Private Nachricht senden Benutzer-Profile anzeigen


Schrank
Forum-Century

Forum-Century


Beiträge: 203
Anmeldedatum: 10.07.08
Wohnort: Berlin
Version: ---
     Beitrag Verfasst am: 10.09.2008, 18:09     Titel:
  Antworten mit Zitat      
Hallo,
ich weiß der Code ist hässlich, aber vielleicht geht er trotzdem in die von dir gewollte Richtung
Code:

clc;
clear;
Daten = rand(1,1000);
x = 1:1000;
%lokale Maxima finden
maxi = [];
maxiInd = [];
i=2;
while 1
    while Daten(i) >= Daten(i-1)
        if i == length(Daten)
            break
        end
        i = i + 1;

    end
    maxiInd(end+1) = i;
    maxi(end+1) = Daten(i);
    if i == length(Daten)
        break
    end
    i = i + 1;
    if i == length(Daten)
        break
    end

end
%lokale Minima finden
mini = [];
miniInd = [];
i=2;
while 1
    while Daten(i) <= Daten(i-1)
        if i == length(Daten)
            break
        end
        i = i + 1;
        if i == length(Daten)
            break
        end
    end
    miniInd(end+1) = i;
    mini(end+1) = Daten(i);
    if i == length(Daten)
        break
    end
    i = i + 1;
    if i == length(Daten)
        break
    end

end
%glätten, weil sieht ja so doof aus
 mini = sgolayfilt(mini,4,5);
 maxi = sgolayfilt(maxi,4,5);
%plotten
plot(x, Daten, '-y');
hold all
plot(miniInd, mini);
plot(maxiInd, maxi);
hold off


Mit ein bißchen denken kann man das ganze wahrscheinlich in 5 Zeilen Code packen... aber als Denkanstoß vielleicht in Ordnung.
Gruß Schrank
Private Nachricht senden Benutzer-Profile anzeigen
 
victor
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 44
Anmeldedatum: 25.08.08
Wohnort: Maastricht
Version: R2007b
     Beitrag Verfasst am: 10.09.2008, 18:14     Titel:
  Antworten mit Zitat      
Danke für deine Mühe!! Das sieht schon mal gut aus, ich werds mal ausprobieren!! Very Happy
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 - 2024 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.