/usr/include/shark/ObjectiveFunctions/BoxConstraintHandler.h is in libshark-dev 3.1.4+ds1-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 | //===========================================================================
/*!
*
*
* \brief Base class for constraints.
*
*
* \author O.Krause
* \date 2013
*
*
* \par Copyright 1995-2015 Shark Development Team
*
* <BR><HR>
* This file is part of Shark.
* <http://image.diku.dk/shark/>
*
* Shark 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 3 of the License, or
* (at your option) any later version.
*
* Shark 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 Shark. If not, see <http://www.gnu.org/licenses/>.
*
*/
//===========================================================================
#ifndef SHARK_OBJECTIVEFUNCTIONS_BOXCONSTRAINTHANDLER_H
#define SHARK_OBJECTIVEFUNCTIONS_BOXCONSTRAINTHANDLER_H
#include <shark/ObjectiveFunctions/AbstractConstraintHandler.h>
#include <shark/Rng/GlobalRng.h>
namespace shark{
template<class Vector>
class BoxConstraintHandler:public AbstractConstraintHandler<Vector> {
public:
BoxConstraintHandler(Vector const& lower, Vector const& upper)
:m_lower(lower),m_upper(upper){
SIZE_CHECK(lower.size() == upper.size());
typedef AbstractConstraintHandler<Vector> base_type;
this->m_features |= base_type::CAN_PROVIDE_CLOSEST_FEASIBLE;
this->m_features |= base_type::IS_BOX_CONSTRAINED;
this->m_features |= base_type::CAN_GENERATE_RANDOM_POINT;
}
BoxConstraintHandler(std::size_t dim, double lower, double upper)
:m_lower(Vector(dim,lower)),m_upper(Vector(dim,upper)){
typedef AbstractConstraintHandler<Vector> base_type;
this->m_features |= base_type::CAN_PROVIDE_CLOSEST_FEASIBLE;
this->m_features |= base_type::IS_BOX_CONSTRAINED;
this->m_features |= base_type::CAN_GENERATE_RANDOM_POINT;
}
BoxConstraintHandler(){
typedef AbstractConstraintHandler<Vector> base_type;
this->m_features |= base_type::CAN_PROVIDE_CLOSEST_FEASIBLE;
this->m_features |= base_type::IS_BOX_CONSTRAINED;
this->m_features |= base_type::CAN_GENERATE_RANDOM_POINT;
}
std::size_t dimensions()const{
return m_lower.size();
}
bool isFeasible(Vector const& point)const{
SIZE_CHECK(point.size() == dimensions());
for(std::size_t i = 0; i != dimensions();++i){
if(point(i) < m_lower(i)||point(i) > m_upper(i))
return false;
}
return true;
}
void closestFeasible(Vector& point )const{
SIZE_CHECK(point.size() == dimensions());
for(std::size_t i = 0; i != dimensions();++i){
point(i) = std::max(point(i),m_lower(i));
point(i) = std::min(point(i),m_upper(i));
}
}
virtual void generateRandomPoint( Vector & startingPoint )const {
startingPoint.resize(dimensions());
for(std::size_t i = 0; i != dimensions(); ++i){
startingPoint(i) = Rng::uni(m_lower(i),m_upper(i));
}
}
/// \brief Sets lower and upper bounds of the box.
void setBounds(Vector const& lower, Vector const& upper){
SIZE_CHECK(lower.size() == upper.size());
m_lower = lower;
m_upper = upper;
}
/// \brief Sets lower and upper bounds of the box.
void setBounds(std::size_t dimension, double lower, double upper){
m_lower = Vector(dimension,lower);
m_upper = Vector(dimension,upper);
}
/// \brief Returns the lower bound of the box.
Vector const& lower()const{
return m_lower;
}
/// \brief Returns the upper bound of the box.
Vector const& upper()const{
return m_upper;
}
private:
/// \brief Represents the lower bound of the points in the box
Vector m_lower;
/// \brief Represents the upper bound of the points in the box
Vector m_upper;
};
}
#endif
|