SMACC2
Loading...
Searching...
No Matches
smacc2_client_library
cl_px4_mr
src
cl_px4_mr
client_behaviors
cb_yaw_rotate.cpp
Go to the documentation of this file.
1
// Copyright 2025 Robosoft Inc.
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
// http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
#include <
cl_px4_mr/client_behaviors/cb_yaw_rotate.hpp
>
16
#include <
cl_px4_mr/components/cp_trajectory_setpoint.hpp
>
17
#include <
cl_px4_mr/components/cp_vehicle_local_position.hpp
>
18
19
namespace
cl_px4_mr
20
{
21
22
CbYawRotate::CbYawRotate
(
float
targetYawRad,
bool
relative)
23
: targetYawRad_(targetYawRad), relative_(relative)
24
{
25
}
26
27
void
CbYawRotate::onEntry
()
28
{
29
this->
requiresComponent
(
trajectorySetpoint_
);
30
this->
requiresComponent
(
localPosition_
);
31
32
float
currentYaw =
localPosition_
->
getHeading
();
33
34
if
(
relative_
)
35
{
36
absoluteTargetYaw_
= currentYaw +
targetYawRad_
;
37
}
38
else
39
{
40
absoluteTargetYaw_
=
targetYawRad_
;
41
}
42
43
// Normalize to [-PI, PI]
44
absoluteTargetYaw_
= std::atan2(std::sin(
absoluteTargetYaw_
), std::cos(
absoluteTargetYaw_
));
45
46
float
curX =
localPosition_
->
getX
();
47
float
curY =
localPosition_
->
getY
();
48
float
curZ =
localPosition_
->
getZ
();
49
50
RCLCPP_INFO(
51
getLogger
(),
"CbYawRotate: rotating from %.2f to %.2f rad (relative=%d)"
, currentYaw,
52
absoluteTargetYaw_
,
relative_
);
53
54
trajectorySetpoint_
->
setPositionNED
(curX, curY, curZ,
absoluteTargetYaw_
);
55
}
56
57
void
CbYawRotate::onExit
() {}
58
59
void
CbYawRotate::update
()
60
{
61
float
currentYaw =
localPosition_
->
getHeading
();
62
63
// Compute shortest angular distance
64
float
diff =
absoluteTargetYaw_
- currentYaw;
65
diff = std::atan2(std::sin(diff), std::cos(diff));
66
67
if
(std::abs(diff) < 0.1f)
68
{
69
RCLCPP_INFO(
70
getLogger
(),
"CbYawRotate: target yaw reached (error=%.3f rad) - posting success"
,
71
std::abs(diff));
72
this->
postSuccessEvent
();
73
}
74
}
75
76
}
// namespace cl_px4_mr
cb_yaw_rotate.hpp
cl_px4_mr::CbYawRotate::targetYawRad_
float targetYawRad_
Definition
cb_yaw_rotate.hpp:36
cl_px4_mr::CbYawRotate::CbYawRotate
CbYawRotate(float targetYawRad, bool relative=false)
Definition
cb_yaw_rotate.cpp:22
cl_px4_mr::CbYawRotate::localPosition_
CpVehicleLocalPosition * localPosition_
Definition
cb_yaw_rotate.hpp:41
cl_px4_mr::CbYawRotate::onEntry
void onEntry() override
Definition
cb_yaw_rotate.cpp:27
cl_px4_mr::CbYawRotate::update
void update() override
Definition
cb_yaw_rotate.cpp:59
cl_px4_mr::CbYawRotate::relative_
bool relative_
Definition
cb_yaw_rotate.hpp:37
cl_px4_mr::CbYawRotate::absoluteTargetYaw_
float absoluteTargetYaw_
Definition
cb_yaw_rotate.hpp:38
cl_px4_mr::CbYawRotate::onExit
void onExit() override
Definition
cb_yaw_rotate.cpp:57
cl_px4_mr::CbYawRotate::trajectorySetpoint_
CpTrajectorySetpoint * trajectorySetpoint_
Definition
cb_yaw_rotate.hpp:40
cl_px4_mr::CpTrajectorySetpoint::setPositionNED
void setPositionNED(float x, float y, float z, float yaw=std::numeric_limits< float >::quiet_NaN())
Definition
cp_trajectory_setpoint.cpp:46
cl_px4_mr::CpVehicleLocalPosition::getY
float getY() const
Definition
cp_vehicle_local_position.cpp:52
cl_px4_mr::CpVehicleLocalPosition::getX
float getX() const
Definition
cp_vehicle_local_position.cpp:46
cl_px4_mr::CpVehicleLocalPosition::getHeading
float getHeading() const
Definition
cp_vehicle_local_position.cpp:64
cl_px4_mr::CpVehicleLocalPosition::getZ
float getZ() const
Definition
cp_vehicle_local_position.cpp:58
smacc2::ISmaccClientBehavior::getLogger
virtual rclcpp::Logger getLogger() const
Definition
smacc_client_behavior_base.cpp:43
smacc2::ISmaccClientBehavior::requiresComponent
void requiresComponent(SmaccComponentType *&storage, ComponentRequirement requirementType=ComponentRequirement::SOFT)
Definition
smacc_client_behavior_impl.hpp:73
smacc2::SmaccAsyncClientBehavior::postSuccessEvent
void postSuccessEvent()
Definition
smacc_client_async_behavior.cpp:153
cp_trajectory_setpoint.hpp
cp_vehicle_local_position.hpp
cl_px4_mr
Definition
cl_px4_mr.hpp:29
Generated by
1.12.0