【ROS2関係トップページへ】
【ROS2レクチャー:初級 -ROS1 style-】
【ROS2レクチャー:初級 -class style-】
【前:ROS2の最小構成service/client:初級 -ROS1 style-】
【前:ROS2の最小構成service/client:初級 -class style-】
【次:ROS2の最小構成parameter:初級 -ROS1 style-】
【次:ROS2の最小構成parameter:初級 -class type-】
ROS2ではあまり変動しない変数をparameterとして持つことができる.ROSでは中心的なパラメータサーバが存在したが,ROS2では各ノードが各自parameterを持つことになる.
service側とclient側
各ノードが各自parameterを持つことになるので,他のノードから自分のparameterにアクセスされることも頻繁におこる.serviceとはなにか機能を提供する側であり,clientはserviceにお願い(リクエスト)して提供される機能を享受する側である.よって他のノード=client(あるノードのパラメータの値を享受するので)となるが,実は自分=service(自分のノードのパラメータを提供する側)になるとは限らない.というのは,自分のparameterにclientとしてアクセスすることも考えらるからである.お店をservice(品物を提供する側),お客さんをclient(品物を提供してもらう側・買う側)とすると,店主は自分のお店のものをお店の一員として扱うこともできる(店主=service)が,自分のお店のものであっても自分で使うからお客として購入することもできる(店主=client).
ROS2の機能で説明するために,以下ではget_parameters関数を例にとる.
- get_parameters({"foo","bar"});
- 引数として,パラメータの名前の動的配列(vector)を渡すと値の動的配列が返ってくる
service側
パラメータを宣言し,自身のパラメータを使用するモノである.
その「モノ」はノードであるのでノードが持つパラメータアクセス関数を使用する.
例1
auto node = rclcpp::Node::make_shared("param_service_node");
...
auto res = node->get_parameters({"foo","bar"});
例2
class ParamServiceNode : public rclcpp::Node{
public:
ParamServiceNode(...):Node("param_service_node",...){
auto = this->get_parameters({"foo","bar"});
}
};
client側
service側のノードに接続し,パラメータを使用するモノである.
その「モノ」はROS2が提供する機能としての「client」である.
以下の例はservice側のノード名を"param_service_node"としているが,その部分を自分の名前(例では"test")にすると『自分のパラメータにclientとしてアクセスしている」ことになる.
例1
auto node = rclcpp::Node::make_shared("test");
auto param_client = std::make_shared<rclcpp::SyncParametersClient>(node, "param_service_node");
...
auto res = param_client->get_parameters({"foo","bar");
例2
class Test : public rclcpp::Node{
public:
ParamServiceNode(...):Node("test",...){
_param_client = std::make_shared<rclcpp::SyncParametersClient>(node, "param_service_node");
auto = _param_client->get_parameters({"foo","bar"});
private:
rclcpp::SyncParametersClient::SharedPtr _param_client;
}
serviceとclientの違い
以上見てきたように,serviceはノードとしてパラメータにアクセスし,clientはclient機能を通してアクセスする.重要な点は,同じ関数名であっても微妙に動作や引数が異なる点である.
公式のAPIのうち,ノードとしてアクセスするための関数は当該ページの"Parameters:"にあるrclcpp::Node::パラメータに関する関数もしくはrclcpp::Nodeの中から探す必要がある(どちらも同じもの).
一方で,client機能を通してアクセスする場合は公式のAPIのrclcpp::AsyncParametersClientやrclcpp::SyncParametersClientの中から探す必要がある.
【前:ROS2の最小構成service/client:初級 -ROS1 style-】
【前:ROS2の最小構成service/client:初級 -class style-】
【次:ROS2の最小構成parameter:初級 -ROS1 style-】
【次:ROS2の最小構成parameter:初級 -class type-】