Difference between revisions of "Architecture:RPD Server"

From The BABEL Development Site
(RPD_Server)
(RPD_Server)
 
(10 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
<table width="95%"><tr>
 
<table width="95%"><tr>
 
<td align="left"> <small>Previous: [[Architecture:Unique Event Codes | Event Codes]]</small> </td>
 
<td align="left"> <small>Previous: [[Architecture:Unique Event Codes | Event Codes]]</small> </td>
<td align="right"> <small>Next: [[Architecture:High Level ACHRIN layer | ACHRIN]]</small></td></tr>
+
<td align="right"> <small>Next: [[Architecture:Visual_RPD_Editor | Visual RPD Editor]]</small>
 
</table>
 
</table>
  
Line 16: Line 16:
  
 
'''NOTE:''' The most important service here for now is ''getSettingsForModule'', which is a replacement for individual .ini files in modules.
 
'''NOTE:''' The most important service here for now is ''getSettingsForModule'', which is a replacement for individual .ini files in modules.
 +
 +
 +
TO DO: Remote binary file storage...
  
  
Line 32: Line 35:
 
  <td> <!-- DECLARATION -->
 
  <td> <!-- DECLARATION -->
 
<cpp>
 
<cpp>
::getRobotName(
+
::getParam(
out string name
+
in string name,
 +
out string value
 
)
 
)
 
</cpp>
 
</cpp>
 
  </td>
 
  </td>
 
  <td> <!-- COMMENTS -->
 
  <td> <!-- COMMENTS -->
Returns the name of the currently selected RPD, as appearing in the selected_RPD table
+
A generic way to retrieve a parameter from the table "global_params".
 
  </td>
 
  </td>
</tr>
 
 
<tr>
 
<td> <!-- DECLARATION -->
 
<cpp>
 
::getRobot2DShape(
 
out COMMMON::SeqOfFloats x,
 
out COMMMON::SeqOfFloats y
 
)
 
 
</cpp>
 
</td>
 
<td> <!-- COMMENTS -->
 
Returns the 2D shape of the robot, as stored in the RPD_shape2D… table of its descriptor.
 
</td>
 
</tr>
 
 
<tr>
 
<td> <!-- DECLARATION -->
 
<cpp>
 
::getAllLogicalDevices(
 
out BABEL::RPD_Server::SeqOfLogicalDevices devices
 
)
 
</cpp>
 
</td>
 
<td> <!-- COMMENTS -->
 
Returns all the information for all the logical devices on the robot. See Appendix III for BDL definitions
 
</td>
 
</tr>
 
 
<tr>
 
<td> <!-- DECLARATION -->
 
<cpp>
 
::findLogicalDevicesByType(
 
in string type,
 
out BABEL::RPD_Server::SeqOfLogicalDevices devices
 
)
 
</cpp>
 
</td>
 
<td> <!-- COMMENTS -->
 
Returns all the information for logical devices on the robot of the specified type (case insensitive comparison). See Appendix III for BDL definitions.
 
</td>
 
</tr>
 
 
<tr>
 
<td> <!-- DECLARATION -->
 
<cpp>
 
::getLogicalDevicePose(
 
in unsigned long deviceID,
 
out double x,
 
out double y,
 
out double z,
 
out double yaw,
 
out double pitch,
 
out double roll,
 
out boolean static,
 
out boolean devNotFound
 
)
 
</cpp>
 
</td>
 
<td> <!-- COMMENTS -->
 
Returns the current 3D pose of the indicated device (if not found, devNotFound will be true). This includes solving the cinematic chain, even for the case of mobile joints. If the device has a static pose, static will be true, and its pose must not be requested anymore.
 
</td>
 
 
</tr>
 
</tr>
  
Line 116: Line 57:
 
  </td>
 
  </td>
 
  <td> <!-- COMMENTS -->
 
  <td> <!-- COMMENTS -->
Returns a multi-line text in the form “key=value” with settings for a specific calling module name (and optionally an alias name, left blank if not used). This text is the content of the field “ini” for the table “INI_<moduleName>[+<myAlias>]@<robotName>.
+
Returns a multi-line text in the form “key=value” with settings for a specific calling module name (and optionally an alias name, left blank if not used).  
 +
This text is the content of the field "config" for the table <robot_name>:<moduleName>:Alias".
 
</td>
 
</td>
 
</tr>
 
</tr>
 +
  
 
</table>
 
</table>
Line 128: Line 71:
 
<br>
 
<br>
  
= RPD Visual Editor =
+
= Definition of RPD_SERVER data types in BDL =  
 
 
 
 
  
  
= Definition of RPD_SERVER data types in BDL =
+
('''Not used yet''')
 
 
  
 
<cpp>
 
<cpp>

Latest revision as of 08:59, 29 May 2009

Previous: Event Codes Next: Visual RPD Editor


RPD_Server

This special module MUST BE ALWAYS present, since it is used by all the modules at start-up to determine their configuration based on the XML database.

Al services should be executed in less than 100ms, except the getLogicalDevicePose service which may require invoking several other services to acquire the current configuration of mobile parts of the robot. Notice that the returned information for any logical device implicitly includes the parameters for opening the associated HAD layer driver module. This information is extracted from the physical devices table in the database and automatically put together to all responses of the server to make easy the opening of drivers by layer 2 modules.


NOTE: The most important service here for now is getSettingsForModule, which is a replacement for individual .ini files in modules.


TO DO: Remote binary file storage...



BABEL service group BABEL services to implement

RPD_Server

<cpp>

getParam(

in string name, out string value ) </cpp>

A generic way to retrieve a parameter from the table "global_params".

<cpp>

getSettingsForModule(

in string myModuleName, in string myAlias, out string settings ) </cpp>

Returns a multi-line text in the form “key=value” with settings for a specific calling module name (and optionally an alias name, left blank if not used). This text is the content of the field "config" for the table “<robot_name>:<moduleName>:Alias".




Definition of RPD_SERVER data types in BDL

(Not used yet)

<cpp> struct TLogicalDevice { unsigned long id; // The numerical ID of each device string type; // The logical device type boolean isChainingPoint; // Whether the device can be the base // for other devices. unsigned long idOfBase; // The id of the base device COMMMON::THomogeneousMatrix pose3D; // The 3D pose of this device relative // to the base one. string implementation; // The name of the HAD layer module.

COMMMON::SeqOfParamValuePairs params; // The params for the HAD module. };

typedef sequence<TLogicalDevice> SeqOfLogicalDevices;

</cpp>