-
Notifications
You must be signed in to change notification settings - Fork 103
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
09e3c69
commit 33a6067
Showing
9 changed files
with
593 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
34 changes: 34 additions & 0 deletions
34
trajopt_ifopt/trajopt/include/trajopt_ifopt/trajopt/variable_sets/node.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
#ifndef TRAJOPT_IFOPT_TRAJOPT_NODE_H | ||
#define TRAJOPT_IFOPT_TRAJOPT_NODE_H | ||
|
||
#include <trajopt_ifopt/trajopt/variable_sets/var.h> | ||
#include <unordered_map> | ||
|
||
namespace trajopt_ifopt | ||
{ | ||
class Node | ||
{ | ||
public: | ||
Node(std::string node_name = "Node"); | ||
|
||
Var addVar(const std::string& name); | ||
|
||
Var addVar(const std::string& name, const std::vector<std::string>& child_names); | ||
|
||
Var getVar(const std::string& name) const; | ||
|
||
bool hasVar(const std::string& name) const; | ||
|
||
Eigen::Index size() const; | ||
|
||
protected: | ||
friend class NodesVariables; | ||
std::string name_; | ||
std::unordered_map<std::string, Var> vars_; | ||
Eigen::Index length_{ 0 }; | ||
|
||
void setVariables(const Eigen::Ref<const Eigen::VectorXd>& x); | ||
}; | ||
|
||
} // namespace trajopt_ifopt | ||
#endif // TRAJOPT_IFOPT_TRAJOPT_NODE_H |
70 changes: 70 additions & 0 deletions
70
trajopt_ifopt/trajopt/include/trajopt_ifopt/trajopt/variable_sets/nodes_observer.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
/****************************************************************************** | ||
Copyright (c) 2018, Alexander W. Winkler. All rights reserved. | ||
Redistribution and use in source and binary forms, with or without | ||
modification, are permitted provided that the following conditions are met: | ||
* Redistributions of source code must retain the above copyright notice, this | ||
list of conditions and the following disclaimer. | ||
* Redistributions in binary form must reproduce the above copyright notice, | ||
this list of conditions and the following disclaimer in the documentation | ||
and/or other materials provided with the distribution. | ||
* Neither the name of the copyright holder nor the names of its | ||
contributors may be used to endorse or promote products derived from | ||
this software without specific prior written permission. | ||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
******************************************************************************/ | ||
|
||
#ifndef TRAJOPT_IFOPT_TRAJOPT_NODES_OBSERVER_H | ||
#define TRAJOPT_IFOPT_TRAJOPT_NODES_OBSERVER_H | ||
|
||
#include <memory> | ||
|
||
namespace trajopt_ifopt | ||
{ | ||
class NodesVariables; | ||
|
||
/** | ||
* @brief Base class to receive up-to-date values of the NodeVariables. | ||
* | ||
* This class registers with the node variables and everytime the positions or | ||
* velocities of a node change, the subject updates this class by calling the | ||
* UpdatePolynomials() method. | ||
* | ||
* Used by spline.h | ||
* | ||
* This class implements the observer pattern: | ||
* https://sourcemaking.com/design_patterns/observer | ||
*/ | ||
class NodesObserver | ||
{ | ||
public: | ||
/** | ||
* @brief Registers this observer with the subject class to receive updates. | ||
* @param node_values The subject holding the Hermite node values. | ||
*/ | ||
NodesObserver(std::weak_ptr<NodesVariables> node_values); | ||
virtual ~NodesObserver() = default; | ||
|
||
/** | ||
* @brief Callback method called every time the subject changes. | ||
*/ | ||
virtual void UpdateNodes() = 0; | ||
|
||
protected: | ||
std::weak_ptr<NodesVariables> node_values_; | ||
}; | ||
} // namespace trajopt_ifopt | ||
#endif // TRAJOPT_IFOPT_TRAJOPT_NODES_OBSERVER_H |
143 changes: 143 additions & 0 deletions
143
trajopt_ifopt/trajopt/include/trajopt_ifopt/trajopt/variable_sets/nodes_variables.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
/****************************************************************************** | ||
Copyright (c) 2018, Alexander W. Winkler. All rights reserved. | ||
Redistribution and use in source and binary forms, with or without | ||
modification, are permitted provided that the following conditions are met: | ||
* Redistributions of source code must retain the above copyright notice, this | ||
list of conditions and the following disclaimer. | ||
* Redistributions in binary form must reproduce the above copyright notice, | ||
this list of conditions and the following disclaimer in the documentation | ||
and/or other materials provided with the distribution. | ||
* Neither the name of the copyright holder nor the names of its | ||
contributors may be used to endorse or promote products derived from | ||
this software without specific prior written permission. | ||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | ||
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | ||
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | ||
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | ||
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
******************************************************************************/ | ||
|
||
#ifndef TRAJOPT_IFOPT_TRAJOPT_NODES_VARIABLES_H | ||
#define TRAJOPT_IFOPT_TRAJOPT_NODES_VARIABLES_H | ||
|
||
#include <trajopt_common/macros.h> | ||
TRAJOPT_IGNORE_WARNINGS_PUSH | ||
#include <ifopt/variable_set.h> | ||
#include <ifopt/bounds.h> | ||
#include <Eigen/Core> | ||
TRAJOPT_IGNORE_WARNINGS_POP | ||
|
||
#include <trajopt_ifopt/trajopt/variable_sets/node.h> | ||
|
||
namespace trajopt_ifopt | ||
{ | ||
class NodesObserver; | ||
|
||
class NodesVariables : public ifopt::VariableSet | ||
{ | ||
public: | ||
using Ptr = std::shared_ptr<NodesVariables>; | ||
|
||
/** | ||
* @brief Add node to the variable set | ||
* @param node The node to append | ||
*/ | ||
void AddNode(Node node); | ||
|
||
/** | ||
* @brief Get node based on index | ||
* @param opt_idx The node index | ||
* @return The node | ||
*/ | ||
const Node& GetNode(std::size_t opt_idx) const; | ||
|
||
/** | ||
* @brief Pure optimization variables that define the nodes. | ||
* | ||
* Not all node position and velocities are independent or optimized over, so | ||
* usually the number of optimization variables is less than all nodes' pos/vel. | ||
* | ||
* @sa GetNodeInfoAtOptIndex() | ||
*/ | ||
VectorXd GetValues() const override; | ||
|
||
/** | ||
* @brief Sets some node positions and velocity from the optimization variables. | ||
* @param x The optimization variables. | ||
* | ||
* Not all node position and velocities are independent or optimized over, so | ||
* usually the number of optimization variables is less than | ||
* all nodes pos/vel. | ||
* | ||
* @sa GetNodeValuesInfo() | ||
*/ | ||
void SetVariables(const VectorXd& x) override; | ||
|
||
/** | ||
* @returns the bounds on position and velocity of each node and dimension. | ||
*/ | ||
VecBound GetBounds() const override; | ||
|
||
/** | ||
* @returns All the nodes that can be used to reconstruct the spline. | ||
*/ | ||
const std::vector<Node> GetNodes() const; | ||
|
||
/** | ||
* @brief Adds a dependent observer that gets notified when the nodes change. | ||
* @param spline Usually a pointer to a spline which uses the node values. | ||
*/ | ||
void AddObserver(std::shared_ptr<NodesObserver> observer); | ||
|
||
/** | ||
* @returns The dimensions (x,y,z) of every node. | ||
*/ | ||
Eigen::Index GetDim() const; | ||
|
||
protected: | ||
/** | ||
* @param n_dim The number of dimensions (x,y,..) each node has. | ||
* @param variable_name The name of the variables in the optimization problem. | ||
*/ | ||
NodesVariables(const std::string& variable_name); | ||
virtual ~NodesVariables() = default; | ||
|
||
Eigen::VectorXd values_; | ||
VecBound bounds_; ///< the bounds on the node values. | ||
std::vector<std::pair<Eigen::Index, Node>> nodes_; | ||
Eigen::Index n_dim_{ -1 }; | ||
std::vector<std::shared_ptr<NodesObserver>> observers_; | ||
|
||
/** @brief Notifies the subscribed observers that the node values changes. */ | ||
void UpdateObservers(); | ||
|
||
// /** | ||
// * @brief Bounds a specific node variables. | ||
// * @param node_id The ID of the node to bound. | ||
// * @param deriv The derivative of the node to set. | ||
// * @param dim The dimension of the node to bound. | ||
// * @param values The values to set the bounds to. | ||
// */ | ||
// void AddBounds(int node_id, Dx deriv, const std::vector<int>& dim, | ||
// const VectorXd& values); | ||
// /** | ||
// * @brief Restricts a specific optimization variables. | ||
// * @param node_info The specs of the optimization variables to restrict. | ||
// * @param value The value to set the bounds to. | ||
// */ | ||
// void AddBound(const NodeValueInfo& node_info, double value); | ||
}; | ||
|
||
} // namespace trajopt_ifopt | ||
|
||
#endif // TRAJOPT_IFOPT_TRAJOPT_NODES_VARIABLES_H |
Oops, something went wrong.