Robobuilder
(Difference between revisions)
m (→Ruby Examples) |
m (→Using the RBC controller) |
||
Line 10: | Line 10: | ||
=Ruby Examples= | =Ruby Examples= | ||
==Using the RBC controller== | ==Using the RBC controller== | ||
− | [[Image:New.gif]] You can download the Ruby-extension for controlling the Robobuilder here: [http://vision.eng.shu.ac.uk/jan/robobuilder-0. | + | [[Image:New.gif]] You can download the Ruby-extension for controlling the Robobuilder here: [http://vision.eng.shu.ac.uk/jan/robobuilder-0.2.tar.bz2 robobuilder-0.2.tar.bz2] |
Here is a small example program which makes the robot get up if it's lying on its back or its front. | Here is a small example program which makes the robot get up if it's lying on its back or its front. | ||
Line 22: | Line 22: | ||
end | end | ||
end | end | ||
− | robot = Robobuilder.new '/dev/ | + | robot = Robobuilder.new '/dev/ttyUSB0' |
puts "Robobuilder" | puts "Robobuilder" | ||
puts "Serial number: #{robot.serial_number}" | puts "Serial number: #{robot.serial_number}" |
Revision as of 15:53, 2 October 2009
Contents |
Gallery
Ruby Examples
Using the RBC controller
You can download the Ruby-extension for controlling the Robobuilder here: robobuilder-0.2.tar.bz2
Here is a small example program which makes the robot get up if it's lying on its back or its front.
#!/usr/bin/env ruby require 'robobuilder' require 'matrix' class Vector def norm Math.sqrt inner_product( self ) end end robot = Robobuilder.new '/dev/ttyUSB0' puts "Robobuilder" puts "Serial number: #{robot.serial_number}" acceleration = Vector[ *robot.accelerometer ] if acceleration.inner_product( Vector[ 0, 0, 1 ] ) > acceleration.norm / 2 robot.basic robot.a elsif acceleration.inner_product( Vector[ 0, 0, 1 ] ) < -acceleration.norm / 2 robot.basic robot.b end acceleration = Vector[ *robot.accelerometer ] if acceleration.inner_product( Vector[ 0, 1, 0 ] ) > acceleration.norm / 2 robot.run 1 end robot.close
External Links
- Robobuilder Ltd. (Korean manufacturer)
- Robosavvy (UK distributor)