-
Notifications
You must be signed in to change notification settings - Fork 179
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
Lars Berscheid
committed
Feb 22, 2021
1 parent
4755cff
commit e029558
Showing
20 changed files
with
856 additions
and
449 deletions.
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
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
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
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,97 @@ | ||
#pragma once | ||
|
||
#include <limits> | ||
#include <optional> | ||
|
||
#include <ruckig/profile.hpp> | ||
|
||
|
||
namespace ruckig { | ||
|
||
//! Which times are possible for synchronization? | ||
struct Block { | ||
struct Interval { | ||
double left, right; // [s] | ||
Profile profile; // Profile corresponding to right (end) time | ||
|
||
explicit Interval(double left, double right, const Profile& profile): left(left), right(right), profile(profile) { }; | ||
}; | ||
|
||
Profile p_min; // Save min profile so that it doesn't need to be recalculated in Step2 | ||
double t_min; // [s] | ||
|
||
// Max. 2 intervals can be blocked: called a and b with corresponding profiles, order does not matter | ||
std::optional<Interval> a, b; | ||
|
||
explicit Block() { } | ||
explicit Block(const Profile& p_min): p_min(p_min), t_min(p_min.t_sum[6] + p_min.t_brake.value_or(0.0)) { } | ||
|
||
bool is_blocked(double t) const { | ||
return (t < t_min) || (a && a->left < t && t < a->right) || (b && b->left < t && t < b->right); | ||
} | ||
|
||
inline static void add_interval(std::optional<Block::Interval>& interval, const Profile& left, const Profile& right) { | ||
const double left_duration = left.t_sum[6] + left.t_brake.value_or(0.0); | ||
const double right_duraction = right.t_sum[6] + right.t_brake.value_or(0.0); | ||
if (left_duration < right_duraction) { | ||
interval = Block::Interval(left_duration, right_duraction, right); | ||
} else { | ||
interval = Block::Interval(right_duraction, left_duration, left); | ||
} | ||
} | ||
|
||
template<size_t N> | ||
static bool calculate_block(Block& block, const std::array<Profile, N>& valid_profiles, const size_t valid_profile_counter) { | ||
// if (valid_profile_counter > 0) | ||
// { | ||
// std::cout << "---\n " << valid_profile_counter << std::endl; | ||
// for (size_t i = 0; i < valid_profile_counter; ++i) { | ||
// std::cout << valid_profiles[i].t_sum[6] << " " << valid_profiles[i].to_string() << std::endl; | ||
// } | ||
// } | ||
|
||
if ( | ||
(valid_profile_counter == 1) | ||
|| (valid_profile_counter == 2 && std::abs(valid_profiles[0].t_sum[6] - valid_profiles[1].t_sum[6]) < std::numeric_limits<double>::epsilon()) | ||
) { | ||
block = Block(valid_profiles[0]); | ||
return true; | ||
|
||
} else if (valid_profile_counter % 2 == 0) { | ||
return false; | ||
} | ||
|
||
// Find index of fastest profile | ||
auto idx_min_it = std::min_element(valid_profiles.cbegin(), valid_profiles.cbegin() + valid_profile_counter, [](auto& a, auto& b) { return a.t_sum[6] + a.t_brake.value_or(0.0) < b.t_sum[6] + b.t_brake.value_or(0.0); }); | ||
size_t idx_min = std::distance(valid_profiles.cbegin(), idx_min_it); | ||
|
||
block = Block(valid_profiles[idx_min]); | ||
|
||
if (valid_profile_counter == 3) { | ||
size_t idx_else_1 = (idx_min + 1) % 3; | ||
size_t idx_else_2 = (idx_min + 2) % 3; | ||
|
||
Block::add_interval(block.a, valid_profiles[idx_else_1], valid_profiles[idx_else_2]); | ||
return true; | ||
|
||
} else if (valid_profile_counter == 5) { | ||
size_t idx_else_1 = (idx_min + 1) % 5; | ||
size_t idx_else_2 = (idx_min + 2) % 5; | ||
size_t idx_else_3 = (idx_min + 3) % 5; | ||
size_t idx_else_4 = (idx_min + 4) % 5; | ||
|
||
if (valid_profiles[idx_else_1].direction == valid_profiles[idx_else_2].direction) { | ||
Block::add_interval(block.a, valid_profiles[idx_else_1], valid_profiles[idx_else_2]); | ||
Block::add_interval(block.b, valid_profiles[idx_else_3], valid_profiles[idx_else_4]); | ||
} else { | ||
Block::add_interval(block.a, valid_profiles[idx_else_1], valid_profiles[idx_else_4]); | ||
Block::add_interval(block.b, valid_profiles[idx_else_2], valid_profiles[idx_else_3]); | ||
} | ||
return true; | ||
} | ||
|
||
return false; | ||
} | ||
}; | ||
|
||
} // namespace ruckig |
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,20 @@ | ||
#pragma once | ||
|
||
#include <array> | ||
|
||
|
||
namespace ruckig { | ||
|
||
//! Calculates (pre-) trajectory to get current state below the limits | ||
class Brake { | ||
static constexpr double eps {2e-14}; | ||
|
||
static void acceleration_brake(double v0, double a0, double vMax, double vMin, double aMax, double aMin, double jMax, std::array<double, 2>& t_brake, std::array<double, 2>& j_brake); | ||
static void velocity_brake(double v0, double a0, double vMax, double vMin, double aMax, double aMin, double jMax, std::array<double, 2>& t_brake, std::array<double, 2>& j_brake); | ||
|
||
public: | ||
static void get_position_brake_trajectory(double v0, double a0, double vMax, double vMin, double aMax, double aMin, double jMax, std::array<double, 2>& t_brake, std::array<double, 2>& j_brake); | ||
static void get_velocity_brake_trajectory(double a0, double aMax, double aMin, double jMax, std::array<double, 2>& t_brake, std::array<double, 2>& j_brake); | ||
}; | ||
|
||
} // namespace ruckig |
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
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
Oops, something went wrong.