[R-SIG-Finance] fPortfolio (portfolioFrontier function)

Mark Gordon mgordon at mcphedge.com
Thu Dec 2 14:12:09 CET 2010


 I ran into the same problem with the function minriskPortfolio when I
started using R in September.  I posted the problem, but didn't get any
response.
 
 Within minriskPortfolio there is this line of code:

	 portfolio <- optimize(targetRiskFun, interval =
range(getMu(Data)), 
      	data = Data, spec = spec, constraints = constraints, 
        	tol = .Machine$double.eps^0.5)
 
 The parameter "interval" specificies the range of returns to search for
determining an optimal portfolio.  The "range" function returns an array
containing the returns for the best and worst assets in the dataset.
These returns are feasible only if there is no constriant on owning 100%
of the best or worst asset, respectively.  

 I worked around this by writing my own range function which returns the
best and worst returns subject to my constraints.  I look to create the
minimum return by first setting weights to their minimum constraints
then by choosing a maximum weight on the lowest returning asset, then
choosing the maximum weight on the second lowest returning asset et
cetera until I have my weights equal to 100%.  The calculation for
maximum return is similar.  I am not an R-maven, so I am sure that it is
possible to write more concise code but here is what I did and it works
for me:

MCPrange<-function(data, constraints)
{
mu=getMu(data)
maxCon<-maxWConstraints(data, constraints=constraints)
minCon<-minWConstraints(data, constraints=constraints)
Excess<-maxCon-minCon
summin=sum(minCon)

temp<-sort(mu, index.return=TRUE)
smu=temp$x
sExcess=Excess[temp$ix]
sminCon=minCon[temp$ix]
i=1
while (summin+sum(sExcess[1:i])<1) i=i+1
sExcess[i]=sExcess[i]+1-sum(sExcess[1:i])-summin
sExcess[(i+1):length(sExcess)]=0
min=sum((sExcess+sminCon)*smu)

temp<-sort(mu, decreasing=TRUE, index.return=TRUE)
smu=temp$x
sExcess=Excess[temp$ix]
sminCon=minCon[temp$ix]
i=1
while (summin+sum(sExcess[1:i])<1) i=i+1
sExcess[i]=sExcess[i]+1-sum(sExcess[1:i])-summin
sExcess[(i+1):length(sExcess)]=0
max=sum((sExcess+sminCon)*smu)

return(c(min, max))
}

  I substituted MCPrange for the range function in my version of
minriskPortfolio and use that version in all of my optimization
functions.

Mark

-----Original Message-----
From: r-sig-finance-bounces at r-project.org
[mailto:r-sig-finance-bounces at r-project.org] On Behalf Of Maciej Ombach
Sent: Saturday, November 27, 2010 10:35 PM
To: r-sig-finance at r-project.org
Subject: [R-SIG-Finance] fPortfolio (portfolioFrontier function)


In the code below (fPortfolio Version 2110.79, R 2.11.1), if min weights
(min.weights <- c(rep(0, 5), 0.2)) are 0, portfolioFrontier function
works fine.  But when, for example, min weights increase (min.weights <-
c(rep(0.1, 5), 0.2)), a portfolioFrontier call returns the following
error: 
 
Execution stopped:
  The minimum risk portfolio could not be computed.
Possible Reason:
  Your portfolio constraints may be too restrictive.
 
It seems that the minvariancePortfolio function (inside
portfolioFrontier) attempts to minimize risk subject to a return
constraint that is not feasible.  Or am I missing something?  
Any suggestions will be appreciated. 
 
 
library(fPortfolio)
x <- SMALLCAP.RET[,1:6]
spec <- portfolioSpec()
setNFrontierPoints(spec) <- 50
assets.num <- 1:ncol(x)
min.weights <- c(rep(0.1, 5), 0.2)
constraints.min <- paste("minW[", assets.num, "]=", min.weights, sep =
"") max.weights <- c(rep(1, 5), 0.4) constraints.max <- paste("maxW[",
assets.num, "]=", max.weights, sep = "") constraints <-
c(constraints.min, constraints.max) frontier <- portfolioFrontier(x,
spec = spec, constraints = constraints)
 
Maciek  		 	   		  
	[[alternative HTML version deleted]]

_______________________________________________
R-SIG-Finance at r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-sig-finance
-- Subscriber-posting only. If you want to post, subscribe first.
-- Also note that this is not the r-help list where general R questions
should go.



More information about the R-SIG-Finance mailing list