PortfolioMAD

Создайте объект PortfolioMAD для средней абсолютной оптимизации портфеля отклонения и анализа

Описание

Объект PortfolioMAD реализует среднюю абсолютную оптимизацию портфеля отклонения, где MAD обозначает “среднее абсолютное отклонение”. PortfolioMAD возражает функциям поддержки, которые характерны для оптимизации портфеля MAD.

Основной рабочий процесс для оптимизации портфеля MAD должен создать экземпляр объекта PortfolioMAD, который полностью задает задачу оптимизации портфеля и работать с объектом PortfolioMAD получить и анализировать эффективные портфели. Для получения дополнительной информации о рабочем процессе при использовании объектов PortfolioMAD смотрите Рабочий процесс Объекта PortfolioMAD.

Можно использовать объект PortfolioMAD несколькими способами. Чтобы настроить задачу оптимизации портфеля в объекте PortfolioMAD, самый простой синтаксис:

p = PortfolioMAD;
Этот синтаксис создает объект PortfolioMAD, p, такой, что все свойства объектов пусты.

Объект PortfolioMAD также принимает наборы аргументов пары "имя-значение" для свойств и их значений. Объект PortfolioMAD принимает входные параметры для свойств с общим синтаксисом:

	p = PortfolioMAD('property1',value1,'property2',value2, ... );

Если объект PortfolioMAD существует, синтаксис разрешает первое (и только первый аргумент) объекта PortfolioMAD быть существующим объектом с последующими аргументами пары "имя-значение" для свойств, которые будут добавлены или изменены. Например, учитывая существующий объект PortfolioMAD в p, общий синтаксис:

p = PortfolioMAD(p,'property1',value1,'property2',value2, ... );

Имена входного параметра не являются чувствительными к регистру, но должны быть полностью заданы. Кроме того, несколько свойств могут быть заданы с альтернативными именами аргумента (см. Ярлыки для Имен свойства). Объект PortfolioMAD пытается обнаружить проблемные размерности от входных параметров и, когда-то установить, последующие входные параметры могут подвергнуться различным скалярным или матричным операциям расширения, которые упрощают полный процесс, чтобы сформулировать проблему. Кроме того, объект PortfolioMAD является объектом значения так, чтобы, учитывая портфель p следующий код создал два объекта, p и q, которые отличны:

q = PortfolioMAD(p, ...)

После создания объекта PortfolioMAD можно использовать связанные объектные функции, чтобы установить ограничения портфеля, анализировать границу эффективности и подтвердить модель портфеля.

Для более подробной информации на теоретической основе для условной подверженной риску значения оптимизации портфеля см. Теорию Оптимизации Портфеля.

Создание

Синтаксис

p = PortfolioMAD
p = PortfolioMAD(Name,Value)
p = PortfolioMAD(p,Name,Value)

Описание

пример

p = PortfolioMAD создает пустой объект PortfolioMAD для средней абсолютной оптимизации портфеля отклонения и анализа. Можно затем добавить, что элементы к объекту PortfolioMAD с помощью поддерживаемого "добавляют" и "устанавливают" функции. Для получения дополнительной информации смотрите Создание Объекта PortfolioMAD.

пример

p = PortfolioMAD(Name,Value) создает объект PortfolioMAD (p) и устанавливает Свойства с помощью пар "имя-значение". Например, p = PortfolioMAD('AssetList',Assets(1:12)). Можно задать несколько пар "имя-значение".

пример

p = PortfolioMAD(p,Name,Value) создает объект PortfolioMAD (p) с помощью ранее созданного объекта PortfolioMAD p и устанавливает Свойства с помощью пар "имя-значение". Можно задать несколько пар "имя-значение".

Входные параметры

развернуть все

Ранее созданный объект PortfolioMAD, заданное использование PortfolioMAD.

Свойства

развернуть все

Подготовка объекта

Имена или символы активов во вселенной, заданной как массив ячеек из символьных векторов или массив строк.

Типы данных: cell | string

