You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							189 lines
						
					
					
						
							5.4 KiB
						
					
					
				
			
		
		
	
	
							189 lines
						
					
					
						
							5.4 KiB
						
					
					
				/*
 | 
						|
 *	This file is part of qpOASES.
 | 
						|
 *
 | 
						|
 *	qpOASES -- An Implementation of the Online Active Set Strategy.
 | 
						|
 *	Copyright (C) 2007-2008 by Hans Joachim Ferreau et al. All rights reserved.
 | 
						|
 *
 | 
						|
 *	qpOASES is free software; you can redistribute it and/or
 | 
						|
 *	modify it under the terms of the GNU Lesser General Public
 | 
						|
 *	License as published by the Free Software Foundation; either
 | 
						|
 *	version 2.1 of the License, or (at your option) any later version.
 | 
						|
 *
 | 
						|
 *	qpOASES is distributed in the hope that it will be useful,
 | 
						|
 *	but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 *	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
						|
 *	Lesser General Public License for more details.
 | 
						|
 *
 | 
						|
 *	You should have received a copy of the GNU Lesser General Public
 | 
						|
 *	License along with qpOASES; if not, write to the Free Software
 | 
						|
 *	Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | 
						|
 *
 | 
						|
 */
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 *	\file INCLUDE/Bounds.hpp
 | 
						|
 *	\author Hans Joachim Ferreau
 | 
						|
 *	\version 1.3embedded
 | 
						|
 *	\date 2007-2008
 | 
						|
 *
 | 
						|
 *	Declaration of the Bounds class designed to manage working sets of
 | 
						|
 *	bounds within a QProblem.
 | 
						|
 */
 | 
						|
 | 
						|
 | 
						|
#ifndef QPOASES_BOUNDS_HPP
 | 
						|
#define QPOASES_BOUNDS_HPP
 | 
						|
 | 
						|
 | 
						|
#include <SubjectTo.hpp>
 | 
						|
 | 
						|
 | 
						|
 | 
						|
/** This class manages working sets of bounds by storing
 | 
						|
 *	index sets and other status information.
 | 
						|
 *
 | 
						|
 *	\author Hans Joachim Ferreau
 | 
						|
 *	\version 1.3embedded
 | 
						|
 *	\date 2007-2008
 | 
						|
 */
 | 
						|
