目录

  • QuantLib 金融计算——收益率曲线之构建曲线(2)

    • YieldTermStructure
    • 问题描述
    • Piecewise**
      • 分段收益率曲线的原理
      • Piecewise** 对象的构造
    • FittedBondDiscountCurve
      • FittedBondDiscountCurve 的原理
      • FittedBondDiscountCurve 的构造
      • FittingMethod
    • 拟合曲线

如果未做特别说明,文中的程序都是 Python3 代码。

QuantLib 金融计算——收益率曲线之构建曲线(2)

理论和实践上有多种方法可以构建与市场一致的收益率曲线,背后的方法论取决于市场上的可获得金融工具的流动性。在构建收益率曲线时有两个选项必须选定好:拟合方法和所选的金融工具。

quantlib-python 允许构建下列两大类收益率曲线:

  • 第一类,根据数值和对应日期构建:

    • DiscountCurve,根据贴现因子构建
    • 若干 *ZeroCurve 型的收益率曲线,根据债券零息收益率构建(前缀表示具体的构建方法)
    • ForwardCurve,根据远期收益率构建
  • 第二类,根据若干固定收益类对象(如 FixedRateBond)构建:
    • 若干 Piecewise** 型的收益率曲线,根据若干不同类型金融工具(存款收益率、收益率远期合约和互换等等)的报价分段构建(后缀表示具体的构建方法和曲线类型)
    • FittedBondDiscountCurve,根据若干债券的价格构建

本文介绍第二种。

载入 QuantLib:

import QuantLib as qlprint(ql.__version__)
1.12

YieldTermStructure

事实上,所有上述类都派生自基类 YieldTermStructure,该基类实现了一些常用的功能。例如,实现了返回基准日期、天数计算规则、日历的函数,以及返回收益率的最小或最大日期的函数。

YieldTermStructure 常用的成员函数:

  • discount(d, extrapolate = False):浮点数,dDate 对象, extrapolate 是布尔型。返回贴现因子大小。
  • zeroRate(d, resultDayCounter, comp, freq = Annual, extrapolate = False)InterestRatedDate 对象,resultDayCounterDayCounter 对象,compfreq 是预置整数,extrapolate 是布尔型。返回等价的零息收益率对象。
  • forwardRate(d1, d2, dc, comp, freq = Annual, extrapolate = false)InterestRated1d2Date 对象,resultDayCounterDayCounter 对象,compfreq 是 quantlib-python 预置整数(表示付息方式和频率),extrapolate 是布尔型。返回 d1d2 之间的远期收益率对象。

问题描述

以货币网 2018-07-23 发布的国债收盘收益率曲线为基准,构造一组样本券:

  • 样本券的期限分别为收益率曲线的关键期限,如 1、5、15 年等;
  • 样本券的付息频率为每年付息一次;
  • 样本券的票息率为对应期限的到期收益率;
  • 样本券的当前价格为 100 元

此时,这些样本券确定的“到期”收益率曲线即为发布的收盘收益率曲线,因为对于每年付息一次的固息债,全价等于 100 时票息率恰好等于到期收益率。

下面,从上述样本券中构造出满足某种限制条件的“即期”收益率曲线。理论上,重新构造出的即期收益率应当与货币网发布的即期收益率非常接近,甚至相等。

期限 到期收益率 即期收益率
1 3.0544 3.0544
2 3.1549 3.1565
3 3.2489 3.2531
4 3.2702 3.2744
5 3.2915 3.2964
6 3.3958 3.4092
7 3.5000 3.5237
8 3.5050 3.5264
9 3.5100 3.5298
10 3.5150 3.5337
15 3.7765 3.8517
20 3.8163 3.8884
30 3.9568 4.0943
50 3.9720 4.0720

Piecewise**

quantlib-python 提供的若干 Piecewise** 型的收益率曲线意为“分段收益率曲线”,可以根据若干固收类金融工具的报价推算出特定期限的收益率(或贴现因子),进而构建收益率曲线。

