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

Stoppuhr programmieren zur Erfassung der Laufzeit vom Code

 

Arjen10
Forum-Anfänger

Forum-Anfänger


Beiträge: 10
Anmeldedatum: 12.06.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 16.06.2015, 12:53     Titel: Stoppuhr programmieren zur Erfassung der Laufzeit vom Code
  Antworten mit Zitat      
Hallo in die Runde,

ich möchte gerne die geschriebenen scilab-codes mit einer Stoppuhr ergänzen, sodass man weiß, wie lange die Laufzeit des Codes gedauert hat.
Es sollte sobald der code ausgeführt anfangen, die Zeit zu erfassen und stoppen, wenn es vorbei ist.

So könnte man verschiedene Verfahren bezüglich ihrer Laufzeit beurteilen.

Habe gerade gar keinen Ansatzpunkt. Ist dies überhaupt möglich bei Scilab oder generell bei Matlab ?


Danke im Voraus.


Grüße,

Arjen10
Private Nachricht senden Benutzer-Profile anzeigen


Winkow
Moderator

Moderator



Beiträge: 3.842
Anmeldedatum: 04.11.11
Wohnort: Dresden
Version: R2014a 2015a
     Beitrag Verfasst am: 16.06.2015, 12:57     Titel:
  Antworten mit Zitat      
https://help.scilab.org/doc/5.3.3/en_US/tic.html
grüße
_________________

richtig Fragen
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: 16.06.2015, 17:51     Titel: Zeit stimmt nicht
  Antworten mit Zitat      
Danke für die schnelle Antwort. Allerdings stimmt die Zeit noch nicht.

Code:
% Programm


// Log-Euler Method //This code simulates paths from the Heston using the exact Log-Euler method
tic()
funcprot(0);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 =ones(m,1);
    sigma(1,1)=sigma0;
    S=ones(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);
        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
   
   
    // Take exponential
    path = 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;   // terminal date
m = 250; // controls time grid
N=10; // number of simulations
vartheta = 0.3;
theta = 0.04;
rho = -0.5,
path_memory_plot = ones(m,N);
path_memory = ones(m,N);

//Generate N=10 different paths for plotting
for j=1:N
   path_memory_plot(:,j) = Log_EULER (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m);
end
x_arg=linspace(0,1,m);
plot(x_arg',path_memory_plot);
xlabel('Discretized time');
ylabel('Stock price');
title('Exact Log-Euler Method for the Heston model');

toc();
t=toc();

//Generate N=10.000 different paths for simulation

for j=1:10000
   path_memory(:,j) = Log_EULER (S0, sigma0, mu, kappa, theta, vartheta,rho,T,m);
end

disp('Processing time in seconds: "+string(t))




 


Es werden "Processing time in seconds: 0.485 " angezeigt.

In der Command-Beschreibung heißt es auch Sekunden

"number of seconds since last call to tic() (Precision in order of millisecond"


Danke im Voraus.
Grüße,

Arjen10
Private Nachricht senden Benutzer-Profile anzeigen
 
Andreas Goser
Forum-Meister

Forum-Meister


Beiträge: 3.654
Anmeldedatum: 04.12.08
Wohnort: Ismaning
Version: 1.0
     Beitrag Verfasst am: 17.06.2015, 07:26     Titel:
  Antworten mit Zitat      
Die Fragestellung ist ja meistens nicht pure Neugierde, sondern man möchte möglichst schnellen Code. In MATLAB gibt es einen Profiler, der einem hilft die Bottlenecks zu identifizieren. Der Technische Support berät gerne wie man Code beschleunigt. Weiterhin gibt es viele Möglichkeiten des parallelen und verteilten Rechnens.

Andreas
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
Winkow
Moderator

Moderator



Beiträge: 3.842
Anmeldedatum: 04.11.11
Wohnort: Dresden
Version: R2014a 2015a
     Beitrag Verfasst am: 17.06.2015, 07:56     Titel:
  Antworten mit Zitat      
Zitat:
. Der Technische Support berät gerne wie man Code beschleunigt.
machen die das auch wenn es um scilab/xcos geht?
_________________

richtig Fragen
Private Nachricht senden Benutzer-Profile anzeigen
 
Yann Debray

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 17.06.2015, 11:13     Titel:
  Antworten mit Zitat      
Hallo zusammen,

Wenn es um Scilab/Xcos geht, kann Scilab Enterprises dabei helfen.
Wir sind das Entwicklungsteam von Scilab, und ich bin für die Firma in Deutschland zuständig.

Wir stehen für solche Frage jeder Zeit zur Verfügung.
--

Yann DEBRAY (Dipl. Ing.)
Mobile Germany: +49 (0)157 51 49 49 15
http://www.scilab-enterprises.com
 
Andreas Goser
Forum-Meister

Forum-Meister


Beiträge: 3.654
Anmeldedatum: 04.12.08
Wohnort: Ismaning
Version: 1.0
     Beitrag Verfasst am: 17.06.2015, 13:05     Titel:
  Antworten mit Zitat      
Der Nutzer hat ja ganz allgemein geschrieben "Ist dies überhaupt möglich bei Scilab oder generell bei Matlab ?"

Andreas
Private Nachricht senden Benutzer-Profile anzeigen E-Mail senden
 
Arjen10
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 10
Anmeldedatum: 12.06.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 17.06.2015, 14:07     Titel:
  Antworten mit Zitat      
Hallo,

Da ich ich zuletzt ein Beispiel gepostet habe, meinte ich das schon konkret bezogen auf das Beispiel. Die Zeit wird falsch angezeigt. Fehlt da vielleicht noch was im Code ?

Gruß,

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.