class Bounds : public SubjectTo
 | 
						|
{
 | 
						|
	/*
 | 
						|
	 *	PUBLIC MEMBER FUNCTIONS
 | 
						|
	 */
 | 
						|
	public:
 | 
						|
		/** Default constructor. */
 | 
						|
		Bounds( );
 | 
						|
 | 
						|
		/** Copy constructor (deep copy). */
 | 
						|
		Bounds(	const Bounds& rhs	/**< Rhs object. */
 | 
						|
				);
 | 
						|
 | 
						|
		/** Destructor. */
 | 
						|
		~Bounds( );
 | 
						|
 | 
						|
		/** Assignment operator (deep copy). */
 | 
						|
		Bounds& operator=(	const Bounds& rhs	/**< Rhs object. */
 | 
						|
							);
 | 
						|
 | 
						|
 | 
						|
		/** Pseudo-constructor takes the number of bounds.
 | 
						|
		 *	\return SUCCESSFUL_RETURN */
 | 
						|
		returnValue init(	int n	/**< Number of bounds. */
 | 
						|
							);
 | 
						|
 | 
						|
 | 
						|
		/** Initially adds number of a new (i.e. not yet in the list) bound to
 | 
						|
		 *  given index set.
 | 
						|
		 *	\return SUCCESSFUL_RETURN \n
 | 
						|
		 			RET_SETUP_BOUND_FAILED \n
 | 
						|
					RET_INDEX_OUT_OF_BOUNDS \n
 | 
						|
					RET_INVALID_ARGUMENTS */
 | 
						|
		returnValue setupBound(	int _number,					/**< Number of new bound. */
 | 
						|
								SubjectToStatus _status			/**< Status of new bound. */
 | 
						|
								);
 | 
						|
 | 
						|
		/** Initially adds all numbers of new (i.e. not yet in the list) bounds to
 | 
						|
		 *  to the index set of free bounds; the order depends on the SujectToType
 | 
						|
		 *  of each index.
 | 
						|
		 *	\return SUCCESSFUL_RETURN \n
 | 
						|
		 			RET_SETUP_BOUND_FAILED */
 | 
						|
		returnValue setupAllFree( );
 | 
						|
 | 
						|
 | 
						|
		/** Moves index of a bound from index list of fixed to that of free bounds.
 | 
						|
		 *	\return SUCCESSFUL_RETURN \n
 | 
						|
		 			RET_MOVING_BOUND_FAILED \n
 | 
						|
					RET_INDEX_OUT_OF_BOUNDS */
 | 
						|
		returnValue moveFixedToFree(	int _number				/**< Number of bound to be freed. */
 | 
						|
										);
 | 
						|
 | 
						|
		/** Moves index of a bound from index list of free to that of fixed bounds.
 | 
						|
		 *	\return SUCCESSFUL_RETURN \n
 | 
						|
		 			RET_MOVING_BOUND_FAILED \n
 | 
						|
					RET_INDEX_OUT_OF_BOUNDS */
 | 
						|
		returnValue moveFreeToFixed(	int _number,			/**< Number of bound to be fixed. */
 | 
						|
										SubjectToStatus _status	/**< Status of bound to be fixed. */
 | 
						|
										);
 | 
						|
 | 
						|
		/** Swaps the indices of two free bounds within the index set.
 | 
						|
		 *	\return SUCCESSFUL_RETURN \n
 | 
						|
		 			RET_SWAPINDEX_FAILED */
 | 
						|
		returnValue swapFree(	int number1,					/**< Number of first constraint or bound. */
 | 
						|
								int number2						/**< Number of second constraint or bound. */
 | 
						|
								);
 | 
						|
 | 
						|
 | 
						|
		/** Returns number of variables.
 | 
						|
		 *	\return Number of variables. */
 | 
						|
		inline int getNV( ) const;
 | 
						|
 | 
						|
		/** Returns number of implicitly fixed variables.
 | 
						|
		 *	\return Number of implicitly fixed variables. */
 | 
						|
		inline int getNFV( ) const;
 | 
						|
 | 
						|
		/** Returns number of bounded (but possibly free) variables.
 | 
						|
		 *	\return Number of bounded (but possibly free) variables. */
 | 
						|
		inline int getNBV( ) const;
 | 
						|
 | 
						|
		/** Returns number of unbounded variables.
 | 
						|
		 *	\return Number of unbounded variables. */
 | 
						|
		inline int getNUV( ) const;
 | 
						|
 | 
						|
 | 
						|
		/** Sets number of implicitly fixed variables.
 | 
						|
		 *	\return SUCCESSFUL_RETURN */
 | 
						|
		inline returnValue setNFV(	int n	/**< Number of implicitly fixed variables. */
 | 
						|
									);
 | 
						|
 | 
						|
		/** Sets number of bounded (but possibly free) variables.
 | 
						|
		 *	\return SUCCESSFUL_RETURN */
 | 
						|
		inline returnValue setNBV(	int n	/**< Number of bounded (but possibly free) variables. */
 | 
						|
									);
 | 
						|
 | 
						|
		/** Sets number of unbounded variables.
 | 
						|
		 *	\return SUCCESSFUL_RETURN */
 | 
						|
		inline returnValue setNUV(	int n	/**< Number of unbounded variables */
 | 
						|
									);
 | 
						|
 | 
						|
 | 
						|
		/** Returns number of free variables.
 | 
						|
		 *	\return Number of free variables. */
 | 
						|
		inline int getNFR( );
 | 
						|
 | 
						|
		/** Returns number of fixed variables.
 | 
						|
		 *	\return Number of fixed variables. */
 | 
						|
		inline int getNFX( );
 | 
						|
 | 
						|
 | 
						|
		/** Returns a pointer to free variables index list.
 | 
						|
		 *	\return Pointer to free variables index list. */
 | 
						|
		inline Indexlist* getFree( );
 | 
						|
 | 
						|
		/** Returns a pointer to fixed variables index list.
 | 
						|
		 *	\return Pointer to fixed variables index list. */
 | 
						|
		inline Indexlist* getFixed( );
 | 
						|
 | 
						|
 | 
						|
	/*
 | 
						|
	 *	PROTECTED MEMBER VARIABLES
 | 
						|
	 */
 | 
						|
	protected:
 | 
						|
		int nV;					/**< Number of variables (nV = nFV + nBV + nUV). */
 | 
						|
		int nFV;				/**< Number of implicitly fixed variables. */
 | 
						|
		int	nBV;				/**< Number of bounded (but possibly free) variables. */
 | 
						|
		int nUV;				/**< Number of unbounded variables. */
 | 
						|
 | 
						|
		Indexlist free;			/**< Index list of free variables. */
 | 
						|
		Indexlist fixed;		/**< Index list of fixed variables. */
 | 
						|
};
 | 
						|
 | 
						|
#include <Bounds.ipp>
 | 
						|
 | 
						|
#endif	/* QPOASES_BOUNDS_HPP */
 | 
						|
 | 
						|
 | 
						|
/*
 | 
						|
 *	end of file
 | 
						|
 */
 | 
						|
 |