分段收益率曲线的原理

分段收益率曲线接受一组不同期限的固收类金融工具(如固息债、利率互换和远期利率协议等等),根据具体金融工具的贴现方法、期限、价格等等因素拆解(bootstrap)出对应期限的即期收益率(或等价的贴现因子)。再通过某种插值手段——通常是样条插值,构造出与实际即期收益率(或贴现因子)最接近的理论收益率曲线。

Piecewise** 对象的构造

PiecewiseLogCubicDiscount 从金融工具报价中拆解出贴现因子,并用对数三次样条插值构建理论贴现因子曲线。其构造函数具有以下实现

PiecewiseLogCubicDiscount(referenceDate,instruments,dayCounter,jumps,jumpDates,accuracy,i)

PiecewiseLogCubicDiscount(settlementDays,calendar,instruments,dayCounter,jumps,jumpDates,accuracy,i)

这些变量的类型和解释如下:

  • referenceDateDate 对象,构造曲线的基准日期
  • settlementDays:整数,结算日天数
  • calendarCalendar 对象,市场对应的日历表
  • instruments:一列 *Helper 类的对象,特定金融工具的辅助类,用于拆解计算。
  • dayCounterDayCounter 对象,市场对应的天数计算规则
  • jumps:一列 RelinkableQuoteHandle 对象,收益率跳跃的幅度,默认是空的
  • jumpDates:一列 Date 对象,收益率跳跃的日期,默认是空的
  • accuracy:浮点数,收敛精度,默认是 1e-12
  • iMonotonicLogCubic 对象,插值方法,默认是 MonotonicLogCubic()

PiecewiseLogCubicDiscount 常用的成员函数均继承自基类 YieldTermStructure

PiecewiseLogCubicDiscount 对收益率曲线的形状没有“结构性”的限制,可以很好的拟合实际得到的收益率数据,代价是缺少理论性的解释能力。

FittedBondDiscountCurve

PiecewiseLogCubicDiscount 相反,FittedBondDiscountCurve 对收益率曲线的形状提出了“结构性”的限制,最终拟合曲线的理论解释性更强,曲线也更光滑,但代价是拟合程度会降低。

FittedBondDiscountCurve 的原理

FittedBondDiscountCurve 接受一组不同期限的固息债对象,同时假设理论即期收益率(或贴现因子)满足某种特定的函数形式——通常由几个参数控制。用理论曲线对算出债券的理论价格,寻找最佳参数,使得理论价格和实际价格的距离最小。最佳参数确定的曲线便是拟合出的理论曲线。

FittedBondDiscountCurve 的构造

FittedBondDiscountCurve 从一列固息债对象中拆解出贴现因子,并用要求理论贴现因子曲线满足某种参数形式。其构造函数具有以下实现

FittedBondDiscountCurve(referenceDate,helpers,dayCounter,fittingMethod,accuracy,maxEvaluations,guess,simplexLambda)

FittedBondDiscountCurve(settlementDays,calendar,helpers,dayCounter,fittingMethod,accuracy,maxEvaluations,guess,simplexLambda)

这些变量的类型和解释如下:

  • referenceDateDate 对象,构造曲线的基准日期
  • settlementDays:整数,结算日天数
  • calendarCalendar 对象,市场对应的日历表
  • helps:一列 *Helper 类的对象,固息债的辅助类,用于拆解计算。
  • dayCounterDayCounter 对象,市场对应的天数计算规则
  • fittingMethodFittingMethod 对象,规定理论曲线的函数形式。
  • accuracy:浮点数,收敛精度,默认是 1e-10
  • maxEvaluations:整数,数值优化计算中的最大迭代次数
  • guess:一列浮点数,数值优化计算的初始参数,默认是空的
  • simplexLambda:浮点数,单纯型算法中的尺度,默认是 1.0

FittedBondDiscountCurve 常用的成员函数均继承自基类 YieldTermStructure

