use of org.ojalgo.optimisation.convex.ConvexSolver in project ojAlgo-finance by optimatika.
the class PortfolioProblems method testP20110614.
/**
* A user claimed he got constraint breaking weights using these figures.
*/
@Test
public void testP20110614() {
final Builder<PrimitiveMatrix> tmpCovarsBuilder = PrimitiveMatrix.FACTORY.getBuilder(3, 3);
tmpCovarsBuilder.set(0, 0, 0.04);
tmpCovarsBuilder.set(0, 1, 0.01);
tmpCovarsBuilder.set(0, 2, 0.02);
tmpCovarsBuilder.set(1, 0, 0.01);
tmpCovarsBuilder.set(1, 1, 0.09);
tmpCovarsBuilder.set(1, 2, 0.01);
tmpCovarsBuilder.set(2, 0, 0.02);
tmpCovarsBuilder.set(2, 1, 0.01);
tmpCovarsBuilder.set(2, 2, 0.16);
final BasicMatrix tmpCovars = tmpCovarsBuilder.build();
final Builder<PrimitiveMatrix> tmpReturnsBuilder = PrimitiveMatrix.FACTORY.getBuilder(3, 1);
tmpReturnsBuilder.set(0, 0, 0.10);
tmpReturnsBuilder.set(1, 0, 0.15);
tmpReturnsBuilder.set(2, 0, 0.18);
final BasicMatrix tmpReturs = tmpReturnsBuilder.build();
final MarketEquilibrium tmpME = new MarketEquilibrium(tmpCovars);
final MarkowitzModel tmpMarkowitz = new MarkowitzModel(tmpME, tmpReturs);
for (int i = 1; i < 10; i++) {
tmpMarkowitz.setRiskAversion(new BigDecimal(i));
final List<BigDecimal> tmpWeights = tmpMarkowitz.getWeights();
for (final BigDecimal tmpBigDecimal : tmpWeights) {
if ((tmpBigDecimal.compareTo(BigMath.ZERO) == -1) || (tmpBigDecimal.compareTo(BigMath.ONE) == 1)) {
TestUtils.fail("!(0.0 <= " + tmpBigDecimal + " <= 1.0)");
}
}
}
// As the Markowitz model built it the problem
final MatrixStore<Double> tmpQ = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 4.0, 1.0, 2.0 }, { 1.0, 9.0, 1.0 }, { 2.0, 1.0, 16.0 } });
final MatrixStore<Double> tmpC = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 10.0 }, { 15.0 }, { 18.0 } });
final MatrixStore<Double> tmpAE = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 1.0, 1.0, 1.0 } });
final MatrixStore<Double> tmpBE = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 1.0 } });
MatrixStore<Double> tmpAI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { -1.0, 0.0, 0.0 }, { 0.0, -1.0, 0.0 }, { 0.0, 0.0, -1.0 } });
MatrixStore<Double> tmpBI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 0.0 }, { 0.0 }, { 0.0 } });
final MatrixStore<Double> tmpX = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 0.0 }, { 0.5217391304347826 }, { 0.4782608695652173 } });
ConvexSolver.Builder tmpBuilder = new ConvexSolver.Builder(tmpQ, tmpC).equalities(tmpAE, tmpBE).inequalities(tmpAI, tmpBI);
ConvexSolver tmpSolver = tmpBuilder.build();
// tmpSolver.options.debug(ConvexSolver.class);
Optimisation.Result tmpResult = tmpSolver.solve();
// BasicMatrix tmpSolution = tmpResult.getSolution();
TestUtils.assertEquals(tmpX, tmpResult, new NumberContext(7, 6));
// As (I believe) the user built it
//
// The only *problem* I found was that he did not set lower limits
// on the portfolio weights, which you have to do. No problem with
// ojAlgo.
tmpAI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 1.0, 0.0, 0.0 }, { 0.0, 1.0, 0.0 }, { 0.0, 0.0, 1.0 } });
tmpBI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 1.0 }, { 1.0 }, { 1.0 } });
tmpBuilder = new ConvexSolver.Builder(tmpQ, tmpC).equalities(tmpAE, tmpBE).inequalities(tmpAI, tmpBI);
tmpSolver = tmpBuilder.build();
tmpResult = tmpSolver.solve();
// Should NOT be equal in this case!
TestUtils.assertFalse(Access1D.equals(tmpX, tmpResult, new NumberContext(7, 6)));
// No problem with both the lower and upper limits set.
tmpAI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { -1.0, 0.0, 0.0 }, { 0.0, -1.0, 0.0 }, { 0.0, 0.0, -1.0 }, { 1.0, 0.0, 0.0 }, { 0.0, 1.0, 0.0 }, { 0.0, 0.0, 1.0 } });
tmpBI = PrimitiveDenseStore.FACTORY.rows(new double[][] { { 0.0 }, { 0.0 }, { 0.0 }, { 1.0 }, { 1.0 }, { 1.0 } });
tmpBuilder = new ConvexSolver.Builder(tmpQ, tmpC).equalities(tmpAE, tmpBE).inequalities(tmpAI, tmpBI);
tmpSolver = tmpBuilder.build();
tmpResult = tmpSolver.solve();
TestUtils.assertEquals(tmpX, tmpResult, new NumberContext(7, 6));
}
Aggregations