Source code for pharmpy.modeling.math

from __future__ import annotations

from pharmpy.deps import numpy as np
from pharmpy.deps import pandas as pd
from pharmpy.internals.math import cov2corr


[docs] def calculate_se_from_cov(cov: pd.DataFrame): """Calculate standard errors from a covariance matrix Parameters ---------- cov : pd.DataFrame Input covariance matrix Return ------ pd.Series Standard errors Examples -------- >>> from pharmpy.modeling import calculate_se_from_cov >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> cov = results.covariance_matrix >>> cov POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 4.408600e-08 4.761930e-08 -0.000002 -0.000001 1.552150e-07 8.042430e-08 POP_VC 4.761930e-08 7.233190e-04 -0.000804 0.000050 7.174490e-05 1.467290e-05 COVAPGR -1.679560e-06 -8.041750e-04 0.007015 -0.000108 -3.935790e-05 2.922260e-05 IIV_CL -1.090290e-06 4.989580e-05 -0.000108 0.000180 -1.863210e-05 5.049910e-06 IIV_VC 1.552150e-07 7.174490e-05 -0.000039 -0.000019 5.588920e-05 -4.497590e-07 SIGMA 8.042430e-08 1.467290e-05 0.000029 0.000005 -4.497590e-07 5.197970e-06 >>> calculate_se_from_cov(cov) POP_CL 0.000210 POP_VC 0.026895 COVAPGR 0.083756 IIV_CL 0.013416 IIV_VC 0.007476 SIGMA 0.002280 dtype: float64 See also -------- calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ se = pd.Series(np.sqrt(np.diag(cov.values)), index=cov.index) return se
[docs] def calculate_se_from_prec(precision_matrix: pd.DataFrame): """Calculate standard errors from a precision matrix Parameters ---------- precision_matrix : pd.DataFrame Input precision matrix Return ------ pd.Series Standard errors Examples -------- >>> from pharmpy.modeling import calculate_se_from_prec >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> prec = results.precision_matrix >>> prec POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 2.993428e+07 22261.039122 16027.859538 203633.930854 -39113.269503 -817314.801755 POP_VC 2.226104e+04 2129.852212 260.115313 -373.896066 -2799.330946 -7697.921603 COVAPGR 1.602786e+04 260.115313 187.053488 177.987340 -205.261483 -2224.522815 IIV_CL 2.036339e+05 -373.896066 177.987340 7542.279597 2472.034556 -10209.416944 IIV_VC -3.911327e+04 -2799.330946 -205.261483 2472.034556 22348.216559 9193.203130 SIGMA -8.173148e+05 -7697.921603 -2224.522815 -10209.416944 9193.203130 249978.454601 >>> calculate_se_from_prec(prec) POP_CL 0.000210 POP_VC 0.026895 COVAPGR 0.083756 IIV_CL 0.013416 IIV_VC 0.007476 SIGMA 0.002280 dtype: float64 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ se = pd.Series( np.sqrt(np.diag(np.linalg.inv(precision_matrix.values))), index=precision_matrix.index ) return se
[docs] def calculate_corr_from_cov(cov: pd.DataFrame): """Calculate correlation matrix from a covariance matrix Parameters ---------- cov : pd.DataFrame Covariance matrix Return ------ pd.DataFrame Correlation matrix Examples -------- >>> from pharmpy.modeling import calculate_corr_from_cov >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> cov = results.covariance_matrix >>> cov POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 4.408600e-08 4.761930e-08 -0.000002 -0.000001 1.552150e-07 8.042430e-08 POP_VC 4.761930e-08 7.233190e-04 -0.000804 0.000050 7.174490e-05 1.467290e-05 COVAPGR -1.679560e-06 -8.041750e-04 0.007015 -0.000108 -3.935790e-05 2.922260e-05 IIV_CL -1.090290e-06 4.989580e-05 -0.000108 0.000180 -1.863210e-05 5.049910e-06 IIV_VC 1.552150e-07 7.174490e-05 -0.000039 -0.000019 5.588920e-05 -4.497590e-07 SIGMA 8.042430e-08 1.467290e-05 0.000029 0.000005 -4.497590e-07 5.197970e-06 >>> calculate_corr_from_cov(cov) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 1.000000 0.008433 -0.095506 -0.387063 0.098882 0.168004 POP_VC 0.008433 1.000000 -0.357003 0.138290 0.356831 0.239295 COVAPGR -0.095506 -0.357003 1.000000 -0.095767 -0.062857 0.153034 IIV_CL -0.387063 0.138290 -0.095767 1.000000 -0.185775 0.165104 IIV_VC 0.098882 0.356831 -0.062857 -0.185775 1.000000 -0.026388 SIGMA 0.168004 0.239295 0.153034 0.165104 -0.026388 1.000000 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ corr = pd.DataFrame(cov2corr(cov.values), index=cov.index, columns=cov.columns) return corr
[docs] def calculate_cov_from_prec(precision_matrix: pd.DataFrame): """Calculate covariance matrix from a precision matrix Parameters ---------- precision_matrix : pd.DataFrame Precision matrix Return ------ pd.DataFrame Covariance matrix Examples -------- >>> from pharmpy.modeling import calculate_cov_from_prec >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> prec = results.precision_matrix >>> prec POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 2.993428e+07 22261.039122 16027.859538 203633.930854 -39113.269503 -817314.801755 POP_VC 2.226104e+04 2129.852212 260.115313 -373.896066 -2799.330946 -7697.921603 COVAPGR 1.602786e+04 260.115313 187.053488 177.987340 -205.261483 -2224.522815 IIV_CL 2.036339e+05 -373.896066 177.987340 7542.279597 2472.034556 -10209.416944 IIV_VC -3.911327e+04 -2799.330946 -205.261483 2472.034556 22348.216559 9193.203130 SIGMA -8.173148e+05 -7697.921603 -2224.522815 -10209.416944 9193.203130 249978.454601 >>> calculate_cov_from_prec(prec) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 4.408600e-08 4.761930e-08 -0.000002 -0.000001 1.552150e-07 8.042430e-08 POP_VC 4.761930e-08 7.233190e-04 -0.000804 0.000050 7.174490e-05 1.467290e-05 COVAPGR -1.679560e-06 -8.041750e-04 0.007015 -0.000108 -3.935790e-05 2.922260e-05 IIV_CL -1.090290e-06 4.989580e-05 -0.000108 0.000180 -1.863210e-05 5.049910e-06 IIV_VC 1.552150e-07 7.174490e-05 -0.000039 -0.000019 5.588920e-05 -4.497590e-07 SIGMA 8.042430e-08 1.467290e-05 0.000029 0.000005 -4.497590e-07 5.197970e-06 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ cov = pd.DataFrame( np.linalg.inv(precision_matrix.values), index=precision_matrix.index, columns=precision_matrix.columns, ) return cov
[docs] def calculate_cov_from_corrse(corr: pd.DataFrame, se: pd.Series): """Calculate covariance matrix from a correlation matrix and standard errors Parameters ---------- corr : pd.DataFrame Correlation matrix se : pd.Series Standard errors Return ------ pd.DataFrame Covariance matrix Examples -------- >>> from pharmpy.modeling import calculate_cov_from_corrse >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> corr = results.correlation_matrix >>> se = results.standard_errors >>> corr POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 1.000000 0.008433 -0.095506 -0.387063 0.098882 0.168004 POP_VC 0.008433 1.000000 -0.357003 0.138290 0.356831 0.239295 COVAPGR -0.095506 -0.357003 1.000000 -0.095767 -0.062857 0.153034 IIV_CL -0.387063 0.138290 -0.095767 1.000000 -0.185775 0.165104 IIV_VC 0.098882 0.356831 -0.062857 -0.185775 1.000000 -0.026388 SIGMA 0.168004 0.239295 0.153034 0.165104 -0.026388 1.000000 >>> calculate_cov_from_corrse(corr, se) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 4.408614e-08 4.761939e-08 -0.000002 -0.000001 1.552153e-07 8.042458e-08 POP_VC 4.761939e-08 7.233195e-04 -0.000804 0.000050 7.174494e-05 1.467293e-05 COVAPGR -1.679562e-06 -8.041749e-04 0.007015 -0.000108 -3.935789e-05 2.922264e-05 IIV_CL -1.090293e-06 4.989586e-05 -0.000108 0.000180 -1.863212e-05 5.049924e-06 IIV_VC 1.552153e-07 7.174494e-05 -0.000039 -0.000019 5.588923e-05 -4.497600e-07 SIGMA 8.042458e-08 1.467293e-05 0.000029 0.000005 -4.497600e-07 5.197990e-06 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ sd_matrix = np.diag(se.to_numpy()) cov = sd_matrix @ corr.values @ sd_matrix cov_df = pd.DataFrame(cov, index=corr.index, columns=corr.columns) return cov_df
[docs] def calculate_prec_from_cov(cov: pd.DataFrame): """Calculate precision matrix from a covariance matrix Parameters ---------- cov : pd.DataFrame Covariance matrix Return ------ pd.DataFrame Precision matrix Examples -------- >>> from pharmpy.modeling import calculate_prec_from_cov >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> cov = results.covariance_matrix >>> cov POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 4.408600e-08 4.761930e-08 -0.000002 -0.000001 1.552150e-07 8.042430e-08 POP_VC 4.761930e-08 7.233190e-04 -0.000804 0.000050 7.174490e-05 1.467290e-05 COVAPGR -1.679560e-06 -8.041750e-04 0.007015 -0.000108 -3.935790e-05 2.922260e-05 IIV_CL -1.090290e-06 4.989580e-05 -0.000108 0.000180 -1.863210e-05 5.049910e-06 IIV_VC 1.552150e-07 7.174490e-05 -0.000039 -0.000019 5.588920e-05 -4.497590e-07 SIGMA 8.042430e-08 1.467290e-05 0.000029 0.000005 -4.497590e-07 5.197970e-06 >>> calculate_prec_from_cov(cov) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 2.993428e+07 22261.039122 16027.859538 203633.930854 -39113.269503 -817314.801755 POP_VC 2.226104e+04 2129.852212 260.115313 -373.896066 -2799.330946 -7697.921603 COVAPGR 1.602786e+04 260.115313 187.053488 177.987340 -205.261483 -2224.522815 IIV_CL 2.036339e+05 -373.896066 177.987340 7542.279597 2472.034556 -10209.416944 IIV_VC -3.911327e+04 -2799.330946 -205.261483 2472.034556 22348.216559 9193.203130 SIGMA -8.173148e+05 -7697.921603 -2224.522815 -10209.416944 9193.203130 249978.454601 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors calculate_corr_from_prec : Correlation matrix from precision matrix """ Pm = pd.DataFrame(np.linalg.inv(cov.values), index=cov.index, columns=cov.columns) return Pm
[docs] def calculate_prec_from_corrse(corr: pd.DataFrame, se: pd.Series): """Calculate precision matrix from a correlation matrix and standard errors Parameters ---------- corr : pd.DataFrame Correlation matrix se : pd.Series Standard errors Return ------ pd.DataFrame Precision matrix Examples -------- >>> from pharmpy.modeling import calculate_prec_from_corrse >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> corr = results.correlation_matrix >>> se = results.standard_errors >>> corr POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 1.000000 0.008433 -0.095506 -0.387063 0.098882 0.168004 POP_VC 0.008433 1.000000 -0.357003 0.138290 0.356831 0.239295 COVAPGR -0.095506 -0.357003 1.000000 -0.095767 -0.062857 0.153034 IIV_CL -0.387063 0.138290 -0.095767 1.000000 -0.185775 0.165104 IIV_VC 0.098882 0.356831 -0.062857 -0.185775 1.000000 -0.026388 SIGMA 0.168004 0.239295 0.153034 0.165104 -0.026388 1.000000 >>> calculate_prec_from_corrse(corr, se) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 2.993418e+07 22260.995666 16027.840996 203633.422078 -39113.196303 -817311.952371 POP_VC 2.226100e+04 2129.850713 260.115336 -373.895598 -2799.329201 -7697.904374 COVAPGR 1.602784e+04 260.115336 187.053654 177.987259 -205.261518 -2224.519605 IIV_CL 2.036334e+05 -373.895598 177.987259 7542.266046 2472.031665 -10209.388516 IIV_VC -3.911320e+04 -2799.329201 -205.261518 2472.031665 22348.204432 9193.183296 SIGMA -8.173120e+05 -7697.904374 -2224.519605 -10209.388516 9193.183296 249977.511621 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_corr_from_prec : Correlation matrix from precision matrix """ sd_matrix = np.diag(se.to_numpy()) cov = sd_matrix @ corr.values @ sd_matrix Pm = pd.DataFrame(np.linalg.inv(cov), index=corr.index, columns=corr.columns) return Pm
[docs] def calculate_corr_from_prec(precision_matrix: pd.DataFrame): """Calculate correlation matrix from a precision matrix Parameters ---------- precision_matrix : pd.DataFrame Precision matrix Return ------ pd.DataFrame Correlation matrix Examples -------- >>> from pharmpy.modeling import calculate_corr_from_prec >>> from pharmpy.tools import load_example_modelfit_results >>> results = load_example_modelfit_results("pheno") >>> prec = results.precision_matrix >>> prec POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 2.993428e+07 22261.039122 16027.859538 203633.930854 -39113.269503 -817314.801755 POP_VC 2.226104e+04 2129.852212 260.115313 -373.896066 -2799.330946 -7697.921603 COVAPGR 1.602786e+04 260.115313 187.053488 177.987340 -205.261483 -2224.522815 IIV_CL 2.036339e+05 -373.896066 177.987340 7542.279597 2472.034556 -10209.416944 IIV_VC -3.911327e+04 -2799.330946 -205.261483 2472.034556 22348.216559 9193.203130 SIGMA -8.173148e+05 -7697.921603 -2224.522815 -10209.416944 9193.203130 249978.454601 >>> calculate_corr_from_prec(prec) POP_CL POP_VC COVAPGR IIV_CL IIV_VC SIGMA POP_CL 1.000000 0.008433 -0.095506 -0.387063 0.098882 0.168004 POP_VC 0.008433 1.000000 -0.357003 0.138290 0.356831 0.239295 COVAPGR -0.095506 -0.357003 1.000000 -0.095767 -0.062857 0.153034 IIV_CL -0.387063 0.138290 -0.095767 1.000000 -0.185775 0.165104 IIV_VC 0.098882 0.356831 -0.062857 -0.185775 1.000000 -0.026388 SIGMA 0.168004 0.239295 0.153034 0.165104 -0.026388 1.000000 See also -------- calculate_se_from_cov : Standard errors from covariance matrix calculate_se_from_prec : Standard errors from precision matrix calculate_corr_from_cov : Correlation matrix from covariance matrix calculate_cov_from_prec : Covariance matrix from precision matrix calculate_cov_from_corrse : Covariance matrix from correlation matrix and standard errors calculate_prec_from_cov : Precision matrix from covariance matrix calculate_prec_from_corrse : Precision matrix from correlation matrix and standard errors """ corr = pd.DataFrame( cov2corr(np.linalg.inv(precision_matrix.values)), index=precision_matrix.index, columns=precision_matrix.columns, ) return corr