Начальный портфель, заданный как вектор.

Типы данных: double

Имя, например, объекта Portfolio, заданного как вектор символов.

Типы данных: char | string

Количество активов во вселенной, заданной как целочисленный скаляр.

Типы данных: double

Ограничения объекта портфеля

Линейная матрица ограничений равенства, заданная как матрица.

Типы данных: double

Линейная матрица ограничения неравенства, заданная как матрица.

Типы данных: double

Линейный ограничительный вектор равенства, заданный как вектор.

Типы данных: double

Линейный вектор ограничения неравенства, заданный как вектор.

Типы данных: double

Сгруппируйте веса, которые будут ограничены весами в группе B, заданной как матрица.

Типы данных: double

Веса группы B, заданные как матрица.

Типы данных: double

Матрица состава группы, заданная как матрица.

Типы данных: double

Ограничение нижней границы, заданное как вектор.

Типы данных: double

Ограничение бюджета нижней границы, заданное как скаляр.

Типы данных: double

Ограничение группы нижней границы, заданное как вектор.

Типы данных: double

Минимальное отношение выделений между GroupA и GroupB, заданным как вектор.

Типы данных: double

Ограничение верхней границы, заданное как вектор.

Типы данных: double

Ограничение бюджета верхней границы, заданное как скаляр.

Типы данных: double

Ограничение группы верхней границы, заданное как вектор.

Типы данных: double

Максимальное отношение выделений между GroupA и GroupB, заданным как вектор.

Типы данных: double

Тип границ для каждого веса актива, заданного как скалярный вектор символов или строка, или массив ячеек из символьных векторов или массив строк. Для получения дополнительной информации смотрите setBounds.

Типы данных: char | cell | string

Минимальное количество активов выделяется в портфеле, заданном как скалярное числовое значение. Для получения дополнительной информации смотрите setMinMaxNumAssets.

Типы данных: double

Максимальное количество активов выделяется в портфеле, заданном как скалярное числовое значение. Для получения дополнительной информации смотрите setMinMaxNumAssets.

Типы данных: double

Ограничение оборота на покупки, заданные как скаляр.

Типы данных: double

Ограничение оборота на продажи, заданные как скаляр.

Типы данных: double

Ограничение оборота, заданное как скаляр.

Типы данных: double

Объектное моделирование портфеля

Пропорциональные затраты на покупку, заданные как вектор.

Типы данных: double

Безрисковый уровень, заданный как скаляр.

Типы данных: double

Подверженный риску значения уровень вероятности, который является 1 − (вероятность потери), заданная как скаляр.

Типы данных: double

Количество сценариев, заданных как целочисленный скаляр.

Типы данных: double

Пропорциональные затраты на продажи, заданные как вектор.

Типы данных: double

Функции объекта

