当前位置:网站首页>性能提升400倍丨外汇掉期估值计算优化案例
性能提升400倍丨外汇掉期估值计算优化案例
2022-08-04 15:04:00 【51CTO】
在金融领域,合约的估值计算是个常见需求。几百万个合约,由于到期时间和期限长短不同,计算时往往对应不同的利率。合约匹配利率,最常见的做法是通过循环语句对每一个合约做计算。而 DolphinDB 中,可以通过强大的表连接函数,将需要的信息关联后,再通过 SQL向量编程 进行计算。该优化方法相比循环的方法,性能提升超 400 倍。
本文包含的主要内容有:外汇掉期估值的计算逻辑及数据准备、开发环境配置、外汇掉期估值的普通实现和优化实现等。
本文中的脚本在 DolphinDB 1.30.18/2.00.6 及以上版本的环境中测试通过。
1. 外汇掉期估值的计算逻辑及数据准备
1.1 外汇掉期估值的计算逻辑
本次的计算整体逻辑如下图:
本次外汇掉期估值计算的逻辑,参考 中国外汇交易中心2019年4月2日在官网推出的外汇掉期估值服务中的估值算法,即通过掉期曲线计算当日的远端全价汇率折算,并与约定交易的全价汇率生成的现金流轧差得到净值,再用当日的 Shibor3M(Shanghai Interbank Offered Rate) 利率互换收盘曲线进行贴现,最后得到合约净额的贴现值即为合约估值。
1.2 数据准备
外汇掉期估值的计算需要用到掉期曲线利率以及利率互换曲线两张表。以上两张表的数据直接采集于2021年12月14日中国外汇掉期 USD.CNY外汇掉期曲线及 Shibor3M利率互换行情曲线。
数据结构分别为:
- USD.CNY外汇掉期曲线:
name | typeString | comment |
Date | DATE | 日期 |
timeminute | MINUTE | 时间 |
currencyPair | STRING | 货币对 |
termToMaturity | STRING | 期限品种 |
swapRate_Pips | DOUBLE | 掉期点 |
exchangeRate | DOUBLE | 全价汇率 |
maturityDate | DATE | 远端起息日 |
- Shibor3M利率互换行情曲线:
name | typeString | comment |
Maturity | STRING | 标准期限 |
buying_rate | DOUBLE | 报买(%) |
average_rate | DOUBLE | 均值(%) |
selling_rate | DOUBLE | 报卖(%) |
本教程用到的合约数据为自行模拟的100万个不同到期期限的合约数据,数据结构为:
name | typeString | comment |
contract_no | INT | 合约编号 |
contract_date | DATE | 合约日 |
trade_date | DATE | 近端起息日 |
maturity_date | DATE | 远端起息日 |
buy_sell | STRING | 买卖方向 |
period | STRING | 期限 |
near_leg_currency | STRING | 近端交易货币 |
near_leg_amount | INT | 交易量 |
near_leg_spot_rate | DOUBLE | 近端掉期全价汇率 |
far_leg_currency | STRING | 远端清算货币 |
far_leg_spot_rate | DOUBLE | 远端掉期全价汇率 |
上述利率数据以及模拟合约数据的脚本请参阅 数据准备脚本。
2. 开发环境配置
2.1 DolphinDB server服务器环境
- CPU 类型:Intel(R) Xeon(R) Silver 4216 CPU @ 2.10GHz
- 逻辑 CPU 总数:8
- 内存:64GB
- OS:64位 CentOS Linux 7 (Core)
2.2 DolphinDB server部署
- server版本:1.30.18 或 2.00.6
- server部署模式:单节点
- 配置文件:dolphindb.cfg
单节点部署教程: 单节点部署
3. 外汇掉期估值的普通实现
由于每一个合约有不同的起息日和合约期限,因此会对应不同的互换利率以及全价汇率。普通的实现方法是自定义一个包含估值计算逻辑的函数,通过循环语句,将每个合约与对应利率进行计算。
包含三表的估值函数定义如下:
由于涉及到多表间的信息提取,函数看起来会相对复杂。做完这一步之后,就可以对所有的合约进行循环计算。100万个合约在测试环境下做计算耗时约3分20秒。
for循环写法的代码示例如下:
或用loop函数的写法示例如下:
利用多线程并行计算,可以在同样的计算逻辑上做进一步优化,将原本的单线程循环改成多线程并行计算,最后将结果进行拼接。DolphinDB 提供了 ploop
/peach
函数,可以很方便的把这类循环语句内存计算转换成多线程任务。
此例用了8个并行度做计算,最后耗时大约20秒:
注意:
ploop
/peach
的并行度由配置文件中的 localExecutors 控制,默认值是 CPU 内核数减1。在批流一体的因子实现中,不建议使用 ploop
/peach
并行加速。具体并行策略可以参考因子最佳实践中的 并行计算章节。
4. 外汇掉期估值的优化实现
DolphinDB 中提供了许多表关联函数,故原本的两张小表 swap_rate 和 IR_rate 以及合约大表,可以先通过表关联函数将有效信息提取出来,继而直接通过 SQL 做计算即可。如此一来,避免了循环语句重复消耗资源,也减少了代码的开发量。
做外汇掉期估值计算时,可以用 equal join
, asof join
及 window join
将需要的远端利率等信息通过三表关联得到,代码如下:
由于关联后的信息可以在一张表( res_wj )中得到,故计算逻辑也可以得到简化,可以直观地翻译原公式逻辑进行向量化计算:
用优化后的表关联逻辑做外汇掉期估值计算,整体耗时只需0.5秒左右,性能相比最初提升了超400倍。
5. 总结
对于需要用到多表数据计算的任务,用循环语句的方式性能较差。建议先用 DolphinDB 优化的 asof join
等表关联函数将需要的信息提取。asof join
等表关联函数亦支持分布式关联,对于存储于数据库中的分布式表也可以多线程并行关联,性能卓越。计算部分建议使用 SQL 向量化编程的方式做计算,不仅可以减少代码开发量(基本可以直观地翻译计算公式),也避免了循环语句重复消耗 CPU 资源。
6. 代码附录
数据准备脚本
完整优化过程
边栏推荐
- Sum of four squares, laser bombs
- 16. Learn MySQL Regular Expressions
- I/O stream summary
- 杭电校赛(ACM组队安排)
- IP第十七天笔记
- Technology sharing | Mini program realizes audio and video calls
- 大众点评搜索相关性技术探索与实践
- 兆骑科创创新创业大赛活动举办,线上直播路演,投融资对接
- [The Art of Hardware Architecture] Study Notes (1) The World of Metastability
- C# 将dll打包到程序中
猜你喜欢
【剑指offer59】队列的最大值
QT笔记——Q_INVOKABLE了解
【 HMS core 】 【 Media 】 online video editing service 】 【 material can't show, or network anomalies have been Loading state
IP第十六天笔记
微软表示将向内部网络安全专家共享数据 为企业提供更安全保护
在腾讯,我的试用期总结!
分布式链路追踪Jaeger + 微服务Pig在Rainbond上的实践分享
Zheng Qing freshmen school competition and middle-aged engineering selection competition
leetcode:253. 至少需要多少间会议室
程序猿七夕礼物-如何30分钟给女朋友快速搭建专属语聊房
随机推荐
C# TextBlock 上标
用了TCP协议,就一定不会丢包吗?
leetcode: 259. Smaller sum of three numbers
大众点评搜索相关性技术探索与实践
How to fall in love with a programmer
[机缘参悟-60]:《兵者,诡道也》-1-开篇:“死“与“生“都是天道
leetcode:251. 展开二维向量
Roslyn 节点的 Span 和 FullSpan 有什么区别
实际工作中的高级技术(训练加速、推理加速、深度学习自适应、对抗神经网络)
QT笔记——QUuid了解
xpath获取带命名空间节点注意事项
宣传海报
[The Art of Hardware Architecture] Study Notes (1) The World of Metastability
郑轻新生校赛和中工选拔赛题解
16、学习MySQL 正则表达式
第十六章 源代码文件 REST API 教程(一)
基于数据库实现分布式锁
特殊品种的二次开户验资金额
Nuget 通过 dotnet 命令行发布
leetcode:253. 至少需要多少间会议室