当前位置:网站首页>400 times performance improvement 丨 swap valuation optimization case calculation
400 times performance improvement 丨 swap valuation optimization case calculation
2022-08-05 07:07:00 【DolphinDB Zhiyi Technology】
在金融领域,Valuation calculations for contracts are a common requirement.millions of contracts,Due to different expiry times and term lengths,Calculations often correspond to different interest rates.Contract matching rate,The most common approach is to perform calculations on each contract through a loop statement.而 DolphinDB 中,Can join functions through powerful tables,After linking the required information,再通过 SQL向量编程 进行计算.This optimization method is compared to the cyclic method,性能提升超 400 倍.
The main contents of this article are:Calculation logic and data preparation for foreign exchange swap valuation、开发环境配置、Valuation of ordinary foreign exchange swaps and optimization等.
The scripts in this article are in DolphinDB 1.30.18/2.00.6 Passed the test in the environment of the above version.
1. Calculation logic and data preparation for foreign exchange swap valuation
1.1 Calculation logic of foreign exchange swap valuation
The calculation of the overall logic below:
The logic of this foreign exchange swap valuation calculation,参考中国外汇交易中心2019年4月2In the website launched by the foreign exchange swap algorithm in valuing its holdings in the valuation service,That is, the far-end full-price exchange rate conversion on the day is calculated through the swap curve.,The net value is obtained by netting the cash flow generated by the full price exchange rate of the agreed transaction.,re-use today's Shibor3M(Shanghai Interbank Offered Rate) Interest rate swap closing curve for discounting,The final discounted value of the net contract amount is the contract valuation.
1.2 数据准备
The calculation of foreign exchange swap valuation requires two tables: swap curve interest rate and interest rate swap curve.The data in the above two tables were collected directly from2021年12月14Japan-China FX SwapUSD.CNYFX Swap Curve及Shibor3MInterest rate swap market curve.
数据结构分别为:
- USD.CNYFX Swap Curve:
name | typeString | comment |
---|---|---|
Date | DATE | 日期 |
timeminute | MINUTE | 时间 |
currencyPair | STRING | 货币对 |
termToMaturity | STRING | 期限品种 |
swapRate_Pips | DOUBLE | swap point |
exchangeRate | DOUBLE | full exchange rate |
maturityDate | DATE | Far value date |
- Shibor3MInterest rate swap market curve:
name | typeString | comment |
---|---|---|
Maturity | STRING | Standard term |
buying_rate | DOUBLE | buy(%) |
average_rate | DOUBLE | 均值(%) |
selling_rate | DOUBLE | offer(%) |
The contract data used in this tutorial is self-simulated10010,000 contracts with different expiration dates,数据结构为:
name | typeString | comment |
---|---|---|
contract_no | INT | 合约编号 |
contract_date | DATE | contract date |
trade_date | DATE | The proximal breath day |
maturity_date | DATE | Far value date |
buy_sell | STRING | 买卖方向 |
period | STRING | 期限 |
near_leg_currency | STRING | The proximal trading currency |
near_leg_amount | INT | 交易量 |
near_leg_spot_rate | DOUBLE | Near-end swap full price exchange rate |
far_leg_currency | STRING | remote clearing currency |
far_leg_spot_rate | DOUBLE | Far-end swap full price exchange rate |
For the above interest rate data and scripts for simulating contract data, please refer todata preparation script.
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
localSite=localhost:8848:local8848mode=singlemaxMemSize=64maxConnections=512workerNum=8localExecutors=7newValuePartitionPolicy=addwebWorkerNum=2dataSync=1
单节点部署教程:单节点部署
3. Common Realization of FX Swap Valuations
Since each contract has a different value date and contract term,Therefore, it will correspond to different swap rates and full-price exchange rates..The common implementation method is to customize a function that contains the evaluation calculation logic,通过循环语句,Each contract with corresponding interest rate to calculate.
The valuation function consisting of three tables is defined as follows:
def valuationDtmRate(today, swap_rate, IR_swap, maturity_date,far_leg_spot_rate, near_leg_amount){ target_swap_rate_next = select * from swap_rate where Date=today, currencyPair = `USD.CNY, maturityDate >=maturity_date limit 1 target_swap_rate_prev = select * from swap_rate where Date=today, currencyPair = `USD.CNY, maturityDate <=maturity_date order by maturityDate desc limit 1 tartget_IR_swap = select * from IR_swap where Maturity in (target_swap_rate_prev.termToMaturity[0],target_swap_rate_next.termToMaturity[0]) fex = target_swap_rate_prev.exchangeRate +(maturity_date - target_swap_rate_prev.maturityDate)\ (target_swap_rate_next.maturityDate-target_swap_rate_prev.maturityDate) * (target_swap_rate_next.exchangeRate - target_swap_rate_prev.exchangeRate) sir = tartget_IR_swap.selling_rate[0] + (maturity_date - target_swap_rate_prev.maturityDate)\ (target_swap_rate_next.maturityDate-target_swap_rate_prev.maturityDate) * ( tartget_IR_swap.selling_rate[1] - tartget_IR_swap.selling_rate[0]) dicount_factor = exp(-sir \ 100 * (maturity_date-today)\365) valuation = (fex - far_leg_spot_rate) * dicount_factor * near_leg_amount return valuation}
Because it involves information extraction between multiple tables,The function looks relatively complicated.做完这一步之后,It is possible to perform circular calculations on all contracts.100It takes about 10,000 contracts to calculate in the test environment3分20秒.
forCycle of writing code examples below:
today = 2021.12.14k = array(DOUBLE, 0)for (x in fx_contract){ k.append!(valuationDtmRate(today, swap_rate, IR_swap,x.maturity_date, x.far_leg_spot_rate, x.near_leg_amount))}result = fx_contract join table(k as valuation)
或用loopAn example of how to write a function is as follows:
k = loop(valuationDtmRate{today, swap_rate, IR_swap},fx_contract.maturity_date, fx_contract.far_leg_spot_rate, fx_contract.near_leg_amount).flatten()result = fx_contract join table(k as valuation)
Utilize multi-threaded parallel computing,Further optimization can be done on the same computational logic,Change the original single-threaded loop to multi-threaded parallel computing,最后将结果进行拼接.DolphinDB 提供了 ploop
/peach
函数,It is very convenient to convert the memory calculation of such loop statements into multi-threaded tasks.
This example uses8parallelism to compute,Final time approx.20秒:
k = ploop(valuationDtmRate{today, swap_rate, IR_swap},fx_contract.maturity_date, fx_contract.far_leg_spot_rate, fx_contract.near_leg_amount).flatten()result = fx_contract join table(k as valuation)
注意:ploop
/peach
The degree of parallelism is determined by the localExecutors 控制,默认值是 CPU 内核数减1.In the factor implementation of batch-stream integration,不建议使用ploop
/peach
并行加速.For specific parallel strategies, please refer to Factor Best Practices in Parallel Computing Chapter.
4. Optimized Implementation of FX Swap Valuations
DolphinDB Many table association functions are provided in,Therefore, the original two small tables swap_rate 和 IR_rate and contract table,You can first extract the effective information through the table association function,then directly through SQL just do the calculation.如此一来,Avoid the repeated consumption of resources by the loop statement,Also reduces the amount of code development.
When doing FX swap valuation calculations,可以用 equal join
, asof join
及 window join
The required information such as the remote interest rate is obtained by correlating the three tables,代码如下:
today = 2021.12.14tmp = select * from ej(swap_rate,IR_swap,`termToMaturity, `Maturity) where Date = todayres_aj=aj(fx_contract,tmp, `maturity_date, `maturityDate)res_wj=wj(res_aj,tmp, 0d:366d,<[first(termToMaturity) as next_termToMaturity, first(exchangeRate) as next_exchangeRate, first(maturityDate) as next_maturityDate,first(buying_rate) as next_buying_rate, first(average_rate) as next_average_rate, first(selling_rate) as next_selling_rate]>, `maturity_date, `maturityDate)
Since the associated information can be stored in a table( res_wj )中得到,Therefore, the calculation logic can also be simplified,The original formula logic can be intuitively translated for vectorized calculation:
def valuationSQL(exchangeRate,maturity_date, maturityDate, next_maturityDate, next_exchangeRate, far_leg_spot_rate, selling_rate, next_selling_rate,today, near_leg_amount){ return (exchangeRate + (maturity_date - maturityDate)\ (next_maturityDate-maturityDate) * (next_exchangeRate - exchangeRate) - far_leg_spot_rate) * exp(-(selling_rate + (maturity_date - maturityDate)\ (next_maturityDate-maturityDate) * (next_selling_rate - selling_rate))\100 * (maturity_date-today)\365) * near_leg_amount}
Use the optimized table association logic for foreign exchange swap valuation calculations,The overall time is only0.5秒左右,Performance has been improved over the original400倍.
timer{ today = 2021.12.14 tmp = select * from ej(swap_rate,IR_swap,`termToMaturity, `Maturity) where Date = today res_aj=aj(fx_contract,tmp, `maturity_date, `maturityDate) res_wj=wj(res_aj,tmp, 0d:366d,<[first(termToMaturity) as next_termToMaturity, first(exchangeRate) as next_exchangeRate, first(maturityDate) as next_maturityDate,first(buying_rate) as next_buying_rate, first(average_rate) as next_average_rate, first(selling_rate) as next_selling_rate]>, `maturity_date, `maturityDate) result = select contract_no,contract_date,trade_date,maturity_date,buy_sell, period, near_leg_currency, near_leg_amount, near_leg_spot_rate, far_leg_currency, far_leg_spot_rate, valuationSQL(exchangeRate,maturity_date, maturityDate, next_maturityDate, next_exchangeRate, far_leg_spot_rate, selling_rate, next_selling_rate,today, near_leg_amount) as valuation from res_wj}
5. 总结
For tasks that require multi-table data calculations,The performance of the loop statement is poor.建议先用 DolphinDB 优化的 asof join
等The table association function will extract the required information.asof join
Table, such as correlation functions also supports distributed association,The table can also be stored in the database distributed multithreaded parallel connection,性能卓越.计算部分建议使用 SQL The way of vectorized programming做计算,Not only can reduce the amount of code development(The calculation formula can be basically translated intuitively),Also avoid the repeated consumption loop statement CPU 资源.
6. 代码附录
边栏推荐
猜你喜欢
随机推荐
Shiny02---Shiny异常解决
Unable to import torchvision. IO. Read_image
RK3568环境安装
【MyCat简单介绍】
360度反馈调查表中的问题示范
1、Citrix XenDesktop 2203之AD域系统安装(一)
【工具配置篇】VSCode 常用使用总结
Database table insert data
在小程序中关于js数字精度丢失的解决办法
日本卫生设备行业协会:日本温水喷淋马桶座出货量达1亿套
Hong Kong International Jewellery Show and Hong Kong International Diamond, Gem and Pearl Show kick off
typescript60-泛型工具类型(readonly)
香港国际珠宝展及香港国际钻石、宝石及珍珠展揭幕
export使用
Linux中安装Redis教程
Rapid Medical's Ultra-Small and Only Adjustable Thromb Retriever Receives FDA Clearance
Shiny04---Application of DT and progress bar in shiny
PCI Pharma Services宣布斥资数百万美元扩建英国制造设施,以满足市场对支持肿瘤治疗的全球高效药制造服务日益增长的需求
Promise (3) async/await
Kioxia and Aerospike Collaborate to Improve Database Application Performance