setAssetListНастройте список идентификаторов для активов
setInitPortНастройте начальный или текущий портфель
setDefaultConstraintsНастройте ограничения портфеля с неотрицательными весами та сумма к 1
estimateAssetMomentsОценочное среднее значение и ковариация актива возвращаются из данных
setCostsНастройте пропорциональные операционные издержки
addEqualityДобавьте линейные ограничения равенства для весов портфеля к существующим ограничениям
addGroupRatioДобавьте ограничения отношения группы для весов портфеля к существующим ограничениям отношения группы
addGroupsДобавьте ограничения группы для весов портфеля к существующим ограничениям группы
addInequalityДобавьте линейные ограничения неравенства для весов портфеля к существующим ограничениям
getBoundsПолучите границы для весов портфеля от объекта портфеля
getBudgetПолучите границы ограничения бюджета из объекта портфеля
getCostsПолучите покупают и продают операционные издержки от объекта портфеля
getEqualityПолучите ограничительные массивы равенства из объекта портфеля
getGroupRatioПолучите ограничительные массивы отношения группы из объекта портфеля
getGroupsПолучите ограничительные массивы группы из объекта портфеля
getInequalityПолучите массивы ограничения неравенства из объекта портфеля
getOneWayTurnoverПолучите односторонние ограничения оборота из объекта портфеля
setGroupsНастройте ограничения группы для весов портфеля
setInequalityНастройте линейные ограничения неравенства для весов портфеля
setBoundsНастройте границы для весов портфеля для объекта портфеля
setMinMaxNumAssetsУстановите ограничения кардинальности на количество активов, которые инвестируют в объект портфеля
setBudgetНастройте ограничения бюджета
setCostsНастройте пропорциональные операционные издержки
setDefaultConstraintsНастройте ограничения портфеля с неотрицательными весами та сумма к 1
setEqualityНастройте линейные ограничения равенства для весов портфеля
setGroupRatioНастройте ограничения отношения группы для весов портфеля
setInitPortНастройте начальный или текущий портфель
setOneWayTurnoverНастройте односторонние ограничения оборота портфеля
setTurnoverНастройте максимальное ограничение оборота портфеля
checkFeasibilityПроверяйте выполнимость входных портфелей против объекта портфеля
estimateBoundsОцените глобальные нижние и верхние границы для набора портфелей
estimateFrontierОцените конкретное количество оптимальных портфелей на границе эффективности
estimateFrontierByReturnОцените, что оптимальные портфели с целенаправленным портфелем возвращаются
estimateFrontierByRiskОцените оптимальные портфели с целенаправленными портфельными рисками
estimateFrontierLimitsОцените оптимальные портфели в конечных точках границы эффективности
plotFrontierПостройте границу эффективности
estimatePortReturnОцените, что среднее значение портфеля возвращается
estimatePortRiskОцените портфельный риск согласно прокси риска, сопоставленному с соответствующим объектом
setSolverВыберите основной решатель и задайте сопоставленные опции решателя для оптимизации портфеля
setProbabilityLevelУстановите уровень вероятности для вычислений VaR и CVaR
setScenariosАктив набора возвращает сценарии прямой матрицей
getScenariosПолучите сценарии из объекта портфеля
simulateNormalScenariosByDataМоделируйте многомерный нормальный актив, возвращают сценарии в данные
simulateNormalScenariosByMomentsМоделируйте многомерный нормальный актив, возвращают сценарии в среднее значение, и ковариация актива возвращается
estimateScenarioMomentsОценочное среднее значение и ковариация актива возвращают сценарии
estimatePortStdОцените, что стандартное отклонение портфеля возвращается

Примеры

свернуть все

Можно создать объект PortfolioMAD, p, без входных параметров и отобразить его с помощью disp.

p = PortfolioMAD;
disp(p);
  PortfolioMAD with properties:

         BuyCost: []
        SellCost: []
    RiskFreeRate: []
        Turnover: []
     BuyTurnover: []
    SellTurnover: []
    NumScenarios: []
            Name: []
       NumAssets: []
       AssetList: []
        InitPort: []
     AInequality: []
     bInequality: []
       AEquality: []
       bEquality: []
      LowerBound: []
      UpperBound: []
     LowerBudget: []
     UpperBudget: []
     GroupMatrix: []
      LowerGroup: []
      UpperGroup: []
          GroupA: []
          GroupB: []
      LowerRatio: []
      UpperRatio: []
    MinNumAssets: []
    MaxNumAssets: []
       BoundType: []

Этот подход обеспечивает способ настроить задачу оптимизации портфеля с функцией PortfolioMAD. Можно затем использовать связанные функции множества, чтобы установить и изменить наборы свойств в объекте PortfolioMAD.

Можно использовать объект PortfolioMAD непосредственно, чтобы настроить “стандартную” задачу оптимизации портфеля. Учитывая сценарии актива возвращается в переменной AssetScenarios, эта проблема полностью задана можно следующим образом:

m = [ 0.05; 0.1; 0.12; 0.18 ];
C = [ 0.0064 0.00408 0.00192 0; 
    0.00408 0.0289 0.0204 0.0119;
    0.00192 0.0204 0.0576 0.0336;
    0 0.0119 0.0336 0.1225 ];
