example1.c
Go to the documentation of this file.
1 /*
2  * This file is part of qpOASES.
3  *
4  * qpOASES -- An Implementation of the Online Active Set Strategy.
5  * Copyright (C) 2007-2015 by Hans Joachim Ferreau, Andreas Potschka,
6  * Christian Kirches et al. All rights reserved.
7  *
8  * qpOASES is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * qpOASES is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16  * See the GNU Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with qpOASES; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  *
22  */
23 
24 
35 #include <qpOASES_e.h>
36 
37 
39 int main( )
40 {
42 
43  /* Setup data of first QP. */
44  real_t H[2*2] = { 1.0, 0.0, 0.0, 0.5 };
45  real_t A[1*2] = { 1.0, 1.0 };
46  real_t g[2] = { 1.5, 1.0 };
47  real_t lb[2] = { 0.5, -2.0 };
48  real_t ub[2] = { 5.0, 2.0 };
49  real_t lbA[1] = { -1.0 };
50  real_t ubA[1] = { 2.0 };
51 
52  /* Setup data of second QP. */
53  real_t g_new[2] = { 1.0, 1.5 };
54  real_t lb_new[2] = { 0.0, -1.0 };
55  real_t ub_new[2] = { 5.0, -0.5 };
56  real_t lbA_new[1] = { -2.0 };
57  real_t ubA_new[1] = { 1.0 };
58 
59 
60  /* Setting up QProblem object. */
61  static Options options;
62  static QProblem example;
63 
64  int nWSR;
65  real_t xOpt[2];
66  real_t yOpt[2+1];
67 
68  QProblemCON( &example,2,1,HST_UNKNOWN );
69  Options_setToDefault( &options );
70  QProblem_setOptions( &example,options );
71 
72  /* Solve first QP. */
73  nWSR = 10;
74  QProblem_init( &example,H,g,A,lb,ub,lbA,ubA, &nWSR,0 );
75 
76  /* Get and print solution of first QP. */
77  QProblem_getPrimalSolution( &example,xOpt );
78  QProblem_getDualSolution( &example,yOpt );
79  printf( "\nxOpt = [ %e, %e ]; yOpt = [ %e, %e, %e ]; objVal = %e\n\n",
80  xOpt[0],xOpt[1],yOpt[0],yOpt[1],yOpt[2], QProblem_getObjVal( &example ) );
81 
82  /* Solve second QP. */
83  nWSR = 10;
84  QProblem_hotstart( &example,g_new,lb_new,ub_new,lbA_new,ubA_new, &nWSR,0 );
85 
86  /* Get and print solution of second QP. */
87  QProblem_getPrimalSolution( &example,xOpt );
88  QProblem_getDualSolution( &example,yOpt );
89  printf( "\nxOpt = [ %e, %e ]; yOpt = [ %e, %e, %e ]; objVal = %e\n\n",
90  xOpt[0],xOpt[1],yOpt[0],yOpt[1],yOpt[2], QProblem_getObjVal( &example ) );
91 
92  QProblem_printOptions( &example );
93  /*QProblem_printProperties( &example );*/
94 
95  return 0;
96 }
97 
98 
99 /*
100  * end of file
101  */
returnValue QProblem_getPrimalSolution(QProblem *_THIS, real_t *const xOpt)
Definition: QProblem.c:1168
int main()
Definition: example1.c:39
Provides a generic way to set and pass user-specified options.
Definition: options.hpp:65
real_t QProblem_getObjVal(QProblem *_THIS)
Definition: QProblem.c:1095
int_t QProblem_init(const real_t *const H, const real_t *const g, const real_t *const A, const real_t *const lb, const real_t *const ub, const real_t *const lbA, const real_t *const ubA, int_t *const nWSR, real_t *const cputime, const qpOASES_Options *const options, real_t *const x, real_t *const y, real_t *const obj, int_t *const status)
returnValue QProblem_getDualSolution(QProblem *_THIS, real_t *const yOpt)
Definition: QProblem.c:1058
returnValue Options_setToDefault(Options *_THIS)
Definition: Options.c:112
#define HST_UNKNOWN
int_t QProblem_hotstart(const real_t *const g, const real_t *const lb, const real_t *const ub, const real_t *const lbA, const real_t *const ubA, int_t *const nWSR, real_t *const cputime, real_t *const x, real_t *const y, real_t *const obj, int_t *const status)
double real_t
Definition: AD_test.c:10
Implements the online active set strategy for QPs with general constraints.
void QProblemCON(QProblem *_THIS, int _nV, int _nC, HessianType _hessianType)
Definition: QProblem.c:51
static returnValue QProblem_setOptions(QProblem *_THIS, Options _options)
Definition: QProblem.h:1818
returnValue QProblem_printOptions(QProblem *_THIS)
Definition: QProblem.c:1240


acado
Author(s): Milan Vukov, Rien Quirynen
autogenerated on Mon Jun 10 2019 12:34:33