Почему эти бета-версии не совпадают? - PullRequest
1 голос
/ 08 октября 2019

Я также спрашивал о Quant Finance, но я думал, что здесь тоже кто-то может помочь: https://quant.stackexchange.com/questions/49099/why-dont-these-betas-match

Я ожидаю, что бета-версия моего портфеля при сравнении с рынком будет соответствовать моим бета-версиям отдельных компонентов, умноженным на весовые коэффициенты портфеля. ,Я создал простой пример ниже. Любая помощь в объяснении, где я ошибся, будет высоко ценится.

import pandas as pd
    import numpy as np
    import statsmodels.api as sm
    from statsmodels import regression

    def beta(x, y):
        x = sm.add_constant(x)
        model = regression.linear_model.OLS(y, x).fit()
        # Remove the constant now that we're done
        x = x[:, 1]
        return model.params[1]


    bond_one = [100, 96, 102, 88, 96, 101, 120, 110, 105, 107, 106]
    bond_two = [98, 102, 88, 95, 105, 100, 101, 99, 104, 108, 112]
    mkt = [1000, 1004, 1000, 1010, 1020, 1000, 990, 995, 1005, 1025, 1035]

    df_mkt = pd.DataFrame(mkt, columns = ['mkt'])
    df_mkt = df_mkt.pct_change().dropna()
    df = pd.DataFrame(bond_one, columns = ['bond_one'])
    df['bond_two'] = bond_two

    df_price = df.copy()
    df = df.pct_change().dropna()

    notionals = {'bond_one': 2500000,
                    'bond_two': 6500000}

    mkt_values = {key: value*(df_price[key].iloc[-1]/100)
                  for (key, value) in notionals.items()}

    #create portfolio market value
    tot_port = sum(list(mkt_values.values()))
    #generate weights
    wts = {key: value/tot_port for (key, value) in mkt_values.items()}

    #create portfolio returns
    df_port = df.copy()*0
    df_port = df.mul(list(wts.values()), axis=1)
    df_port['port'] = df_port.sum(axis=1)

    #add port and market into original dataframe
    df['port'] = df_port['port'].copy()
    df['mkt'] = df_mkt['mkt'].copy()

    #run OLS on individuals and portfolio
    b1_beta = regression.linear_model.OLS(x = df['bond_one'].values, y=df['mkt'].values).fit()
    b2_beta = beta(x=df['bond_two'].values, y=df['mkt'].values)
    port_beta = beta(x=df['port'].values, y=df['mkt'].values)

    calc_beta = wts['bond_one']*b1_beta + wts['bond_two']*b2_beta
    ###why don't calc_beta and port_beta match?

1 Ответ

1 голос
/ 09 октября 2019

Разница связана с наличием (или его отсутствием) весов портфеля в регрессии. Поскольку стоимость составляющих вашего портфеля меняется ежедневно, то же самое происходит и с весами. port_beta - это бета-версия стоимости вашего портфеля во времени до market, тогда как calc_beta - это взвешенная сумма беты по компонентам портфеля. Разница возникает главным образом из-за того, что calc_beta вычисляется с использованием текущих весов, тогда как port_beta рассчитывается по историческим весам.

...