m = m/12;
C = C/12;

AssetScenarios = mvnrnd(m, C, 20000);

p = PortfolioMAD('Scenarios', AssetScenarios, ...
'LowerBound', 0, 'LowerBudget', 1, 'UpperBudget', 1)
p = 
  PortfolioMAD with properties:

         BuyCost: []
        SellCost: []
    RiskFreeRate: []
        Turnover: []
     BuyTurnover: []
    SellTurnover: []
    NumScenarios: 20000
            Name: []
       NumAssets: 4
       AssetList: []
        InitPort: []
     AInequality: []
     bInequality: []
       AEquality: []
       bEquality: []
      LowerBound: [4x1 double]
      UpperBound: []
     LowerBudget: 1
     UpperBudget: 1
     GroupMatrix: []
      LowerGroup: []
      UpperGroup: []
          GroupA: []
          GroupB: []
      LowerRatio: []
      UpperRatio: []
    MinNumAssets: []
    MaxNumAssets: []
       BoundType: []

Обратите внимание на то, что значение свойства LowerBound подвергается скалярному расширению, поскольку AssetScenarios обеспечивает размерности проблемы.

Используя последовательность шагов альтернативный способ выполнить ту же задачу подготовки “стандартной” задачи оптимизации портфеля MAD, учитывая AssetScenarios, который переменная:

m = [ 0.05; 0.1; 0.12; 0.18 ];
C = [ 0.0064 0.00408 0.00192 0;
0.00408 0.0289 0.0204 0.0119;
0.00192 0.0204 0.0576 0.0336;
0 0.0119 0.0336 0.1225 ];

m = m/12;
C = C/12;

AssetScenarios = mvnrnd(m, C, 20000);

p = PortfolioMAD;
p = setScenarios(p, AssetScenarios);
p = PortfolioMAD(p, 'LowerBound', 0);
p = PortfolioMAD(p, 'LowerBudget', 1, 'UpperBudget', 1);

plotFrontier(p);

Этот путь работает, потому что вызовы PortfolioMAD находятся в этом конкретном порядке. В этом случае вызов, чтобы инициализировать AssetScenarios обеспечивает размерности для проблемы. Если бы необходимо было выполнить этот шаг в последний раз, необходимо было бы явным образом определить размеры свойства LowerBound можно следующим образом:

m = [ 0.05; 0.1; 0.12; 0.18 ];
C = [ 0.0064 0.00408 0.00192 0;
0.00408 0.0289 0.0204 0.0119;
0.00192 0.0204 0.0576 0.0336;
0 0.0119 0.0336 0.1225 ];

m = m/12;
C = C/12;

AssetScenarios = mvnrnd(m, C, 20000);

p = PortfolioMAD;
p = PortfolioMAD(p, 'LowerBound', zeros(size(m)));
p = PortfolioMAD(p, 'LowerBudget', 1, 'UpperBudget', 1);
p = setScenarios(p, AssetScenarios);

plotFrontier(p);

Если вы не задавали размер LowerBound, но, вместо этого, вводили скалярный аргумент, объект PortfolioMAD принимает, что вы задаете проблему одно актива, и производит ошибку в вызове, чтобы установить сценарии актива с четырьмя активами.

Можно создать объект PortfolioMAD, p с объектом PortfolioMAD с помощью ярлыков для имен свойства.

m = [ 0.05; 0.1; 0.12; 0.18 ];
C = [ 0.0064 0.00408 0.00192 0;
0.00408 0.0289 0.0204 0.0119;
0.00192 0.0204 0.0576 0.0336;
0 0.0119 0.0336 0.1225 ];

m = m/12;
C = C/12;

AssetScenarios = mvnrnd(m, C, 20000);

