Working with Budget Constraints Using Portfolio Object
The budget constraint is an optional linear constraint that
maintains upper and lower bounds on the sum of portfolio weights (see Budget Constraints). Budget constraints
have properties LowerBudget for the lower budget
constraint and UpperBudget for the upper budget
constraint. If you set up a portfolio optimization problem that requires
portfolios to be fully invested in your universe of assets, you can
set LowerBudget to be equal to UpperBudget.
These budget constraints can be set with default values equal to 1 using setDefaultConstraints (see Setting Default Constraints for Portfolio Weights Using Portfolio Object). 
Setting Budget Constraints Using the Portfolio Function
The properties for the budget constraint can also be set using the Portfolio object. Suppose that you
                have an asset universe with many risky assets and a riskless asset and you want to
                ensure that your portfolio never holds more than 1% cash, that is, you want to
                ensure that you are 99–100% invested in risky assets. The budget constraint for this
                portfolio can be set with:
                
p = Portfolio('LowerBudget', 0.99, 'UpperBudget', 1); disp(p.LowerBudget) disp(p.UpperBudget)
0.9900 1
Setting Budget Constraints Using the setBudget Function
You can also set the properties for a budget constraint using setBudget. Suppose that you have a
                fund that permits up to 10% leverage which means that your portfolio can be from
                100% to 110% invested in risky assets. Given a Portfolio object
                    p, use setBudget to set the budget
                constraints:
                
p = Portfolio; p = setBudget(p, 1, 1.1); disp(p.LowerBudget) disp(p.UpperBudget)
1 1.1000
RiskFreeRate
                property to the borrowing rate to finance possible leveraged positions. For details
                on the RiskFreeRate property, see Working with a Riskless Asset. To clear either bound for the budget
                constraint from your Portfolio object, use either the Portfolio object or setBudget with empty inputs for the
                properties to be cleared. For example, clear the upper-budget constraint from the
                    Portfolio object p in the previous example
                with:p = Portfolio(p, 'UpperBudget', []);See Also
Portfolio | setDefaultConstraints | setBounds | setBudget | setConditionalBudget | setGroups | setGroupRatio | setEquality | setInequality | setTurnover | setOneWayTurnover | setTrackingPort | setTrackingError
Topics
- Creating the Portfolio Object
- Working with Portfolio Constraints Using Defaults
- Validate the Portfolio Problem for Portfolio Object
- Estimate Efficient Portfolios for Entire Efficient Frontier for Portfolio Object
- Estimate Efficient Frontiers for Portfolio Object
- Constraint Specification Using a Portfolio Object
- Asset Allocation Case Study
- Portfolio Optimization Examples Using Financial Toolbox
- Portfolio Optimization with Semicontinuous and Cardinality Constraints
- Black-Litterman Portfolio Optimization Using Financial Toolbox
- Portfolio Optimization Using Factor Models
- Portfolio Optimization Using Social Performance Measure
- Diversify Portfolios Using Custom Objective
- Portfolio Object
- Portfolio Optimization Theory
- Portfolio Object Workflow
- Setting Up a Tracking Portfolio