qpOASES-3.0beta/examples/example1b.cpp
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-2011 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.hpp>
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 g[2] = { 1.5, 1.0 };
46  real_t lb[2] = { 0.5, -2.0 };
47  real_t ub[2] = { 5.0, 2.0 };
48 
49  /* Setup data of second QP. */
50  real_t g_new[2] = { 1.0, 1.5 };
51  real_t lb_new[2] = { 0.0, -1.0 };
52  real_t ub_new[2] = { 5.0, -0.5 };
53 
54 
55  /* Setting up QProblemB object. */
56  QProblemB example( 2 );
57 
61  options.numRefinementSteps = 1;
62  example.setOptions( options );
63 
64  /* Solve first QP. */
65  int nWSR = 10;
66  example.init( H,g,lb,ub, nWSR,0 );
67 // printf( "\nnWSR = %d\n\n", nWSR );
68 
69  /* Solve second QP. */
70  nWSR = 10;
71  example.hotstart( g_new,lb_new,ub_new, nWSR,0 );
72 // printf( "\nnWSR = %d\n\n", nWSR );
73 
74  /* Get and print solution of second QP. */
75  real_t xOpt[2];
76  example.getPrimalSolution( xOpt );
77  printf( "\nxOpt = [ %e, %e ]; objVal = %e\n\n", xOpt[0],xOpt[1],example.getObjVal() );
78 
79  return 0;
80 }
81 
82 
83 /*
84  * end of file
85  */
Implements the online active set strategy for box-constrained QPs.
returnValue init(const real_t *const _H, const real_t *const _g, const real_t *const _lb, const real_t *const _ub, int &nWSR, const real_t *const yOpt=0, real_t *const cputime=0)
#define ST_INACTIVE
returnValue setOptions(const Options &_options)
returnValue hotstart(const real_t *const g_new, const real_t *const lb_new, const real_t *const ub_new, int &nWSR, real_t *const cputime)
Provides a generic way to set and pass user-specified options.
Definition: options.hpp:65
#define BT_FALSE
Definition: acado_types.hpp:49
double real_t
Definition: AD_test.c:10


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