/******************************************************** Xpress-BCL C Example Problems ============================= file folioqp.c `````````````` Modeling a small QP problem to perform portfolio optimization. -- 1. QP: minimize variance 2. MIQP: limited number of assets --- (c) 2008-2023 Fair Isaac Corporation author: S.Heipcke, Dec. 2003, rev. Mar. 2011 ********************************************************/ #include #include "xprb.h" #define DATAFILE XPRBDATAPATH "/GS/foliocppqp.dat" #define TARGET 9 /* Target yield */ #define MAXNUM 4 /* Max. number of different assets */ #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 prob; XPRBctr Variance,Na,Return,Cap,Num; XPRBvar frac[NSHARES]; /* Fraction of capital used per share */ XPRBvar buy[NSHARES]; /* 1 if asset is in portfolio, 0 otherwise */ FILE *datafile; prob = XPRBnewprob("FolioQP"); /* Initialize a new problem in BCL */ /* Read `VAR' data from file */ datafile=fopen(DATAFILE,"r"); for(s=0;s