FittingMethod

FittingMethod 是一个基类,quantlib-python 具体提供的 FittingMethod 子类有以下几个:

  • ExponentialSplinesFitting:指数样条模型,贴现因子的形式为 \(d(t) = \sum_{i=1}^9 c_i \exp^{-\kappa \cdot i \cdot t}​\),其中 \(c_i​\) 和 \(\kappa​\) 是需要确定的参数。
  • CubicBSplinesFitting:三次 B-样条模型,贴现因子的形式为一组三次 B-样条 \(N_{i,3}(t)\) 的组合,\(d(t) = \sum_{i=0}^{n} c_i \cdot N_{i,3}(t)\),其中 \(c_i\) 是需要确定的参数。
  • SimplePolynomialFitting:简单多项式模型,贴现因子的形式为多项式
  • NelsonSiegelFitting:Nelson-Siegel 模型,即期收益率的形式为 \(r(t) = c_0 + (c_1 + c_2) \cdot (1 - exp^{-\kappa \cdot t})/(\kappa \cdot t) - c_2 exp^{- \kappa \cdot t}\),其中 \(c_i\) 和 \(\kappa\) 是需要确定的参数。
  • SvenssonFitting:Svensson-Nelson-Siegel 模型,即期收益率的形式为 \(r(t) = c_0 + (c_0 + c_1)(\frac {1 - exp^{-\kappa \cdot t}}{\kappa \cdot t}) - c_2exp^{ - \kappa \cdot t} + c_3{(\frac{1 - exp^{-\kappa_1 \cdot t}}{\kappa_1 \cdot t} -exp^{-\kappa_1 \cdot t})}\),其中 \(c_i\)、\(\kappa\) 和 \(\kappa_1\) 是需要确定的参数。

拟合曲线

下面分别用 PiecewiseLogCubicDiscountFittedBondDiscountCurve 拟合“问题描述”中构造出的样本券对应的即期收益率曲线,FittedBondDiscountCurve 方法使用 Svensson-Nelson-Siegel 模型。

理论上,PiecewiseLogCubicDiscount 拟合出的曲线应该非常接近货币网发布的即期收益率曲线,很可能是锯齿状的,不光滑的(由于市场的深度和广度有限)。FittedBondDiscountCurve 拟合出的曲线应该非常光滑,并且足够接近货币网发布的曲线。

例子,拟合曲线并输出 Svensson-Nelson-Siegel 模型的参数。

