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

Auf Werte nach NaN zugreifen

 

andi_0815
Forum-Anfänger

Forum-Anfänger



Beiträge: 26
Anmeldedatum: 01.03.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 06.05.2010, 18:26     Titel: Auf Werte nach NaN zugreifen
  Antworten mit Zitat      
Hallo,

ich habe eine Matrix, ungefähr so:

Code:

NaN   1     2     NaN
NaN   4     8     3
5     7     9     13
15    28    12    18
 


Ich möchte die kummulative Summe jeder Spalte haben, was generell kein Problem ist, aber die Summe soll erst ab der ersten Zeile berechnet werden, in der kein NaN mehr steht.
Also, wie sage ich Matlab "in der ersten Zeile nach dem NaN beginnen"?

Bin für alle Vorschläge offen Very Happy
Grüßele
Private Nachricht senden Benutzer-Profile anzeigen


denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 06.05.2010, 18:39     Titel:
  Antworten mit Zitat      
Hallo

ersetze NaN doch durch die Nullen

Code:

A=[NaN   1     2      NaN
NaN   4     8     3
5     7     9     13
15    28    12    18 ]

B= A
B(isnan(A))=0

cumsum(B)
 
Private Nachricht senden Benutzer-Profile anzeigen
 
derOli
Forum-Meister

Forum-Meister


Beiträge: 579
Anmeldedatum: 19.03.08
Wohnort: Leipzig
Version: 2010a
     Beitrag Verfasst am: 06.05.2010, 18:57     Titel:
  Antworten mit Zitat      
Hi,

reicht der Vorschlag von Denny für dein Problem oder gibt es auch sowas:

Code:

A=[NaN   1     2       NaN
NaN   4     Nan     3
5     7     9     13
15    28    12    18 ]
 


Wo dann in der 3. Spalte nur die 9 und die 12 addiert werden sollen und nicht die 2?

Viele Grüße,

der Oli
Private Nachricht senden Benutzer-Profile anzeigen
 
lilov
Forum-Century

Forum-Century


Beiträge: 193
Anmeldedatum: 05.05.10
Wohnort: Bremerhaven
Version: ---
     Beitrag Verfasst am: 06.05.2010, 18:59     Titel:
  Antworten mit Zitat      
Versuch's damit:

CumSum = cumsum(~isnan(A))

Gruß,

Hristo
Private Nachricht senden Benutzer-Profile anzeigen
 
andi_0815
Themenstarter

Forum-Anfänger

Forum-Anfänger



Beiträge: 26
Anmeldedatum: 01.03.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 08:22     Titel:
  Antworten mit Zitat      
Hi,
sorry, dass ich jetzt erst antworte...
Das mit den Nullen hab ich schon probiert, aber ich brauche die NaNs nach Umrechnung in die CumSum wieder, drum hätt ichs gern, dass sie drin bleiben. Denn ich habe Messwerte dabei die "0" sind und die will ich nicht NaNen Very Happy
Es sollten keine NaNs zwischendrin zu finden sein.

Der CumSum = cumsum(~isnan(A)) -Vorschlag funktioniert leider nicht so ganz. Da kommen furchtbar komische Zahlen bei raus... Shocked

Grüßele
Andrea
Private Nachricht senden Benutzer-Profile anzeigen
 
lilov
Forum-Century

Forum-Century


Beiträge: 193
Anmeldedatum: 05.05.10
Wohnort: Bremerhaven
Version: ---
     Beitrag Verfasst am: 07.05.2010, 08:59     Titel:
  Antworten mit Zitat      
oops,

versuch's mit
CumSum = cumsum(A(~isnan(A)));

hab ein A vergessen, sorry:)

Hristo
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 07.05.2010, 09:10     Titel:
  Antworten mit Zitat      
Hallo

dann muss man die NaN wieder zurückkopieren
Code:


A=[NaN   1     2      NaN
NaN   4     8     3
5     7     9     13
15    28    12    18 ]

B= A
B(isnan(A))=0

B = cumsum(B)
B(isnan(A))=NaN
 
Private Nachricht senden Benutzer-Profile anzeigen
 
andi_0815
Themenstarter

Forum-Anfänger

Forum-Anfänger



Beiträge: 26
Anmeldedatum: 01.03.10
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 07.05.2010, 09:22     Titel:
  Antworten mit Zitat      
Danke,

ich probier deine Idee noch aus, habe aber jetzt eine andere Lösung gefunden. Ich geb zu, nicht besonders matlab-mäßig, aber es funktioniert. Ich hab einfach die NaNs ans Ende gepackt und die CumSum gebildet, dann wieder die NaNs an den Anfang der Datei und fertig Very Happy

Cool, wa?! Wink
Private Nachricht senden Benutzer-Profile anzeigen
 
Fourier
Forum-Guru

Forum-Guru


Beiträge: 329
Anmeldedatum: 05.04.10
Wohnort: Karlsruhe
Version: 2009b
     Beitrag Verfasst am: 07.05.2010, 09:25     Titel:
  Antworten mit Zitat      
hallo,
ich hab mal so versucht scheint zu funktionieren:
Code:
A=[NaN   1     2       NaN
NaN   4     NaN     3
5     7     9     13
15    28    12    18 ];

len_A=size(A,2);

for i=1:len_A
    x=find(isnan(A(:,i)));
    if(numel(x)~=0)
        A(:,i)=[A(1:x(end),i);cumsum(A(x(end)+1:end,i))];
    else
        A(:,i)=cumsum(A(:,i));
    end
end
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.