p = PortfolioMAD('scenario', AssetScenarios, 'lb', 0, 'budget', 1)
p = 
  PortfolioMAD with properties:

         BuyCost: []
        SellCost: []
    RiskFreeRate: []
        Turnover: []
     BuyTurnover: []
    SellTurnover: []
    NumScenarios: 20000
            Name: []
       NumAssets: 4
       AssetList: []
        InitPort: []
     AInequality: []
     bInequality: []
       AEquality: []
       bEquality: []
      LowerBound: [4x1 double]
      UpperBound: []
     LowerBudget: 1
     UpperBudget: 1
     GroupMatrix: []
      LowerGroup: []
      UpperGroup: []
          GroupA: []
          GroupB: []
      LowerRatio: []
      UpperRatio: []
    MinNumAssets: []
    MaxNumAssets: []
       BoundType: []

Несмотря на то, что не рекомендуемый, можно установить свойства непосредственно, однако никакая проверка ошибок не сделана на входных параметрах.

m = [ 0.05; 0.1; 0.12; 0.18 ];
C = [ 0.0064 0.00408 0.00192 0; 
    0.00408 0.0289 0.0204 0.0119;
    0.00192 0.0204 0.0576 0.0336;
    0 0.0119 0.0336 0.1225 ];
m = m/12;
C = C/12;

AssetScenarios = mvnrnd(m, C, 20000);

p = PortfolioMAD;

p = setScenarios(p, AssetScenarios);

p.LowerBudget = 1;
p.UpperBudget = 1;
p.LowerBound = zeros(size(m));
disp(p);
  PortfolioMAD with properties:

         BuyCost: []
        SellCost: []
    RiskFreeRate: []
        Turnover: []
     BuyTurnover: []
    SellTurnover: []
    NumScenarios: 20000
            Name: []
       NumAssets: 4
       AssetList: []
        InitPort: []
     AInequality: []
     bInequality: []
       AEquality: []
       bEquality: []
      LowerBound: [4x1 double]
      UpperBound: []
     LowerBudget: 1
     UpperBudget: 1
     GroupMatrix: []
      LowerGroup: []
      UpperGroup: []
          GroupA: []
          GroupB: []
      LowerRatio: []
      UpperRatio: []
    MinNumAssets: []
    MaxNumAssets: []
       BoundType: []

Сценарии не могут быть присвоены непосредственно объекту PortfolioMAD. Сценарии должны всегда устанавливаться или через функцию PortfolioMAD, функцию setScenarios или через любую из функций симуляции сценария.

Создайте эффективные портфели:

load CAPMuniverse

p = PortfolioMAD('AssetList',Assets(1:12));
p = simulateNormalScenariosByData(p, Data(:,1:12), 20000 ,'missingdata',true);
p = setDefaultConstraints(p);

plotFrontier(p);

pwgt = estimateFrontier(p, 5);

pnames = cell(1,5);
for i = 1:5
	pnames{i} = sprintf('Port%d',i);
end

Blotter = dataset([{pwgt},pnames],'obsnames',p.AssetList);

disp(Blotter);
            Port1          Port2         Port3         Port4         Port5
    AAPL       0.030223      0.075387       0.11279       0.13456    0    
    AMZN     1.7513e-21             0             0    2.9507e-23    0    
    CSCO     4.7098e-22             0    2.7217e-21    2.2868e-22    0    
    DELL      0.0088968             0             0    3.6883e-24    0    
    EBAY              0     6.375e-23    1.6312e-23    2.9507e-23    0    
    GOOG        0.16119       0.35202       0.54487       0.74888    1    
    HPQ        0.056534       0.02405             0    3.0567e-22    0    
    IBM         0.45909       0.37889       0.29384       0.11656    0    
    INTC    -1.8808e-37             0    6.5246e-24             0    0    
    MSFT        0.28406       0.16965      0.048509    3.6883e-23    0    
    ORCL     1.9575e-22    2.2491e-23    7.2782e-22             0    0    
    YHOO     6.0477e-22             0    3.7185e-22             0    0    

Больше о

развернуть все

Ссылки

[1] Для полного списка ссылок для объекта PortfolioMAD смотрите Оптимизацию Портфеля.

Введенный в R2013b