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

reshape - Fehler?

 

thomas0815
Forum-Century

Forum-Century


Beiträge: 153
Anmeldedatum: 13.05.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 01.06.2010, 15:01     Titel: reshape - Fehler?
  Antworten mit Zitat      
Hallo ich benutze die reshape Funktion in einem Programm, die zu einem Fehler führt. Ich weiß nicht woran das liegt.

Die Fehlermeldung:

To RESHAPE the number of elements must not change.

und hier der code:

Code:
x = zeros(n,T);
    v = [zeros(n,T) v];
    for t=T:-1:1                            
        [n,m]=size(f);
        [v(:,t),x(:,t)]=max(f+delta*reshape(v(:,t+1),n,m),[],2);  
        i=n*(x(:,t)-1)+(1:n)';
        fstar = f(i);


Viele Grüße,
Thomas
Private Nachricht senden Benutzer-Profile anzeigen


denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 01.06.2010, 15:45     Titel:
  Antworten mit Zitat      
Anzahl der Elemente in Ursprungsmatrix, muss der Anzahl der Elemente
in Resultat-Matrix entsprechen

Code:


% also Anzahl Elemente in v muss n*m ergeben
reshape(v,n,m)

 



noch zu Verdeutlichung
Code:


v=[1 2 3 4 5 6]
n  =3
m =2
% 6 Elemente in v, n*m ergibt 6
%    
if numel(v) == n*m
  disp('so würde reshape funktionieren')
else
 disp('so würde reshape Fehler ausgeben')
end



v=[1 2 3 4 5 6 7]
n  =3
m =2
% 7 Elemente in v, n*m ergibt aber 6  
% also funktioniert es nicht mehr
if numel(v) == n*m
  disp('so würde reshape funktionieren')
else
 disp('so würde reshape Fehler ausgeben')
end
 


PS: Du muss mal überprüfen ob du an richtigen Stelle Schleifenindex verwendest. Vielleicht wolltest Zeile statt Spalte verwenden.
Oder ob Spalte wirklich genügend Elemente enthält.
Private Nachricht senden Benutzer-Profile anzeigen
 
thomas0815
Themenstarter

Forum-Century

Forum-Century


Beiträge: 153
Anmeldedatum: 13.05.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 01.06.2010, 16:20     Titel:
  Antworten mit Zitat      
Hallo, aber das müsste doch funktionieren

Code:
x = zeros(n,T);
    v = [zeros(n,T) v]
    for t=T:-1:1                              
       [n,T]=size(f);
        valmax(v,f,delta)=max(f+delta*reshape(v,n,T+1),[],2);
       [v(:,t),x(:,t)] = valmax(v(:,t+1),f,delta)


v entspricht nxT+1; deswegen müsste die Anzahl der Elemente doch mit der Matrizendimension übereinstimmen. Aber ich bekomme immernoch die Fehlermeldung!?
Private Nachricht senden Benutzer-Profile anzeigen
 
denny
Supporter

Supporter



Beiträge: 3.853
Anmeldedatum: 14.02.08
Wohnort: Ulm
Version: R2012b
     Beitrag Verfasst am: 01.06.2010, 16:33     Titel:
  Antworten mit Zitat      
Ich hab ja keine Ahnung was du überhaupt machst, vielleicht sollst du mal erklären was du überhaupt versuchst zu machen,
denn dein Code sieht im Moment nicht besonders klar aus.

Du erzeugst doch V über ZEROS? oder wie kommt bei dir alles zu Stande? apropos was soll v=[zeros(n,T) v]?
Code:

v= zeros(n,T)
% warum sollte dann n*T == n*(T+1) gleich sein
reshape(v,n,T+1)
 
Private Nachricht senden Benutzer-Profile anzeigen
 
thomas0815
Themenstarter

Forum-Century

Forum-Century


Beiträge: 153
Anmeldedatum: 13.05.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 01.06.2010, 19:58     Titel:
  Antworten mit Zitat      
Hallo,

also:

Code:
v = [zeros(n,T) v]
kommt zustande, weil ich zunächst eine Nullmatrix erzeuge, an die noch ein Spaltenvektor mit vorher definierten Werten angehängt wird. Deswegen kommt es hier auch zu
Code:
valmax(v,f,delta)=max(f+delta*reshape(v,n,t+1),[],2);
dem T+1. Deswegen ist mir an sich unklar, warum das mit den Dimensionen nicht passt.

Aber was möchte ich machen: Das f im Code entspricht einer Matrix:

Code:
    0     0     0     0
  -Inf     3     3     3
  -Inf  -Inf     6     6


mit
Code:
[v(:,t),x(:,t)] = valmax(v(:,t+1),f,delta)


und

Code:
valmax(v,f,delta)=max(f+delta*reshape(v,n,t+1),[],2);


sollen zunächst die Matrizen f und (v*delta) miteinander addiert werden. Damit die Matrizen zusammenpassen verwende ich reshape. Dann soll aus jeder Spalte der sich so ergebenden Matrix der Maximalwert gewählt werden und zum einen als v(:,t) ausgegeben werden und zum anderen als x(:,t) ausgegeben werden (x wird über eine weitere Funktion bestimmt). Da es sich um eine Schleife von T:-1:1 handelt soll mit
Code:
aus dem Bereits bestimmten v der nächstfolgende Wert für v bestimmt werden vorhergehende Wert (v(n,t+1)->v(n,t))

Ich bin wie immer über alle Hinweise dankbar.

Viele Grüße,

Thomas

[/code]
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 01.06.2010, 22:23     Titel:
  Antworten mit Zitat      
Hallo,

verwende doch den Debugger, um dir einen Überblick zu verschaffen.
Vielleicht einen Haltepunkt in die entsprechende Zeile, und dann size auf das Argument anwenden. So solltest du dem selbst auf die Spur kommen können.

Grüße,
Harald
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.