import QuantLib as ql
import pandas as pd
import seaborn as sbdef testingYields3():maturities = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 15, 20, 30, 50]pars = [0.030544, 0.031549, 0.032489, 0.032702, 0.032915, 0.033958, 0.03500,0.035050, 0.035100, 0.035150, 0.037765, 0.038163, 0.039568, 0.03972]spots = [0.030544, 0.031565, 0.032531, 0.032744, 0.032964, 0.034092, 0.035237,0.035264, 0.035298, 0.035337, 0.038517, 0.038884, 0.040943, 0.040720]numberOfBonds = len(maturities)cleanPrice = [100.0] * numberOfBondsquote = [ql.SimpleQuote(c) for c in cleanPrice]quoteHandle = [ql.RelinkableQuoteHandle()] * numberOfBondsfor i in range(len(quoteHandle)):quoteHandle[i].linkTo(quote[i])frequency = ql.Annualdc = ql.ActualActual(ql.ActualActual.ISMA)accrualConvention = ql.ModifiedFollowingconvention = ql.ModifiedFollowingredemption = 100.0calendar = ql.China(ql.China.IB)today = calendar.adjust(ql.Date(23, 7, 2018))ql.Settings.evaluationDate = todaybondSettlementDays = 0bondSettlementDate = calendar.advance(today,ql.Period(bondSettlementDays, ql.Days))instruments = []for j in range(len(maturities)):maturity = calendar.advance(bondSettlementDate,ql.Period(maturities[j], ql.Years))schedule = ql.Schedule(bondSettlementDate,maturity,ql.Period(frequency),calendar,accrualConvention,accrualConvention,ql.DateGeneration.Backward,False)helper = ql.FixedRateBondHelper(quoteHandle[j],bondSettlementDays,100.0,schedule,[pars[j]],dc,convention,redemption)instruments.append(helper)tolerance = 1.0e-10max = 5000svensson = ql.SvenssonFitting()ts0 = ql.PiecewiseLogCubicDiscount(bondSettlementDate,instruments,dc)ts1 = ql.FittedBondDiscountCurve(bondSettlementDate,instruments,dc,svensson,tolerance,max)spline = []sv = []print('{0:>9}{1:>9}{2:>9}{3:>9}'.format("tenor", "spot", "spline", "svensson"))for i in range(len(instruments)):cfs = instruments[i].bond().cashflows()cfSize = len(instruments[i].bond().cashflows())tenor = dc.yearFraction(today, cfs[cfSize - 1].date())print('{0:9.3f}{1:9.3f}{2:9.3f}{3:9.3f}'.format(tenor,100.0 * spots[i],100.0 * ts0.zeroRate(cfs[cfSize - 1].date(), dc, ql.Compounded, frequency).rate(),100.0 * ts1.zeroRate(cfs[cfSize - 1].date(), dc, ql.Compounded, frequency).rate()))spline.append(ts0.zeroRate(cfs[cfSize - 1].date(), dc, ql.Compounded, frequency).rate())sv.append(ts1.zeroRate(cfs[cfSize - 1].date(), dc, ql.Compounded, frequency).rate())df = pd.DataFrame(dict(mat=maturities * 4,rate=pars + spots + spline + sv,type=['par'] * 14 + ['spot'] * 14 + ['spline'] * 14 + ['sv'] * 14))print(ts1.fitResults().solution())return dfrs = testingYields3()sb.relplot(x='mat', y='rate', kind='line', hue='type',data=rs, height=5, aspect=1.6)

结果如下:

    tenor     spot   spline svensson1.000    3.054    2.993    3.0112.000    3.157    3.121    3.1043.000    3.253    3.226    3.1874.000    3.274    3.258    3.2625.000    3.296    3.281    3.3306.000    3.409    3.393    3.3927.000    3.524    3.507    3.4488.000    3.526    3.512    3.4999.000    3.530    3.517    3.54710.000    3.534    3.523    3.59115.000    3.852    3.843    3.77120.000    3.888    3.877    3.90630.000    4.094    4.085    4.08450.000    4.072    4.044    4.025
[ -0.190874; 0.219538; 0.0953552; 0.586634; 0.0896221; 0.0226007 ]

将结果可视化。蓝色线表示到期曲线,橙色线表示即期曲线,绿色线是 PiecewiseLogCubicDiscount 拟合的结果,红色线是 FittedBondDiscountCurve 拟合的 Svensson-Nelson-Siegel 模型,与预期完全一致。

转载于:https://www.cnblogs.com/xuruilong100/p/9551640.html

