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

For-Schleife wird nicht ausgeführt - Euler Methode

 

Arjen10
Forum-Anfänger

Forum-Anfänger


Beiträge: 10
Anmeldedatum: 12.06.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 12.06.2015, 20:59     Titel: For-Schleife wird nicht ausgeführt - Euler Methode
  Antworten mit Zitat      
Hallo und Guten Abend,

bin neu im Forum und auch nicht so lange mit Scilab dabei. Ich habe zwei for-Schleifen erzeugt, die leider nicht laufen. Ich habe bisher den Fehler nicht gefunden. Das Ziel ist es, die Euler-Diskretisierung durchzuführen für das Heston-Modell.

Code:
% Fehlercode
   !--error 21
ungültiger Index.
at line      23 of function Log_EULER called by :  
path = Log_EULER  (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m);
at line      62 of exec file called by :    
exec('C:\Users\...\Desktop\MC and Euler Method\LOG EULER.sce', -1)

 



Der Quellcode lautet:
Code:
%
// Log-Euler Method
funcprot(0);
clf;
clc;



function path = Log_EULER (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m)
   

    delta_t = T/m;
    Z_1= grand(m,1,'nor',0,1);
    Z_sigma = Z_1;
    sigma =zeros(m,1);
    sigma(1,1)=sigma0;
    S=zeros(m,1);
    S(1,1)=S0;
   
    //volatility discretization
   
    for i =2:m
        sigma(i)= sigma(i-1) + kappa*(theta - truncation (sigma(i-1)))*delta_t + vartheta*sqrt(truncation (sigma(i-1)))*sqrt(delta_t)*Z_sigma(i);
    end
    Z_2= grand(m,1,'nor',0,1);
    Z_S= rho*Z_sigma + sqrt(1-rho)*Z_2;
   
    //stock price discretization
   
    for i =2:m
    log(S(i))= log(S(i-1)) +  delta_t*(mu - 0.5*truncation (sigma(i)))+ sqrt(truncation (sigma(i)))*sqrt(delta_t)*Z_S(i);
    end
   
   
    // Take exponential
    path = exp(log(S));



endfunction

// Trunction function

function y = truncation(a)
    y=max(a,0)
endfunction


// Test parameters.
S0 = 100;
mu = 0.05;
sigma0 = 0.04;
kappa = 1.2;
T = 1;
m = 250;
N=10;
vartheta = 0.3;
theta = 0.04;
rho = -0.5,

//Generate one sample

path = Log_EULER  (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m);


 



Ich hoffe, dass ich es verständlich machen konnte.

Danke im Voraus.


Grüße,

Arjen
Private Nachricht senden Benutzer-Profile anzeigen


Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 12.06.2015, 22:28     Titel: Re: For-Schleife wird nicht ausgeführt - Euler Methode
  Antworten mit Zitat      
Hallo Arjen10,

Welches ist denn die Zeile 23? Es ist nicht ganz einfach das hier im Forum im Code abzuzählen.
Ist es diese Zeile?
Code:
       sigma(i)= sigma(i-1) + kappa*(theta - truncation (sigma(i-1)))*delta_t + vartheta*sqrt(truncation (sigma(i-1)))*sqrt(delta_t)*Z_sigma(i);

Sagt Dir "ungültiger Index" etwas dabei?

Ich habe noch nicht mit Scilab gearbeitet, aber ich vermute es gibt Möglichkeiten zum Debuggen. Um welche Variable geht es denn?

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
Arjen10
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 10
Anmeldedatum: 12.06.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 13.06.2015, 05:46     Titel:
  Antworten mit Zitat      
Hallo Jan,

danke für die schnelle Antwort.

Zeile 23 ist die Zeile mit den log-Preisen.

Code:
% Zeile 23

   for i =2:m
 Zeile 23 ----   log(S(i))= log(S(i-1)) +  delta_t*(mu - 0.5*truncation (sigma(i)))+ sqrt(truncation (sigma(i)))*sqrt(delta_t)*Z_S(i);
    end
 

In Zeile 62 ist auch ein Fehler angezeigt


Code:
% Zeile 62


path = Log_EULER  (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m);

 



Ich weiß leider nicht, was ungültiger Index bedeutet. Bei scilab werden die Fehler nicht direkt angezeigt, zumindest in meiner Einstellung nicht.


Ich hoffe dies kann mehr helfen.


Danke.

Grüße,

Arjen10
Private Nachricht senden Benutzer-Profile anzeigen
 
Arjen10
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 10
Anmeldedatum: 12.06.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 14.06.2015, 20:47     Titel:
  Antworten mit Zitat      
Hi,

Das log wurde nicht durchgeführt. Daher musste es anders benannt werden.


Code:
% Lösung
    for i =2:m
        log_S(i)= log(S(i-1)) +  delta_t*(mu - 0.5*truncation (sigma(i)))+ sqrt(truncation (sigma(i)))*sqrt(delta_t)*Z_S(i);
        S(i)=exp(log_S(i));
   // log(S(i))= log(S(i-1)) +  delta_t*(mu - 0.5*truncation(sigma(i))) + sqrt(truncation(sigma(i)))*sqrt(delta_t)*Z_S(i);
    end
   
   
    //
    path = S;

 


Grüße,

Arjen10
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.