/******************************************************** Xpress-BCL C++ Example Problems =============================== file folioqp.cpp ```````````````` Modeling a small QCQP problem to perform portfolio optimization. -- Maximize return with limit on variance --- (c) 2008-2024 Fair Isaac Corporation author: S.Heipcke, July 2008, rev. Mar. 2011 ********************************************************/ #include #include #include "xprb_cpp.h" using namespace std; using namespace ::dashoptimization; #define DATAFILE XPRBDATAPATH "/GS/foliocppqp.dat" #define MAXVAR 0,55 // Max. allowed variance #define NSHARES 10 // Number of shares #define NNA 4 // Number of North-American shares double RET[] = {5,17,26,12,8,9,7,6,31,21}; // Estimated return in investment int NA[] = {0,1,2,3}; // Shares issued in N.-America double VAR[NSHARES][NSHARES]; // Variance/covariance matrix of // estimated returns int main(int argc, char **argv) { int s,t; XPRBprob p("FolioQC"); // Initialize a new problem in BCL XPRBexpr Na,Return,Cap,Variance; XPRBvar frac[NSHARES]; // Fraction of capital used per share FILE *datafile; // Read `VAR' data from file datafile=fopen(DATAFILE,"r"); for(s=0;s= 0,5); // Spend all the capital for(s=0;s