All the news that's fit to assimilate
[ Home | Blogs | Events | Robots | Humans | Projects | About | Account ]Name: Brian Rudy
Member since: 2001-05-15 06:05:39
Last Login: 2006-07-22 06:40:38
Homepage: http://www.praecogito.com/~brudy/
Notes: I have built several robots, including microcontroller and PC-based critters (see my main robotics page for more details).
Clubs: I'm an active member of The Robotics Club of Yahoo (TRCY), and intermittently involved with the Home Brew Robotics Club (HBRC), and the San Francisco Robotics Society of America (SFRSA). Unfortunately, my busy schedule only permits occasional involvement with the latter two groups.
Background: I'm a hardware guy by education, but like to code as well. I am fluent in BASIC, VB, C, Java, Perl, and shell script and have worked with Pascal, C++, Javascript, HTML, 68HC11 and x86 ASM. I've been a Linux user since the 0.99pl10 kernel days, and use it on all of my PC-based robots.
Current Project: My latest robotics project is Zaza an autonomous mobile robot that wanders the exhibit halls of The Tech Museum of Innovation in San Jose, CA.
Hobbies: A few of my other hobbies are SCUBA diving, downhill skiing, home automation and gardening.
My new job demands a substantial amount of what had previously been my free time to work on robotics projects. But, that's life at a startup ;)
I haven't been able to put in much time working on the Blue Cube or Zaza in the last five months, but would very much like to get back to doing so.
I was able to spend a few hours at the Tech this weekend working on Zaza, but it appears her batteries are in need of replacement again, as the voltage never got much above 11.3V. It appears the maintenance technicians left the robot connected to the charger w/o having the the robot power on for a month or more. unfortunately the charger from RWI isn't smart enough to reduce the charge current proporionately, and managed to cook off a lot of the hydrogen in the gell cells. Oh well, there goes another $500...
The schematics (gEDA/gschem + additional custom symbols, PNG) and current firmware are here.
Oh dear, it appears Arthur T. Murray has found robots.net. If you have ever been curious who this guy really is, check out this FAQ assembled by Tristan Miller, I found it rather interesting.
Zaza
I managed to fix a logic bug in the Phase
IV (tourguide)
button handling code that hadn't been debouncing the buttons
properly during tours. It was a problem because kids like to
press the buttons on Zaza's acrylic hood (repeatedly), which
caused a bunch of voice cues listing the intended exhibit
destinations (or information on the current exhibit if the
robot had arrived at an exhibit) to stack up, sounding a bit
like a broken record :P
I also fixed a problem with the POE face client (interfaces remote Java face applets with the voice server) that would occasionally cause remote face applets to 'loose sync' and stop receiving new voice cues from the voiceServer.
During Phase IV testing over the last two weekends I noticed a problem with the voiceServer not rendering some voice cues that list the exhibit destinations during a tour. It looks like a race condition exists when there are more than one active (unvisited) goal that causes the cues to be sent to the voiceServer faster than it can handle them, causing the first of the cues to be dropped. This has compelled me to consider rewriting the voiceServer to use POE to manage the threading issues. I had a quick glance at David Huggins-Daines' POE::Component::Festival and it looks like it could be used in place of direct access to Festival::Client::Async for POE, but both the Perl module, and the 'synth-poe' example needed to be tweaked before they would work.
I stumbled across some new voices for Festival from CMU last week. The first (sample) uses 'cluster unit selection' which basically assembles a synthesized waveform from components of a database of pre-recorded, tagged speech. The results can very from fantastic to horrible, and takes far too long to render on existing hardware, eliminating the possibility of real-time synthesis. It's unlikely we will be using this one with Zaza. The second (sample) uses the same ARCTIC database, but is converted to diphones through HMM analysis. It has less inflection than the current voice (sample), but seems to be quite a bit more intelligible on Zaza's current audio hardware. Due to some differences in text analysis, using the slt_hts voice requires making some changes to both the face applet, and the voiceServer. I have already updated the face applet, and plan to do the same with the voiceServer this Friday.
Blue
Cube
I threw together some Makefiles, and updated the READMEs for
libnmc
and picservo-test to make the build process a little
easier.
I also started work on the CARMEN interface, but need to make some API decisions before progressing any further. I am planning to duplicate the critical interfaces used with the open-sourced version of the Nomadics Scout hardware interface library. This should make it easier to integrate with other robotics toolkits like Player/Stage.
After a great deal of waiting, Thomas Baier finally released a version of 3DWin that worked with a current version of Moray, allowing me to export my model of the Blue Cube that I made a few years ago to VRML. I also put up the hamaPatch model of one of the Blue Cube's 'quarter panels'. At some point I'll rebuild the model using this more accurate model with BlenderCAD.
I finally decided on i2c as the sensor bus, allowing relatively simple interfaces to sensor nodes like the SRF08. Since the Blue Cube's mainboard doesn't have a built-in i2c interface like the VIA EPIA M motherboards do, I needed to find another sufficiently fast means of interfacing with the i2c network. I had a look at dafyddwalters' OAP parallel port i2c interface, but the lack of proper isolation on the SCL line, and the nonlinearities of using transistors for switching concerned me. I found an old article by Simon G. Vogl that used a slightly better design and made a few modifications. The latest block diagram shows all of the current/planned systems on the robot.
I have an initial design for the power distribution board, but need to do some testing before building it. The circuit allows peripheral power to be controlled by the power management uC, as well as automatically switching to battery power when the external +24V dock supply is disconnected.
rudybrian certified others as follows:
Others have certified rudybrian as follows:
[ Certification disabled because you're not logged in. ]
Follow us on twitter
Become a fan on facebook
Subcribe to our RSS feed
Giant Dallas Robot Cited as Best Public Art
VEX Robotics World Championship Report
Robot Builders Forming Hackerspace in Dallas
There's More Than One Way to Skin a Robot
Polulu 3pi: the 10,000 Mile Review
Day of the Androids at Hanson Robotics
TGIMBOEJ for DIY Roboticists Launched!
Review: Scribbler Robot
Tank Tracks for Robots
Review: VIA EPIA M10000 Mini-ITX