このページではOpenRTM-aistのRTC操作関数群CORBA_RTCUtil機能の利用方法に説明します。
今回使用したソースコードは以下から入手できます。
C++の場合はOpenRTM-aistとリンクしたプログラムをビルドする環境が必要です。
以下のCMakeLists.txtを作成してください。
cmake_minimum_required(VERSION 3.1) set(target CORBA_RTCUtil_test) project(${target} CXX) find_package(OpenRTM REQUIRED) add_definitions(${OPENRTM_CFLAGS}) link_directories(${OPENRTM_LIBRARY_DIRS}) add_executable(${target} ${target}.cpp) target_link_libraries(${target} ${OPENRTM_LIBRARIES}) target_include_directories(${target} SYSTEM PRIVATE ${OPENRTM_INCLUDE_DIRS})
また、CORBA_RTCUtil_test.cppのソースファイルを作成してCMakeを実行します。 ソースコードからビルドしたOpenRTM-aistを使う場合は、environment-setup.omniorb.vc**.batを実行します。
%OPENRTM_INSTALL_DIR%\2.0.0\ext\environment-setup.omniorb.vc16.bat mkdir build cd build cmake ..
CORBA_RTCUtil_test.cppには以下の内容を記述しておきます。
#include <rtm/Manager.h> #include <rtm/NamingManager.h> #include <rtm/CORBA_RTCUtil.h> #include <iostream> int main (int argc, char** argv) { RTC::Manager* manager; manager = RTC::Manager::init(argc, argv); manager->activateManager(); manager->runManager(true); RTC::RTObject_var consolein = RTC::RTObject::_nil(); RTC::RTObject_var consoleout = RTC::RTObject::_nil(); RTC::NamingManager* nm = RTC::Manager::instance().getNaming(); RTC::RTCList consoleinlist = nm->string_to_component("rtcname://localhost:2809/*/ConsoleIn0"); if (consoleinlist.length() > 0) { consolein = consoleinlist[0]; } else { std::cout << "Could not found ConsoleIn0" << std::endl; return 1; } RTC::RTCList consoleoutlist = nm->string_to_component("rtcname://localhost:2809/*/ConsoleOut0"); if (consoleoutlist.length() > 0) { consoleout = consoleoutlist[0]; } else { std::cout << "Could not found ConsoleOut0" << std::endl; return 1; } RTC::RTObject_var configsample = RTC::RTObject::_nil(); RTC::RTCList configsamplelist = nm->string_to_component("rtcname://localhost:2809/*/ConfigSample0"); if (configsamplelist.length() > 0) { configsample = configsamplelist[0]; } else { std::cout << "Could not found ConfigSample0" << std::endl; return 1; } RTC::RTObject_var myserviceprovider = RTC::RTObject::_nil(); RTC::RTCList myserviceproviderlist = nm->string_to_component("rtcname://localhost:2809/*/MyServiceProvider0"); if (myserviceproviderlist.length() > 0) { myserviceprovider = myserviceproviderlist[0]; } else { std::cout << "Could not found MyServiceProvider0" << std::endl; return 1; } RTC::RTObject_var myserviceconsumer = RTC::RTObject::_nil(); RTC::RTCList myserviceconsumerlist = nm->string_to_component("rtcname://localhost:2809/*/MyServiceConsumer0"); if (myserviceconsumerlist.length() > 0) { myserviceconsumer = myserviceconsumerlist[0]; } else { std::cout << "Could not found MyServiceConsumer0" << std::endl; return 1; } //以降の処理はここに記述する manager->terminate(); manager->join(); return 0; }
Pythonの場合は以下のCORBA_RTCUtil_test.pyを用意してください。
#!/usr/bin/env python # -*- coding: utf-8 -*- # -*- Python -*- import sys import OpenRTM_aist import OpenRTM_aist.CORBA_RTCUtil from omniORB import CORBA def main(): mgr = OpenRTM_aist.Manager.init(sys.argv) mgr.activateManager() mgr.runManager(True) nm = OpenRTM_aist.Manager.instance().getNaming() consoleinlist = nm.string_to_component( "rtcname://localhost:2809/*/ConsoleIn0") if consoleinlist: consolein = consoleinlist[0] else: print("Could not found ConsoleIn0") sys.exit(1) consoleoutlist = nm.string_to_component( "rtcname://localhost:2809/*/ConsoleOut0") if consoleoutlist: consoleout = consoleoutlist[0] else: print("Could not found ConsoleOut0") sys.exit(1) configsamplelist = nm.string_to_component( "rtcname://localhost:2809/*/ConfigSample0") if consoleoutlist: configsample = consoleoutlist[0] else: print("Could not found ConfigSample0") sys.exit(1) myserviceproviderlist = nm.string_to_component( "rtcname://localhost:2809/*/MyServiceProvider0") if myserviceproviderlist: myserviceprovider = myserviceproviderlist[0] else: print("Could not found MyServiceProvider0") sys.exit(1) myserviceconsumerlist = nm.string_to_component( "rtcname://localhost:2809/*/ConsoleOut0") if myserviceconsumerlist: myserviceconsumer = myserviceconsumerlist[0] else: print("Could not found ConsoleOut0") sys.exit(1) #以降の処理はここに記述する mgr.shutdown() if __name__ == "__main__": main()
以下の内容のrtc.confを作成してください。
manager.shutdown_auto: NO
ConsoleIn、ConsoleOut、ConfiguSample、MyServiceProvider、MyServiceConsumerのサンプルコンポーネントを起動しておきます。
データポートの接続のために、ポートのオブジェクトリファレンスを取得するget_port_by_name関数を使用します。
関数名 | get_port_by_name | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
name | std::string& | RTC名.ポート名 |
戻り値 | ||
型名 | 意味 | |
RTC::PortService_ptr | ポートのオブジェクトリファレンス |
RTC::PortService_var port_in_var = CORBA_RTCUtil::get_port_by_name(consoleout.in(), "ConsoleOut0.in"); if (CORBA::is_nil(port_in_var)) { std::cout << "Could not found ConsoleOut0.in" << std::endl; return 1; } RTC::PortService_var port_out_var = CORBA_RTCUtil::get_port_by_name(consolein.in(), "ConsoleIn0.out"); if (CORBA::is_nil(port_out_var)) { std::cout << "Could not found ConsoleIn0.out" << std::endl; return 1; }
port_in_var = OpenRTM_aist.CORBA_RTCUtil.get_port_by_name( consoleout, "ConsoleOut0.in") if CORBA.is_nil(port_in_var): print("Could not found ConsoleOut0.in") sys.exit(1) port_out_var = OpenRTM_aist.CORBA_RTCUtil.get_port_by_name( consolein, "ConsoleIn0.out") if CORBA.is_nil(port_out_var): print("Could not found ConsoleOut0.in") sys.exit(1)
またget_port_by_url関数を使用すると、rtcname形式、rtcloc形式の文字列からオブジェクトリファレンスを取得できます。
関数名 | get_port_by_url | |
引数 | ||
引数名 | 型名 | 意味 |
port_name | std::string& | ポートのURI |
戻り値 | ||
型名 | 意味 | |
RTC::PortService_ptr | ポートのオブジェクトリファレンス |
RTC::PortService_var port_in_var = CORBA_RTCUtil::get_port_by_url("rtcname://localhost:2809/*/ConsoleOut0.in"); if (CORBA::is_nil(port_in_var)) { std::cout << "Could not found ConsoleOut0.in" << std::endl; return 1; } RTC::PortService_var port_out_var = CORBA_RTCUtil::get_port_by_url("rtcname://localhost:2809/*/ConsoleIn0.out"); if (CORBA::is_nil(port_out_var)) { std::cout << "Could not found ConsoleIn0.out" << std::endl; return 1; }
port_in_var = OpenRTM_aist.CORBA_RTCUtil.get_port_by_url( "rtcname://localhost:2809/*/ConsoleOut0.in") if CORBA.is_nil(port_in_var): print("Could not found ConsoleOut0.in") sys.exit(1) port_out_var = OpenRTM_aist.CORBA_RTCUtil.get_port_by_url( "rtcname://localhost:2809/*/ConsoleIn0.out") if CORBA.is_nil(port_out_var): print("Could not found ConsoleOut0.in") sys.exit(1)
取得したデータポートをconnect関数で接続します。
関数名 | connect | |
引数 | ||
引数名 | 型名 | 意味 |
name | std::string& | コネクタの名前 |
prop | coil::Properties& | コネクタの設定情報 |
port0 | RTC::PortService_ptr | 接続するポート1 |
port1 | RTC::PortService_ptr | 接続するポート2 |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
coil::Properties prop; prop["dataport.dataflow_type"] = "push"; prop["dataport.interface_type"] = "corba_cdr"; prop["dataport.subscription_type"] = "new"; CORBA_RTCUtil::connect("test_connector", prop, port_in_var.in(), port_out_var.in());
prop = OpenRTM_aist.Properties() prop.setProperty("dataport.dataflow_type", "push") prop.setProperty("dataport.interface_type", "corba_cdr") prop.setProperty("dataport.subscription_type", "new") OpenRTM_aist.CORBA_RTCUtil.connect( "test_connector", prop, port_in_var, port_out_var)
関数名 | disconnect_connector_name | |
引数 | ||
引数名 | 型名 | 意味 |
port_ref | RTC::PortService_ptr | 接続中のポート |
conn_name | std::string& | コネクタの名前 |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
コネクタ名を指定してコネクタを削除するためにはdisconnect_connector_name関数を使用します。
CORBA_RTCUtil::disconnect_connector_name(port_in_var.in(), "test_connector");
OpenRTM_aist.CORBA_RTCUtil.disconnect_by_portref_connector_name( port_in_var, "test_connector")
コネクタのURIからオブジェクトリファレンスを取得してコネクタを削除する場合はdisconnect_connector_name関数を使用します。
関数名 | disconnect_connector_name | |
引数 | ||
引数名 | 型名 | 意味 |
port_name | std::string& | ポートのURI |
conn_name | std::string& | コネクタの名前 |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::disconnect_connector_name("rtcname://localhost:2809/*/ConsoleOut0.in", "test_connector");
OpenRTM_aist.CORBA_RTCUtil.disconnect_by_portname_connector_name( "rtcname://localhost:2809/*/ConsoleOut0.in", "test_connector")
複数のポートを一度に接続するためにはconnect_multi関数を使用します。
関数名 | connect_multi | |
引数 | ||
引数名 | 型名 | 意味 |
name | std::string& | コネクタの名前 |
prop | coil::Properties& | コネクタの設定情報 |
port0 | RTC::PortService_ptr | 接続するポート1 |
target_ports | RTC::PortServiceList& | ポート1と接続するポートのリスト |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
RTC::PortServiceList target_ports; target_ports.length(1); target_ports[0] = RTC::PortService::_duplicate(port_out_var.in()); CORBA_RTCUtil::connect_multi("test_connector", prop, port_in_var.in(), target_ports);
OpenRTM_aist.CORBA_RTCUtil.connect_multi( "test_connector", prop, port_in_var, [port_out_var])
対象ポートのすべてのコネクタを削除するためにはdisconnect_all関数を使います。
関数名 | disconnect_all | |
引数 | ||
引数名 | 型名 | 意味 |
port_ref | RTC::PortService_ptr | 接続中のポート |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::disconnect_all(port_in_var.in());
OpenRTM_aist.CORBA_RTCUtil.disconnect_all_by_ref(port_in_var)
関数名 | disconnect_all | |
引数 | ||
引数名 | 型名 | 意味 |
port_name | std::string& | ポートのURI |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::disconnect_all("rtcname://localhost:2809/*/ConsoleIn0.out");
OpenRTM_aist.CORBA_RTCUtil.disconnect_all_by_name( "rtcname://localhost:2809/*/ConsoleIn0.out")
RTCをアクティブ化するためにはactivate関数を使用します。
関数名 | activate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
RTCは状態を実行コンテキストごとに持っているため、デフォルトの実行コンテキスト(ID:0)以外で状態を変更する場合はec_idを指定します。
CORBA_RTCUtil::activate(consolein.in(), 0); CORBA_RTCUtil::activate(consoleout.in(), 0);
OpenRTM_aist.CORBA_RTCUtil.activate(consoleout, 0) OpenRTM_aist.CORBA_RTCUtil.activate(consolein, 0)
RTCを非アクティブ化するためにはdeactivate関数を使用します。
関数名 | deactivate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::deactivate(consolein.in(), 0); CORBA_RTCUtil::deactivate(consoleout.in(), 0);
OpenRTM_aist.CORBA_RTCUtil.deactivate(consoleout, 0) OpenRTM_aist.CORBA_RTCUtil.deactivate(consolein, 0)
RTCをリセットするためにはreset関数を使用します。
関数名 | reset | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::reset(consolein.in(), 0); CORBA_RTCUtil::reset(consoleout.in(), 0);
OpenRTM_aist.CORBA_RTCUtil.reset(consoleout, 0) OpenRTM_aist.CORBA_RTCUtil.reset(consolein, 0)
RTCの現在の状態を取得するためにはget_state関数を使用します。
関数名 | get_state | |
引数 | ||
引数名 | 型名 | 意味 |
state | RTC::LifeCycleState | 状態 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
戻り値 | ||
型名 | 意味 | |
bool | true:状態取得成功、false:状態取得失敗 |
RTC::LifeCycleState state; CORBA_RTCUtil::get_state(state, consoleout.in(), 0); std::cout << state << std::endl;
ret, state = OpenRTM_aist.CORBA_RTCUtil.get_state(consoleout, 0) print(state)
また、is_in_inactive関数、is_in_active関数、is_in_error関数で現在の状態が非アクティブ状態、アクティブ状態、エラー状態かを判定できます。
if (CORBA_RTCUtil::is_in_inactive(consoleout.in()))
{ std::cout << "Inactive State" << std::endl; } else if (CORBA_RTCUtil::is_in_active(consoleout.in())) { std::cout << "Active State" << std::endl; } else if (CORBA_RTCUtil::is_in_error(consoleout.in())) { std::cout << "Error State" << std::endl; }
if OpenRTM_aist.CORBA_RTCUtil.is_in_inactive(consoleout): print("Inactive State") elif OpenRTM_aist.CORBA_RTCUtil.is_in_active(consoleout): print("Active State") elif OpenRTM_aist.CORBA_RTCUtil.is_in_error(consoleout): print("Error State")
実行コンテキストの実行周期を変更するには、set_default_rate関数を使用します。
関数名 | set_default_rate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
rate | CORBA::Double | 実行周期 |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::set_default_rate(consoleout.in(), 20.0);
OpenRTM_aist.CORBA_RTCUtil.set_default_rate(consoleout, 20.0)
set_default_rate関数はデフォルトの実行コンテキストの実行周期を取得しますが、指定IDの実行コンテキストから実行周期を取得するためにはset_current_rate関数を使用します。
関数名 | set_current_rate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
rate | CORBA::Double | 実行周期 |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::set_current_rate(consoleout.in(), 0, 50.0);
OpenRTM_aist.CORBA_RTCUtil.set_current_rate(consoleout, 0, 50.0)
現在の実行周期を取得するためには、get_default_rate関数を使用します。
関数名 | get_default_rate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
CORBA::Double | 実行周期 |
std::cout << CORBA_RTCUtil::get_default_rate(consoleout.in()) << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_default_rate(consoleout))
指定IDの実行コンテキストから実行周期を取得するためにはget_current_rate関数を使用します。
関数名 | get_current_rate | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
ec_id | RTC::UniqueId | 実行コンテキストのID |
戻り値 | ||
型名 | 意味 | |
CORBA::Double | 実行周期 |
std::cout << CORBA_RTCUtil::get_current_rate(consoleout.in(), 0) << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_current_rate(consoleout, 0))
通常はRTCが起動時に生成する実行コンテキストが関連付け(アタッチ)されていますが、、外部の実行コンテキストをRTCにアタッチすると、アタッチした実行コンテキストでRTCを駆動できるようになります。
実行コンテキストを指定のRTCにアタッチするためにはadd_rtc_to_default_ec関数を使用します。
関数名 | add_rtc_to_default_ec | |
引数 | ||
引数名 | 型名 | 意味 |
localcomp | RTC::RTObject_ptr | アタッチする実行コンテキストをデフォルト実行コンテキストとして持つRTC |
othercomp | RTC::RTObject_ptr | アタッチするRTC |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::add_rtc_to_default_ec(consoleout.in(), consolein.in());
OpenRTM_aist.CORBA_RTCUtil.add_rtc_to_default_ec(consoleout, consolein)
アタッチした実行コンテキストの関連付け解除(デタッチ)するためにはremove_rtc_to_default_ec関数を使用します。
関数名 | remove_rtc_to_default_ec | |
引数 | ||
引数名 | 型名 | 意味 |
localcomp | RTC::RTObject_ptr | デタッチする実行コンテキストをデフォルト実行コンテキストとして持つRTC |
othercomp | RTC::RTObject_ptr | デタッチするRTC |
戻り値 | ||
型名 | 意味 | |
RTC::ReturnCode_t |
CORBA_RTCUtil::remove_rtc_to_default_ec(consoleout.in(), consolein.in());
OpenRTM_aist.CORBA_RTCUtil.remove_rtc_to_default_ec(consoleout, consolein)
アタッチした外部RTCの一覧を取得するためにはget_participants_rtc関数を使用します。
関数名 | get_participants_rtc | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | 対象の実行コンテキストをデフォルト実行コンテキストとして持つRTC |
戻り値 | ||
型名 | 意味 | |
RTC::RTCList |
RTC::RTCList rtclist = CORBA_RTCUtil::get_participants_rtc(consoleout.in()); for(CORBA::ULong i=0;i < rtclist.length();i++) { std::cout << i << "\t" << CORBA_RTCUtil::get_component_profile(rtclist[i].in()) << std::endl; }
i = 0 for rtc in OpenRTM_aist.CORBA_RTCUtil.get_participants_rtc(consoleout): print(i, OpenRTM_aist.CORBA_RTCUtil.get_component_profile(rtc)) i += 1
コンフィギュレーションパラメータの設定をするためにはset_active_configuration関数を使用します。 この関数では現在アクティブなコンフィギュレーションセットのパラメータが設定されます。
関数名 | set_active_configuration | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
value_name | std::string& | パラメータ名 |
value | std::string& | 設定値 |
戻り値 | ||
型名 | 意味 | |
bool | true:設定成功、false:設定失敗 |
CORBA_RTCUtil::set_active_configuration(configsample.in(), "int_param1", "100");
OpenRTM_aist.CORBA_RTCUtil.set_active_configuration( configsample, "int_param1", "100")
コンフィギュレーションセットを指定してパラメータを設定する場合はset_configuration関数を使用します。 この関数を実行すると、アクティブなコンフィギュレーションセットが変更されます。
関数名 | set_configuration | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
confset_name | std::string& | コンフィギュレーションセット名 |
value_name | std::string& | パラメータ名 |
value | std::string& | 設定値 |
戻り値 | ||
型名 | 意味 | |
bool | true:設定成功、false:設定失敗 |
CORBA_RTCUtil::set_configuration(configsample.in(), "mode0", "str_param1", "test");
OpenRTM_aist.CORBA_RTCUtil.set_configuration( configsample, "mode0", "str_param1", "test")
現在アクティブなコンフィギュレーションセットの名前を取得するにはget_active_configuration_name関数を使用します。
関数名 | get_active_configuration_name | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
std::string | コンフィギュレーションセット名 |
std::cout << CORBA_RTCUtil::get_active_configuration_name(configsample.in()) << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_active_configuration_name(configsample))
アクティブなコンフィギュレーションセットのパラメータ一覧を取得するにはget_active_configuration関数を使用します。
関数名 | get_active_configuration | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
coil::Properties | パラメータ一覧 |
std::cout << CORBA_RTCUtil::get_active_configuration(configsample.in()) << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_active_configuration(configsample))
コンフィギュレーションセットを指定してパラメータ一覧を取得するにはget_configuration関数を使用します。
関数名 | get_configuration | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
conf_name | std::string& | コンフィギュレーションセット名 |
戻り値 | ||
型名 | 意味 | |
coil::Properties | パラメータ一覧 |
std::cout << CORBA_RTCUtil::get_configuration(configsample.in(), "mode1") << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_configuration(configsample, "mode1"))
指定のパラメータのみを取得する場合はget_parameter_by_key関数を使用します。
関数名 | get_parameter_by_key | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
conf_name | std::string& | コンフィギュレーションセット名 |
value_name | std::string& | パラメータ名 |
戻り値 | ||
型名 | 意味 | |
std::string | パラメータの値 |
std::cout << CORBA_RTCUtil::get_parameter_by_key(configsample.in(), "mode1", "int_param1") << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_parameter_by_key( configsample, "mode1", "int_param1"))
コンポーネントプロファイルを取得するにはget_component_profile関数を使用します。
関数名 | get_component_profile | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
coil::Properties | コンポーネントプロファイルの情報 |
std::cout << CORBA_RTCUtil::get_component_profile(consolein.in()) << std::endl;
print(OpenRTM_aist.CORBA_RTCUtil.get_component_profile(consolein))
指定のRTCが保持しているポートの名前一覧を取得するにはget_port_names関数を使用します。
関数名 | get_port_names | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
coil::vstring | ポート名一覧 |
coil::vstring portlist = CORBA_RTCUtil::get_port_names(consolein.in()); for (auto& port : portlist) { std::cout << port << std::endl; }
for port in OpenRTM_aist.CORBA_RTCUtil.get_port_names(consolein): print(port)
InPortの名前一覧を取得するにはget_inport_names関数、OutPortの名前一覧を取得するにはget_outport_names関数、サービスポートの名前一覧を取得するにはget_svcport_names関数を使用します。
coil::vstring inportlist = CORBA_RTCUtil::get_inport_names(consoleout.in()); for (auto& port : inportlist) { std::cout << port << std::endl; }
coil::vstring outportlist = CORBA_RTCUtil::get_outport_names(consolein.in()); for (auto& port : outportlist) { std::cout << port << std::endl; } coil::vstring svcportlist = CORBA_RTCUtil::get_svcport_names(myserviceprovider.in()); for (auto& port : svcportlist) { std::cout << port << std::endl; }
for port in OpenRTM_aist.CORBA_RTCUtil.get_inport_names(consoleout): print(port) for port in OpenRTM_aist.CORBA_RTCUtil.get_outport_names(consolein): print(port) for port in OpenRTM_aist.CORBA_RTCUtil.get_svcport_names(myserviceprovider): print(port)
指定ポートのコネクタの名前一覧を取得するにはget_connector_names関数を使用します。
関数名 | get_connector_names | |
引数 | ||
引数名 | 型名 | 意味 |
port | RTC::PortService_ptr | ポートのオブジェクトリファレンス |
戻り値 | ||
型名 | 意味 | |
coil::vstring | コネクタ名一覧 |
coil::vstring inconlist = CORBA_RTCUtil::get_connector_names(port_in_var.in()); for (auto& connector : inconlist) { std::cout << connector << std::endl; }
for connector in OpenRTM_aist.CORBA_RTCUtil.get_connector_names_by_portref(port_in_var): print(connector)
ポート名を指定してコネクタの名前一覧を取得することもできます。
関数名 | get_connector_names | |
引数 | ||
引数名 | 型名 | 意味 |
rtc | RTC::RTObject_ptr | RTCのオブジェクトリファレンス |
port_name | std::string& | ポート名 |
戻り値 | ||
型名 | 意味 | |
coil::vstring | コネクタ名一覧 |
coil::vstring outconlist = CORBA_RTCUtil::get_connector_names(consolein.in(), "ConsoleIn0.out"); for (auto& connector : outconlist) { std::cout << connector << std::endl; }
for connector in OpenRTM_aist.CORBA_RTCUtil.get_connector_names(consolein, "ConsoleIn0.out"): print(connector)