QuantLib 金融计算——基本组件之 InterestRate 类
如果未做特别说明,文中的程序都是 Python3 代码。
QuantLib 金融计算——基本组件之 InterestRate
类
围绕收益率展开的若干计算(如计算贴现因子)是固定收益分析中最基础的部分。同时,由于固定收益产品在付息频率、计息方式、天数计算规则等细节方面的多样性,这一块的计算显得更加复杂繁琐。QuantLib 将与收益率有关的计算整合封装在 InterestRate
类,用户所作的只是按照规定配置特定的参数。
载入 QuantLib:
import QuantLib as ql
print(ql.__version__)
1.12
InterestRate
对象的构造
InterestRate
对象的构造需要四个参数,
InterestRate(r,
dc,
comp,
freq)
这些变量的类型和解释如下:
r
,浮点数,收益率大小;dc
,DayCounter
对象,配置天数计算规则;comp
,整数,配置计息方式,取值范围是 quantlib-python 的一些预留变量;freq
,整数,配置付息频率,取值范围是 quantlib-python 的一些预留变量。
目前 quantlib-python 支持的计息方式有:
Simple
,\(1 + r\tau\),单利Compounded
,\((1 + r)^\tau\),复利Continuous
,\(e^{r\tau}\),连续复利
目前 quantlib-python 支持的计息方式有很多:
NoFrequency
,无付息;Once
,付息一次,常见于零息债券;Annual
,每年付息一次;Semiannual
,每半年付息一次;EveryFourthMonth
,每 4 个月年付息一次;Quarterly
,每季度付息一次;Bimonthly
,每两个月付息一次;Monthly
,每月付息一次;EveryFourthWeek
,每 4 周付息一次;Biweekly
,每两周付息一次;Weekly
,每周付息一次;Daily
,每天付息一次。
一些常用的成员函数
下面是一些常用的成员函数:
rate()
:浮点数,返回收益率的值;dayCounter()
:DayCounter
对象,返回控制天数计算规则的成员变量;compounding()
:整数,返回计息方式;frequency()
:整数,返回付息频率。discountFactor(d1, d2)
:浮点数,d1
和d2
都是Date
型对象(d1
<d2
),返回d1
到d2
的贴现因子大小;compoundFactor(d1, d2)
:浮点数,d1
和d2
都是Date
型对象(d1
<d2
),返回d1
到d2
的付息因子大小;equivalentRate(resultDC, comp, freq, d1, d2)
:InterestRate
对象,返回某个与当前对象等价的InterestRate
对象,该对象的配置参数包括resultDC
、comp
、freq
:d1
和d2
都是Date
型对象(d1
<d2
)resultDC
,DayCounter
对象,配置天数计算规则;comp
,整数,配置计息方式,取值范围是 quantlib-python 的一些预留变量;freq
,整数,配置付息频率,取值范围是 quantlib-python 的一些预留变量。
某些情况下需要根据付息因子的大小逆算收益率,InterestRate
类提供了函数 impliedRate
实现这一功能:
impliedRate(compound, resultDC, comp, freq, d1, d2)
:InterestRate
对象,返回逆算出的InterestRate
对象,该对象的配置参数包括resultDC
、comp
、freq
:d1
和d2
都是Date
型对象(d1
<d2
)resultDC
,DayCounter
对象,配置天数计算规则;comp
,整数,配置计息方式,取值范围是 quantlib-python 的一些预留变量;freq
,整数,配置付息频率,取值范围是 quantlib-python 的一些预留变量。
例子1:
def InterestRate1():
dc = ql.ActualActual()
myRate = ql.InterestRate(
0.0341, dc, ql.Simple, ql.Annual)
print('Rate:', myRate)
d1 = ql.Date(10, ql.September, 2009)
d2 = d1 + ql.Period(3, ql.Months)
compFact = myRate.compoundFactor(d1, d2)
print('Compound Factor: ', compFact)
print('Discount Factor: ', myRate.discountFactor(d1, d2))
print(
'Equivalent Rate: ',
myRate.equivalentRate(
dc, ql.Continuous, ql.Semiannual, d1, d2))
implRate = ql.InterestRate.impliedRate(
compFact, dc, ql.Simple, ql.Annual, d1, d2)
print('Implied Rate from Comp Fact : ', implRate)
InterestRate1()
Rate: 3.410000 % Actual/Actual (ISDA) simple compounding
Compound Factor: 1.0085016438356165
Discount Factor: 0.9915700248109837
Equivalent Rate: 3.395586 % Actual/Actual (ISDA) continuous compounding
Implied Rate from Comp Fact : 3.410000 % Actual/Actual (ISDA) simple compounding
QuantLib 金融计算——基本组件之 InterestRate 类的更多相关文章
- QuantLib 金融计算——基本组件之 Currency 类
目录 QuantLib 金融计算--基本组件之 Currency 类 概述 构造函数 成员函数 如果未做特别说明,文中的程序都是 python3 代码. QuantLib 金融计算--基本组件之 Cu ...
- QuantLib 金融计算——基本组件之 Date 类
目录 QuantLib 金融计算--基本组件之 Date 类 Date 对象的构造 一些常用的成员函数 一些常用的静态函数 为估值计算配置日期 如果未做特别说明,文中的程序都是 Python3 代码. ...
- QuantLib 金融计算——基本组件之 Calendar 类
目录 QuantLib 金融计算--基本组件之 Calendar 类 Calendar 对象的构造 一些常用的成员函数 自定义假期列表 工作日修正 如果未做特别说明,文中的程序都是 Python3 代 ...
- QuantLib 金融计算——基本组件之 DayCounter 类
目录 QuantLib 金融计算--基本组件之 DayCounter 类 DayCounter 对象的构造 一些常用的成员函数 如果未做特别说明,文中的程序都是 Python3 代码. QuantLi ...
- QuantLib 金融计算——基本组件之 DateGeneration 类
目录 QuantLib 金融计算--基本组件之 DateGeneration 类 QuantLib 金融计算--基本组件之 DateGeneration 类 许多产品的估值依赖于对未来现金流的分析,因 ...
- QuantLib 金融计算——基本组件之 Schedule 类
目录 QuantLib 金融计算--基本组件之 Schedule 类 Schedule 对象的构造 作为"容器"的 Schedule 对象 一些常用的成员函数 如果未做特别说明,文 ...
- QuantLib 金融计算——基本组件之 Index 类
目录 QuantLib 金融计算--基本组件之 Index 类 QuantLib 金融计算--基本组件之 Index 类 Index 类用于表示已知的指数或者收益率,例如 Libor 或 Shibor ...
- QuantLib 金融计算——基本组件之 ExchangeRateManager 类
目录 QuantLib 金融计算--基本组件之 ExchangeRateManager 类 概述 Money 类中的汇率转换配置 ExchangeRateManager 函数 如果未做特别说明,文中的 ...
- QuantLib 金融计算——基本组件之 Money 类
目录 QuantLib 金融计算--基本组件之 Money 类 概述 构造函数 成员函数 如果未做特别说明,文中的程序都是 python3 代码. QuantLib 金融计算--基本组件之 Money ...
随机推荐
- Spring Boot 简单入门
添加相关依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http ...
- 将Oracle数据库设置为归档模式及非归档模式
一.将Oracle数据库设置为归档模式 1)sql>shutdown normal/immediate;2)sql>startup mount;3)sql>alter databas ...
- 转载:字符串hash总结(hash是一门优雅的暴力!)
转载自:远航休息栈 字符串Hash总结 Hash是什么意思呢?某度翻译告诉我们: hash 英[hæʃ] 美[hæʃ]n. 剁碎的食物; #号; 蔬菜肉丁;vt. 把…弄乱; 切碎; 反复推敲; 搞糟 ...
- spark使用idea以client模式提交应用到standalone集群
使用idea以client方式提交代码到standalone集群非常简单. 1.首先有一个部署好且已经启动的standalone集群 --------------------------------- ...
- Linux的进程/线程间通信方式总结
Linux系统中的进程间通信方式主要以下几种: 同一主机上的进程通信方式 * UNIX进程间通信方式: 包括管道(PIPE), 有名管道(FIFO), 和信号(Signal) * System V进程 ...
- 4、Docker的安装
docker官方安装文档 Mac上安装Docker Install Docker for Mac | Docker Documentation Windows安装Docker Instal ...
- centos mysql忘记密码找回(仅限mysql5.7)
1.停掉mysql 2.执行#mysqld_safe --user=mysql --skip-grant-tables --skip-networking & 3.#mysql 4.updat ...
- UnicodeEncodeError:'latin-1' codec can't encode characters in position 0-1: ordinal not in range(256)
Scrapy爬虫向数据库写入数据时报错: UnicodeEncodeError:'latin-1' codec can't encode characters in position 0-1: ord ...
- [c# 20问] 1. 何时使用class与struct
POINTS struct为可以包含数据和函数的值类型 struct为值类型所以不需要堆(heap)而是在栈(stack)上分配空间 struct将数据直接存在struct中,而class只存引用类型 ...
- PostgreSQL 表空间
PostgreSQL 表空间 一 介绍使用表空间可以将不同的表放到不同的存储介质或不同的文件系统下,实际上是为表指定一个存储的目录.创建数据库,表,索引时可以指定表空间,将数据库,表,索引放到指定的目 ...