QuantLib 金融计算——收益率曲线之构建曲线(2)相关推荐

  1. QuantLib 金融计算——收益率曲线之构建曲线(1)

    目录 QuantLib 金融计算--收益率曲线之构建曲线(1) YieldTermStructure DiscountCurve DiscountCurve 对象的构造 ZeroCurve ZeroC ...

  2. QuantLib 金融计算——收益率曲线之构建曲线(3)

    目录 QuantLib 金融计算--收益率曲线之构建曲线(3) 概述 估算期限结构的步骤 读取样本券数据 一些基本配置 配置 *Helper 对象 配置期限结构 估算期限结构 汇总结果 当前实现存在的 ...

  3. QuantLib 金融计算库

    一.简介 QuantLib 是一个免费的.开源的, 金融计算的C++库,旨在为量化金融计算提供一个统一的.综合的软件框架. QuantLib 的源代码由 C++ 编写,得力于 C++ 在面向对象和泛型 ...

  4. QuantLib 金融计算——随机过程之概述

    目录 QuantLib 金融计算--随机过程之概述 框架 用法与接口 如果未做特别说明,文中的程序都是 Python3 代码. QuantLib 金融计算--随机过程之概述 载入模块 import Q ...

  5. QuantLib 金融计算——基本组件之天数计算规则详解

    目录 天数计算规则详解 定义 30 / 360 法 30/360 US 30/360 Bond Basis 30E/360 30E/360 ISDA Actual 法 Actual/Actual IC ...

  6. 【小白的CFD之旅】20 计算区域的构建

    计算域是什么 计算域如何创建 常用的建模软件 计算域几何的特殊之处 具体的计算域提取方法 小白总结 自从上次在食堂听了小牛师兄关于计算网格的一些问题后,小白决定在寒假期间好好的补习一下关于计算网格的划 ...

  7. NLP实践|CCKS2020金融知识图谱自动化构建技术方法总结

    每天给你送来NLP技术干货! 编辑:AI算法小喵 写在前面 文本是参加2020CCKS评测 基于本体的金融知识图谱自动化构建技术 之后的一篇总结博客,笔者查阅了大量文献,并做了大量采用深度学习模型的实 ...

  8. 金融计算与编程 基于matlab,金融计算与编程.pdf

    金融市场与风险管理系列教材 金融计算与编程 ---基于 MATLAB 的应用 曹志广 著 上海财经大学出版社 ( ) 图书在版编目 CIP数据 : / : 金融计算与编程 基于 的应用 曹志广著 上海 ...

  9. portstats matlab,MATLAB金融计算试题

    <MATLAB金融计算试题>由会员分享,可在线阅读,更多相关<MATLAB金融计算试题(19页珍藏版)>请在人人文库网上搜索. 1.精品文档MATLAB金融计算试题(2014级 ...

最新文章

  1. Java项目:药品管理系统(java+swing+Gui+mysql)
  2. [android]am自动化测试框架(原创)
  3. python使用作为转义字符_当需要在字符串中使用特殊字符时, Python使用()作为转义字符。...
  4. linux 安装npm
  5. mysql建考勤信息代码_基于Java+JSP+Servlet+Mysql的考勤管理系统
  6. GaitSet:将步态作为序列的交叉视角步态识别
  7. 简述自定义驱动在工业通讯软件开发中的应用
  8. Are We Ready For Learned Cardinality Estimation实验环境搭建
  9. Bmob后端云的集成与使用
  10. 软考中级软件设计师--下午题
  11. cad指北针lisp_cad指北针命令(CAD如何绘制一个最简单的指北针)
  12. 解析mp3文件,获得mp3中的专辑图片
  13. moonseo小夜:作为一个seo伴随着技术的学习与提升
  14. OFD开发系列(二)-模板填充
  15. macbookair苹果MAC笔记电脑本更换电池教程
  16. 多分类-- ROC曲线和AUC值
  17. 从事家电行业17年,分享下我的购买心得:哪些品牌电器值得你购买
  18. php获取微信小程序用户高清头像的方法
  19. android 加载图片进度条,ImageView上的Android进度条
  20. 西门子1200与3台欧姆龙E5cc温控器通讯程序

热门文章

  1. 阿凡达 一票难求啊!
  2. 浏览器开发基础培训汇总
  3. c语言的erase函数,[转] C++ STL中map.erase(it++)用法原理解析
  4. C#中的#region
  5. 如何使电脑网速加快,去掉系统的带宽限制
  6. 计算机网络 课程特点,计算机网络课程介绍(Computer Networks).ppt
  7. Web 前端开发1+X认证中级理论考试样题
  8. 拒绝访问 chkdsk无法修复. 不知道怎样找回呢
  9. Java设计模式之(工厂模式)
  10. bootstrap之tooltip