{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "### Loan" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
Connecting engine server -> https://absbox.org/api/dev\n",
       "
\n" ], "text/plain": [ "\u001b[1;35mConnecting engine server -> \u001b[0m\u001b[1;4;35mhttps://absbox.org/api/dev\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "text/html": [ "
Connected, local lib:0.26.4, server:0.27.6\n",
       "
\n" ], "text/plain": [ "✅\u001b[1;32mConnected, local li\u001b[0m\u001b[1;32mb:0\u001b[0m\u001b[1;32m.\u001b[0m\u001b[1;32m26.4\u001b[0m\u001b[1;32m, server:\u001b[0m\u001b[1;32m0.27\u001b[0m\u001b[1;32m.\u001b[0m\u001b[1;32m6\u001b[0m\n" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "from absbox import API,EnginePath\n", "\n", "localAPI = API(EnginePath.DEV,lang='english',check=False)" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [], "source": [ "loan1 = [\"Loan\"\n", " ,{\"originBalance\": 80000\n", " ,\"originRate\": [\"floater\",0.045,{\"index\":\"SOFR3M\"\n", " ,\"spread\":0.01\n", " ,\"reset\":\"QuarterEnd\"}]\n", " ,\"originTerm\": 24\n", " ,\"freq\": \"Monthly\"\n", " ,\"type\": \"i_p\"\n", " ,\"originDate\": \"2021-03-01\"}\n", " ,{\"currentBalance\": 65000\n", " ,\"currentRate\": 0.06\n", " ,\"remainTerm\": 12\n", " ,\"status\": \"Current\"}]" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
BalancePrincipalInterestPrepaymentDefaultRecoveryLossWACCumPrincipalCumPrepayCumDelinqCumDefaultCumRecoveryCumLoss
Date
2022-03-016500000.0000000.06000000
2022-04-01650000331.2300000.06000000
2022-05-01650000320.5400000.06000000
2022-06-01650000331.2300000.06000000
2022-07-01650000267.1200000.05000000
\n", "
" ], "text/plain": [ " Balance Principal Interest Prepayment Default Recovery Loss \\\n", "Date \n", "2022-03-01 65000 0 0.00 0 0 0 0 \n", "2022-04-01 65000 0 331.23 0 0 0 0 \n", "2022-05-01 65000 0 320.54 0 0 0 0 \n", "2022-06-01 65000 0 331.23 0 0 0 0 \n", "2022-07-01 65000 0 267.12 0 0 0 0 \n", "\n", " WAC CumPrincipal CumPrepay CumDelinq CumDefault CumRecovery \\\n", "Date \n", "2022-03-01 0.06 0 0 0 0 0 \n", "2022-04-01 0.06 0 0 0 0 0 \n", "2022-05-01 0.06 0 0 0 0 0 \n", "2022-06-01 0.06 0 0 0 0 0 \n", "2022-07-01 0.05 0 0 0 0 0 \n", "\n", " CumLoss \n", "Date \n", "2022-03-01 0 \n", "2022-04-01 0 \n", "2022-05-01 0 \n", "2022-06-01 0 \n", "2022-07-01 0 " ] }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "r = localAPI.runAsset(\"2020-01-02\"\n", " ,[loan1]\n", " ,poolAssump=(\"Pool\",(\"Loan\",None,None,None,None)\n", " ,None\n", " ,None)\n", " ,rateAssump=[(\"SOFR3M\",0.04)]\n", " ,read=True)\n", "\n", "r[0].head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### Default" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
BalancePrincipalInterestPrepaymentDefaultRecoveryLossWACCumPrincipalCumPrepayCumDelinqCumDefaultCumRecoveryCumLoss
Date
2022-03-0165000.000.00.0000.0000.000.060.0000.0000.00
2022-04-0164944.550.0330.95055.45055.450.060.00055.45055.45
2022-05-0164890.930.0320.01053.62053.620.060.000109.070109.07
2022-06-0164835.570.0330.39055.36055.360.060.000164.430164.43
2022-07-0164782.040.0266.22053.53053.530.050.000217.960217.96
\n", "
" ], "text/plain": [ " Balance Principal Interest Prepayment Default Recovery \\\n", "Date \n", "2022-03-01 65000.00 0.0 0.00 0 0.00 0 \n", "2022-04-01 64944.55 0.0 330.95 0 55.45 0 \n", "2022-05-01 64890.93 0.0 320.01 0 53.62 0 \n", "2022-06-01 64835.57 0.0 330.39 0 55.36 0 \n", "2022-07-01 64782.04 0.0 266.22 0 53.53 0 \n", "\n", " Loss WAC CumPrincipal CumPrepay CumDelinq CumDefault \\\n", "Date \n", "2022-03-01 0.00 0.06 0.0 0 0 0.00 \n", "2022-04-01 55.45 0.06 0.0 0 0 55.45 \n", "2022-05-01 53.62 0.06 0.0 0 0 109.07 \n", "2022-06-01 55.36 0.06 0.0 0 0 164.43 \n", "2022-07-01 53.53 0.05 0.0 0 0 217.96 \n", "\n", " CumRecovery CumLoss \n", "Date \n", "2022-03-01 0 0.00 \n", "2022-04-01 0 55.45 \n", "2022-05-01 0 109.07 \n", "2022-06-01 0 164.43 \n", "2022-07-01 0 217.96 " ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "r = localAPI.runAsset(\"2020-01-02\"\n", " ,[loan1]\n", " ,poolAssump=(\"Pool\",(\"Loan\",{\"CDR\":0.01},None,None,None)\n", " ,None\n", " ,None)\n", " ,rateAssump=[(\"SOFR3M\",0.04)]\n", " ,read=True)\n", "\n", "r[0].head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### Prepayment" ] }, { "cell_type": "code", "execution_count": 7, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
BalancePrincipalInterestPrepaymentDefaultRecoveryLossWACCumPrincipalCumPrepayCumDelinqCumDefaultCumRecoveryCumLoss
Date
2022-03-0165000.000.00.000.000000.060.00.000000
2022-04-0164944.550.0330.9555.450000.060.055.450000
2022-05-0164890.930.0320.0153.620000.060.0109.070000
2022-06-0164835.570.0330.3955.360000.060.0164.430000
2022-07-0164782.040.0266.2253.530000.050.0217.960000
\n", "
" ], "text/plain": [ " Balance Principal Interest Prepayment Default Recovery \\\n", "Date \n", "2022-03-01 65000.00 0.0 0.00 0.00 0 0 \n", "2022-04-01 64944.55 0.0 330.95 55.45 0 0 \n", "2022-05-01 64890.93 0.0 320.01 53.62 0 0 \n", "2022-06-01 64835.57 0.0 330.39 55.36 0 0 \n", "2022-07-01 64782.04 0.0 266.22 53.53 0 0 \n", "\n", " Loss WAC CumPrincipal CumPrepay CumDelinq CumDefault \\\n", "Date \n", "2022-03-01 0 0.06 0.0 0.00 0 0 \n", "2022-04-01 0 0.06 0.0 55.45 0 0 \n", "2022-05-01 0 0.06 0.0 109.07 0 0 \n", "2022-06-01 0 0.06 0.0 164.43 0 0 \n", "2022-07-01 0 0.05 0.0 217.96 0 0 \n", "\n", " CumRecovery CumLoss \n", "Date \n", "2022-03-01 0 0 \n", "2022-04-01 0 0 \n", "2022-05-01 0 0 \n", "2022-06-01 0 0 \n", "2022-07-01 0 0 " ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "r = localAPI.runAsset(\"2020-01-02\"\n", " ,[loan1]\n", " ,poolAssump=(\"Pool\",(\"Loan\",None,{\"CPR\":0.01},None,None)\n", " ,None\n", " ,None)\n", " ,rateAssump=[(\"SOFR3M\",0.04)]\n", " ,read=True)\n", "\n", "r[0].head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "#### Loan With Schedule Repayment" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
BalancePrincipalInterestPrepaymentDefaultRecoveryLossWACCumPrincipalCumPrepayCumDelinqCumDefaultCumRecoveryCumLoss
Date
2021-03-018000000.0000000.06000000
2021-10-1060000200002932.6000000.062000000000
2022-01-104000020000756.1600000.054000000000
2022-10-100400001495.8900000.058000000000
\n", "
" ], "text/plain": [ " Balance Principal Interest Prepayment Default Recovery Loss \\\n", "Date \n", "2021-03-01 80000 0 0.00 0 0 0 0 \n", "2021-10-10 60000 20000 2932.60 0 0 0 0 \n", "2022-01-10 40000 20000 756.16 0 0 0 0 \n", "2022-10-10 0 40000 1495.89 0 0 0 0 \n", "\n", " WAC CumPrincipal CumPrepay CumDelinq CumDefault CumRecovery \\\n", "Date \n", "2021-03-01 0.06 0 0 0 0 0 \n", "2021-10-10 0.06 20000 0 0 0 0 \n", "2022-01-10 0.05 40000 0 0 0 0 \n", "2022-10-10 0.05 80000 0 0 0 0 \n", "\n", " CumLoss \n", "Date \n", "2021-03-01 0 \n", "2021-10-10 0 \n", "2022-01-10 0 \n", "2022-10-10 0 " ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" } ], "source": [ "loan2 = [\"Loan\"\n", " ,{\"originBalance\": 80000\n", " ,\"originRate\": [\"floater\",0.045,{\"index\":\"SOFR3M\"\n", " ,\"spread\":0.01\n", " ,\"reset\":\"QuarterEnd\"}]\n", " ,\"originTerm\": 3\n", " ,\"freq\": \"SemiAnnually\"\n", " ,\"type\": (\"Schedule\",[[\"2021-10-10\",20000]\n", " ,[\"2022-01-10\",20000]\n", " ,[\"2022-10-10\",40000]\n", " ])\n", " ,\"originDate\": \"2021-03-01\"}\n", " ,{\"currentBalance\": 80000\n", " ,\"currentRate\": 0.06\n", " ,\"remainTerm\": 3\n", " ,\"status\": \"Current\"}]\n", "\n", "r = localAPI.runAsset(\"2020-01-02\"\n", " ,[loan2]\n", " ,poolAssump=(\"Pool\",(\"Loan\",None,None,None,None)\n", " ,None\n", " ,None)\n", " ,rateAssump=[(\"SOFR3M\",0.04)]\n", " ,read=True)\n", "\n", "r[0].head()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "##### Schedule Repayment with stress" ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [ { "data": { "text/html": [ "
\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "
BalancePrincipalInterestPrepaymentDefaultRecoveryLossWACCumPrincipalCumPrepayCumDelinqCumDefaultCumRecoveryCumLoss
Date
2021-03-0180000.000.000.000.000000.060.000.000000
2021-10-1059632.7219877.562914.65489.720000.0619877.56489.720000
2022-01-1039654.5819827.27749.63150.870000.0539704.83640.590000
2022-10-100.0039357.621471.86296.960000.0579062.45937.550000
\n", "
" ], "text/plain": [ " Balance Principal Interest Prepayment Default Recovery \\\n", "Date \n", "2021-03-01 80000.00 0.00 0.00 0.00 0 0 \n", "2021-10-10 59632.72 19877.56 2914.65 489.72 0 0 \n", "2022-01-10 39654.58 19827.27 749.63 150.87 0 0 \n", "2022-10-10 0.00 39357.62 1471.86 296.96 0 0 \n", "\n", " Loss WAC CumPrincipal CumPrepay CumDelinq CumDefault \\\n", "Date \n", "2021-03-01 0 0.06 0.00 0.00 0 0 \n", "2021-10-10 0 0.06 19877.56 489.72 0 0 \n", "2022-01-10 0 0.05 39704.83 640.59 0 0 \n", "2022-10-10 0 0.05 79062.45 937.55 0 0 \n", "\n", " CumRecovery CumLoss \n", "Date \n", "2021-03-01 0 0 \n", "2021-10-10 0 0 \n", "2022-01-10 0 0 \n", "2022-10-10 0 0 " ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "r = localAPI.runAsset(\"2020-01-02\"\n", " ,[loan2]\n", " ,poolAssump=(\"Pool\",(\"Loan\",None,{\"CPR\":0.01},None,None)\n", " ,None\n", " ,None)\n", " ,rateAssump=[(\"SOFR3M\",0.04)]\n", " ,read=True)\n", "\n", "r[0].head()" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3 (ipykernel)", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.12.3" } }, "nbformat": 4, "nbformat_minor": 2 }