python数据可视化分析速成笔记_2-2_布朗运动/几何布朗运动(伊藤过程)实现的demo[通俗易懂]

python数据可视化分析速成笔记_2-2_布朗运动/几何布朗运动(伊藤过程)实现的demo[通俗易懂]第二天/第三天目标_不分先后:实践部分:重点熟悉:numpy,scipy,matplotlib,random,https://docs.spyder-ide.org/实际上如果是熟悉matla

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

第二天/第三天

 

目标_不分先后:

 实践部分:   

  实际上如果是熟悉matlab操作的大神们应该改会发现这些包和matlab里面的是相通的

  python 大杂烩实锤

  • 重点
    实现问题训练:

    • 简单的方程求解曲线参数,模拟图像
    • 最小二乘法拟合,回归模型,

   了解微分方程模拟

    • 解常微分方程,模拟图像
    • 解偏微分方程,模拟图像

    时间关系,看看实现例子,然后自己写

    • 布朗运动
    • 维纳过程
    • 几何布朗运动(ito模拟)
  • 运用以上模型直接模拟归奥价格走势

  理论部分:  

  • 复习,推导,理解,几何布朗运动模型,伊藤引理(如果时间不够,跳过这一步)
    1. 期权与股票的性质—
    2. 期权的交易策略
    3. 期权二叉树(BSM模型原理的基础和推导就是基于期权二叉树模拟的随机游走过程

              知乎专栏——AI和金融模型——第一篇文章开始

    重点:

    1. 维纳过程和伊藤引理
    2. BSM,几何布朗运动与布朗运动

时间:24h

 反馈:

  • 总体任务完成情况:
    • 大致完成了基本过程,还剩下一个ito没有实现推导,理论没有完全看完,
  • 难点:
    • 主要是函数用起来不熟练,而且对函数的目的不了解
    • 微积分不熟,对公式的本质,推导过程理解很浅薄。

一开始不知道用函数怎么实现,还以为布朗运动模拟运动的模拟要积分,实际上运用的是正态分布+时间函数求和,

因为时间点是离散的,用定义法求积分,

dx = a*dt  + b*dz,∑a*dt = T,dz=e*sqrt(dt),e~(0,1),∑dz=(sqrt(dt))*∑ e

伊藤引理也是这样,只是它的积分式是微分方程,由公式:dS/S=u* dt+e* o* sqrt(dt),求 S ,需要用微分方程来推导

最后会得到几何布朗运动的基本公式

 

  • 收获与反思:
    • 现在可以实现布朗运动/几何布朗运动模拟股市图像,数据还没有找
    • 更加深刻地理解了公式地推导过程
    • 加深了对正态分布的理解,复习了微分方程
    • 实践带动理解
    • 背函数啥的不如直接看大佬们的代码,一行一行理解,反正用的多的就那几个

代码实现:

python数据可视化分析速成笔记_2-2_布朗运动/几何布朗运动(伊藤过程)实现的demo[通俗易懂]
python数据可视化分析速成笔记_2-2_布朗运动/几何布朗运动(伊藤过程)实现的demo[通俗易懂]

 1 # -*- coding: utf-8 -*-
 2 """
 3 Created on Mon May  4 20:43:06 2020
 4 
 5 @author: 10913
 6 """
 7 
 8 
 9 import numpy as np
10 import matplotlib.pyplot as plt
11 
12 
13 
14 '''
15 
16 
17 几何布朗运动:
18     St=S0*exp(ut)
19     St=S0*exp(u t+o e sqrt(dt))
20     
21     St=S0*exp(a t+b z)
22 
23 
24 '''
25 D=250   #250个交易日
26 T=1.0   #总时间1年
27 dt=T/D   #单位时间
28 
29 '''
30 另一种写法
31 S=np.zeros((M+1,I))
32 
33 S[0]=S0 #定义S[0]=S0
34 
35 for t in range(1,M+1):
36 
37     S[t]=S[t-1]*np.exp(mean*dt+sigma*np.sqrt(dt)*np.random.standard_normal(I))
38 
39 '''
40 s0=100   #初始价格
41 i=4
42 st=np.zeros((i,D))
43 st[0]=s0
44 a=0.15
45 b=0.3
46 n=round(T/dt)#dimension
47 plt.subplot(212)
48 for g in range(1, i):
49     t=np.linspace(0,T,n)
50     e=np.random.standard_normal(size=n)
51     z=np.cumsum(e)*np.sqrt(dt)
52     x=a*t+b*z;
53     st[g]=st[0]*np.exp(z)
54     
55     plt.plot(t,st[g],label='st'+str(g))
56     
57 
58 plt.legend()
59 plt.show()

View Code

 

执行结果:

python数据可视化分析速成笔记_2-2_布朗运动/几何布朗运动(伊藤过程)实现的demo[通俗易懂]

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168215.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • HashMap工作原理和扩容机制

    HashMap工作原理和扩容机制HashMap工作原理HashMap扩容1HashMap的扩容时机2HashMap的扩容过程补充1容量必须是2的幂2rehashReferences1.HashMap工作原理HashMap作为优秀的Java集合框架中的一个重要的成员,在很多编程场景下为我们所用。HashMap作为数据结构散列表的一种实现,就其工作原理来讲单独列出一篇博客来讲都是不过分的。由于本文主要是简单总

    2022年6月18日
    30
  • IDEA打jar包在服务器运行出现Error:Invalid or corrupt jarfile xxx.jar 报错+如何使用IDEA打jar包

    IDEA打jar包在服务器运行出现Error:Invalid or corrupt jarfile xxx.jar 报错+如何使用IDEA打jar包JAR包错误:Error:Invalidorcorruptjarfilexxx.jar错误背景:IDEA打包springboot项目为jar包。打包方法百度了好几种,结果都在运行时报了Error:Invalidorcorruptjarfilexxx.jar错误。…

    2022年8月22日
    7
  • 大型企业局域网安全解决方案[通俗易懂]

    大型企业局域网安全解决方案[通俗易懂]第一章总则本方案为某大型局域网网络安全解决方案,包括原有网络系统分析、安全需求分析、安全目标的确立、安全体系结构的设计、等。本安全解决方案的目标是在不影响某大型企业局域网当前业务的前提下,实现对他们局域网全面的安全管理。1.将安全策略、硬件及软件等方法结合起来,构成一个统一的防御系统,有效阻止非法用户进入网络,减少网络的安全风险。2.定期进行漏洞扫描,审计跟踪,及时发现问题,解

    2022年7月15日
    19
  • Django(33)Django操作cookie

    Django(33)Django操作cookie前言cookie:在网站中,http请求是无状态的。也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户。cookie的出现就是为了解决这个问题,第一次登录

    2022年7月29日
    7
  • nginx反向代理数据库端口安全吗(nginx反向代理80端口)

    nginx反向代理数据库端口使用场景如下:当数据库在服务器A并且处于外网无法直接访问时,此时同局域网下只有服务器B提供对外访问,客户能访问b却无法访问A的情况下,由于两台服务器处于同局域网,并且服务器A有端口是开放的,可以在服务器B内进行nginx反向代理安装nginx首先在服务器b内,安装nginx(docker化的也可以)如果是docker的nginx需要进入docker内的nginxdockerexec-it容器idbash一般nginx的配置文件在e

    2022年4月9日
    47
  • 【python | linux12】模块制作及嵌套的包「建议收藏」

    【python | linux12】模块制作及嵌套的包「建议收藏」在Python中,每个Python文件都可以作为一个模块,模块的名字就是文件的名字。比如有这样一个文件test.py,在test.py中定义了函数add。

    2022年9月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号