联系方式

您当前位置:首页 >> Python编程Python编程

日期:2024-12-19 09:50

FN6806: Object Oriented Programming II

Problems - Set 3

Question 3-1

Implement Vasicek model for interest rate simulation


• Use Euler-Maruyama method to generate the paths. returned value is a tuple: 1) the end

rates of all paths, 2) the sum of all rates of all paths (except the starting   0

).

• You could use either vector or valarray for the result.

auto vasicek(double sd, double kappa, double r_mean, double r0,

double T, int paths, int steps, mt19937 &gen) {

double dt = T / steps;

vector<double> sum_rates(paths);

vector<double> end_rates(paths);

^^.

return make_tuple(end_rates, sum_rates);

}

auto vasicek_valarray(double sd, double kappa, double r_mean,

double r0, double T, int paths, int steps, mt19937 &gen) {

double dt = T / steps;

valarray<double> sum_rates(0.0, paths);

valarray<double> end_rates(r0, paths);

^^.

return make_tuple(end_rates, sum_rates);

}

• Below is my test code and result as reference. You could adapt it to test your result.

seed_seq seed{90127};

auto mtgen = mt19937{seed};

auto [end_rates, sum_rates] =

vasicek(sd, kappa, r_mean, r0, T, 20'000, int(0.5 * 365),

mtgen);

auto end_rates_avg =

accumulate(end_rates.begin(), end_rates.end(), 0.0) /

end_rates.size();

1auto sum_rates_avg =

accumulate(sum_rates.begin(), sum_rates.end(), 0.0) /

sum_rates.size();

cout ^< end_rates_avg ^< ", " ^< sum_rates_avg ^< "\n";

^/ 0.0495695, 9.05915

mtgen.seed(seed);

auto [end_rates2, sum_rates2] =

vasicek_valarray(

sd, kappa, r_mean, r0, T, 20'000, int(0.5 * 365), mtgen);

end_rates_avg =

accumulate(end_rates2.begin(), end_rates2.end(), 0.0) /

end_rates2.size();

sum_rates_avg =

accumulate(sum_rates2.begin(), sum_rates2.end(), 0.0) /

sum_rates2.size();

cout ^< end_rates_avg ^< ", " ^< sum_rates_avg ^< "\n";

^/ 0.0495608, 9.06302

2Question 3-2

A simulator for event-driven backtesting.

There are two approaches in backtesting trading strategy: vectorized and event-driven.

The vectorized approach is the most common one and consists of simulating the strategy directly

on historical data. The price series are loaded as vectors and we use vectorized operations

for both the trading strategy and the performance metrics.

For example, we can have a buy signal whenever Close > Open and sell signal whenever Close

< Open, and porformance metric is the 1-day lagged signal times the return of the next day

(assuming buy at next day Open). It’s fast to implement such backtesting. However, if we want

to simulate for adding the number of orders when we have 2nd buy signal, we need to modify

the algorithm but it will not be easy. Vectorized method can not simulate the execution of

orders realistically. At all, it is a simpliffed approach towards backtesting.

The event-driven approach is more sophiscated as it simulates the strategy as if it was executed

in real-time. The price series are loaded as a stream of ticks and the strategy is executed on

each tick, and various modules can be added at both sides: the exeuction side and the strategy

side. For example, the exeuction could simulation the price slippage of the execution, the

strategy side could simulate for stop loss and dynamic order sizing depends on past performance.

The event-driven approach is more ffexible and more realistic, but it is more difffcult

to implement.

In this exercise, you will read the source code of an event-driven simulator and try to understand

how it works. You will need to document 5 places that exception could occur, what is the

error message, what could be the cause of the error and what could be the exception handling.

Create a ffle exceptions.txt and write down your answers.

This project will also be used in the Final quiz, so you should get familiar with it.

About the simulator:

• The author of this repo only made a start so it’s just a partial implementation. You would

ffnd many rough edges: incomplete and incorrect.

• In one-line explaination, it runs over a CSV ffle with each line as a tick. The trading

strategy acts on the tick data and perform buy/sell operations.

• All cpp ffles are in \src

• All hpp ffles are in \include

Use Replit tools

• When you press Run button, the program shasll run in the Console. However, you need

to scroll back in history for the output.

• You could use Code Search (Shortcut: Ctrl+Shift+F) to search for text in the project.

• For manual mode, usually you don’t need to, you could open the Shell tool to type make

for compilation and then type ./main to run the program. make shall auto-detect any

recently changed ffle and recompile the program. If you want to recompile every thing,

make clean and then make.

3Aku’s class organization

• I created a simple chart to show the class organization of Aku’s simulator. You could use

it as a reference.

4


相关文章

【上一篇】:到头了
【下一篇】:没有了

版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:821613408 微信:horysk8 电子信箱:[email protected]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:horysk8