RSBm » History » Version 12

S. Wrede, 10/17/2011 12:37 AM

1 1 S. Wrede
h1. RSB.m
2 1 S. Wrede
3 3 S. Wrede
We are currently exploring the best way to expose RSB in Matlab. The most straightforward way to do this is to use the Java implementation directly from within Matlab. However, as the Matlab Java interpreter is not able to handle Java's Generic types, we need to wrap around some parts of the RSBJava API which use generics.
4 3 S. Wrede
5 3 S. Wrede
For this, a very preliminary support library for Matlab is available in the Trunk repository: https://code.cor-lab.org/projects/rsb/repository/show/trunk/matlab
6 3 S. Wrede
7 3 S. Wrede
It currently includes a simple example demonstrating the live plotting of rst.JointAngles data.
8 3 S. Wrede
9 3 S. Wrede
After installation of this library, the current steps in using RSB in Matlab are as follows:
10 3 S. Wrede
11 4 S. Wrede
h2. Loading the Java RSB libraries into Matlab
12 3 S. Wrede
13 3 S. Wrede
<pre>
14 8 S. Wrede
javaaddpath /usr/share/java/RSBJava-0.5.0.jar
15 9 S. Wrede
javaaddpath /usr/share/java/protobuf.jar
16 8 S. Wrede
javaaddpath /usr/share/java/rst.jar
17 9 S. Wrede
javaaddpath /usr/share/java/rstsandbox.jar
18 8 S. Wrede
javaaddpath /${home}/workspace/RSB.m/dist/lib/rsb.m-0.5.0.jar
19 3 S. Wrede
rsb.matlab.ConverterRegistration.register()
20 3 S. Wrede
</pre>
21 3 S. Wrede
22 3 S. Wrede
The last call initializes the ProtocolBufferConverter instances with a few selected RST types. This mechanism will definitely be changed as it currently introduces an unwanted dependency (at this stage) to RST.
23 1 S. Wrede
24 6 S. Wrede
h2. Get queue object for domain-specific data
25 1 S. Wrede
26 6 S. Wrede
<pre>
27 6 S. Wrede
%   Scope must map to a rst.kinematics.JointAngles type
28 6 S. Wrede
angles = rsb.matlab.JointAnglesQueue;
29 6 S. Wrede
</pre>
30 6 S. Wrede
31 6 S. Wrede
JointAnglesQueue is a class of the RSB.m library that maps the RSB domain type rst.JointAngles to a matlab vector with floats. Furthermore, it allows access to the underlying BlockingQueue that provides further methods for queue management. See the RSBJava API documentation for more information.
32 6 S. Wrede
33 6 S. Wrede
h2. Connect queue to RSB listener
34 6 S. Wrede
35 6 S. Wrede
<pre>
36 10 S. Wrede
sub = rsb.Factory.getInstance().createListener('/oncilla');
37 6 S. Wrede
sub.activate()
38 6 S. Wrede
sub.addHandler(angles, true)
39 6 S. Wrede
</pre>
40 6 S. Wrede
41 6 S. Wrede
Pretty standard RSB API here. After the call to addHandler the angles queue receives data. You can easily check this by calling: @angles.getQueue().isEmpty()@
42 6 S. Wrede
43 6 S. Wrede
h2. Doing something useful, e.g., data visualization 
44 6 S. Wrede
45 6 S. Wrede
Having the queue, we can now operate directly on the returned floats. For instance, display them in a live plot:
46 6 S. Wrede
47 6 S. Wrede
<pre>
48 6 S. Wrede
a = zeros(1,200)
49 6 S. Wrede
while(1)
50 6 S. Wrede
a(1:end - 1) = a(2:end);
51 6 S. Wrede
% blocks until new data is available
52 6 S. Wrede
a(end) = angles.take;
53 6 S. Wrede
angles.getQueue.clear;
54 6 S. Wrede
plot(a);
55 6 S. Wrede
getframe;
56 6 S. Wrede
end
57 6 S. Wrede
</pre>
58 6 S. Wrede
59 6 S. Wrede
To prevent memory leaks, the above code clears the queue after each (blocking) call to @take@.
60 6 S. Wrede
61 6 S. Wrede
h2. Unload the RSB Java libraries
62 6 S. Wrede
63 6 S. Wrede
<pre>
64 11 S. Wrede
javarmpath ${home}/workspace/RSB.m/dist/lib/rsb.m-0.5.0.jar
65 11 S. Wrede
javarmpath /usr/share/java/rst.jar
66 11 S. Wrede
javarmpath /usr/share/java/rstsandbox.jar
67 11 S. Wrede
javarmpath /usr/share/java/RSBJava-0.5.0.jar
68 11 S. Wrede
javarmpath /usr/share/java/protobuf.jar
69 1 S. Wrede
</pre>
70 7 S. Wrede
71 7 S. Wrede
This example code is available as Matlab functions in the RSB.m project here: https://code.cor-lab.org/projects/rsb/repository/show/trunk/matlab/matlab
72 6 S. Wrede
73 6 S. Wrede
h2. Older notes
74 1 S. Wrede
75 12 S. Wrede
Sending data from Matlab to RSB:
76 1 S. Wrede
77 1 S. Wrede
<pre>
78 1 S. Wrede
>> javaaddpath /vol/cit/share/java/RSBJava-0.4.0.jar
79 1 S. Wrede
>> javaaddpath /opt/local/share/java/protobuf.jar
80 1 S. Wrede
>> f = rsb.Factory.getInstance()
81 1 S. Wrede
 
82 1 S. Wrede
f =
83 1 S. Wrede
 
84 1 S. Wrede
rsb.Factory@5c4e0c39
85 1 S. Wrede
 
86 1 S. Wrede
>> s = Scope('/example/informer')
87 1 S. Wrede
 
88 1 S. Wrede
s =
89 1 S. Wrede
 
90 1 S. Wrede
/example/informer/
91 1 S. Wrede
92 2 S. Wrede
>> i = f.createInformer(s)
93 2 S. Wrede
No rsb.conf found in configuration directory '/Users/swrede/.config'
94 2 S. Wrede
No rsb.conf found in working directory '/Users/swrede/Documents/MATLAB'
95 2 S. Wrede
 
96 2 S. Wrede
i =
97 2 S. Wrede
 
98 2 S. Wrede
rsb.Informer@75222b8e
99 2 S. Wrede
100 2 S. Wrede
>> i.activate
101 2 S. Wrede
18.07.2011 18:21:22 rsb.Informer$InformerStateInactive activate
102 2 S. Wrede
INFO: Informer activated: [Scope:/example/informer/,Type:String]
103 2 S. Wrede
>> i.send('RSB')
104 2 S. Wrede
 
105 2 S. Wrede
ans =
106 2 S. Wrede
 
107 2 S. Wrede
Event[id=4145dcfd-aff7-45de-b00f-0c6c315f0ce7, scope=/example/informer/, type =String, metaData=MetaData[senderId = 4d619c1a-b516-4474-9eed-eb216546ff01, createTime = 1311006099963000, sendTime = 1311006099966000, receiveTime = 0, userTimes = {}, userInfos = {}]]
108 1 S. Wrede
</pre>