Dane.Kouttron

[1.3.20]  Rover Test Platform V2: More Sensors & Bigger Wheels

In early 2019 I put together a rover test platform, lovingly called 'testbot'. It was a quick and simple 2-motor tank-drive rover for testing GPS and navigation

Unfortunatley it lacked a bit in the mechanical department, as it consisted of two wheelchair motors and some 3d printed solid wheel mounts. Continue below for some details on the build of Testbot 2 and some experiments with sensors, and obstacle avoidance. 


What?
Out
Cl Time for Paint Brushless Motor Mounting First Test Testing Notes Conclusion Image Directory

Mechanical Bits and assemblies
This really started with some free wheels. Sibling Chris had these left over from some tractor contraption. They are quite huge but also the right price, free. These tires are tubed and have a bushing to mate to a 3/4 axle. Initially I was heasitant to continue using bushings, but these did have built in grease fittings where the grease would insert from a cavity inside the two bushings. Theoretically as long as these are greased before tests it should be fine as the actual velocity is quite slow. Two more tires + rims of the same size listed used were ~50$, so I grabbed them for a 4 wheeled tank-steer rover. 
Why bigger tires?
I had a few comical issues with the solid tire+printed wheel mount last year. The lack of clearance resulted in tesbot v1 really only working on dry pavement, and finally when it ran into a curb due to a sensor error, it was extremely good at shearing the wheel mounts off. For whatever reason, last year I didnt try and make a shaft adapter, but opted to use the 5-point bolt mount and translate that over to a bolt to act as a secondary drive shaft. Either way its fairly visible how large these tires are in comparison. Finally because I was going to opt for more clearance the same wheelchair motors will be mounted well into the chassis.
The whole chassis was quickly sketched up in soldworks, and to make things 'fast' to assemble, i opted for a plate-waterjet topology. This would use some scrap aluminum and steel plates and simple t-nut style fastening, along with some eaisly available mc-master-ables.
I was lucky enough to get some time on the N51 OMAX, and aside from some flubs, cut out most of the parts for this little beast. Note that the wheels are front-tires for a lawn tractor so they dont particularly have a place to mechanically couple torque. To sort out this issue I opted for adding in ~1/8" steel cut-outs, attached with a few weld points. Three threaded holes around a central shaft cutout would be used to transfer torque from a pulley to the wheel.
Waterjet, oh waterjet solve all of my problems please
At some point in this process i found the paint-removal pre-welding a bit of a bother. Fortunatley the tire (de-flated) fits nicely inside the MITERS lathe. I used a 'sandpaper on a stick' tool to quickly de-paint the inside of the rim assembly to prep for weld. As shown a bunch of table-clamps are used to keep the tire seperated from the rim to limit any hot contact between the steel and the rubber.
How do you remove these things?

de-beading small solid rim (non-split) tires is quite a pain. This is nothing like bicycle tires, so i opted for 'quick low thermal' tig welding to fixture the torque transfer plate to the rim. Seriously its quite a bit of effort to replace these things without specalized tooling. 
How do you make sure this thing is centered?
Excellent question, as making the mounting plate offset would result in uneven belt tension, and as i was initially hoping for not having a tensioner, it helps if everything stays co-ordial. As i was using a proper ground shaft, i designed the wheel adapter to take in a 3/4" bronze bushing, which when situated between the shaft and pressed into the adapter plate would make sure the wheel bushings were co-ordial with the transfer plate. This was left installed during welding to ensure concentridicty. To prevent weld splatter from ruining the shaft, I covered it with masking tape, which did a reasonable job of keeping the shaft clean.
Now repeat that three more times.
It was actually hard to not fully weld the mating surface as i'm so used to not leaving just tack welds on projects. To make sure everything was actually working I did a quick sink test. With the tire fully submerged and held down with a hand I checked for bubbles. I was incredibly surprised that the whole welding and smushing process showed no leaks. Unfortunatley I had just taken bare steel and covered it immediatley in water, which is a wonderful way to have rusty wheels. The bushings also probably didnt benefit much from being submerged.
Now onto the frame.
To make my assembly easier I opted for a (mostly) captured nut and 4-40 screws to assemble the sides. How does this work you ask? the puzzle shaped 1/4" thick aluminum cut out fits into matching square holes in either plate, then a t-shaped cut out fits a 4-40 square nut. A recessed 4-40 screw constrains the assembly in all 3 directions and is great for quick mounting. The big benefit to this is not having to drill and tap holes as the steel nut has more holding force than the equivalent depth tapped aluminum hole.
Comically i did not have any spare 1/4" plate so i opted for using 1/8" thick plate as the base / wheelchair motor mounts and added a 1/4" stiffener plate to the underside. This nominally acts as a spine and prevents the whole assembly from being flexible about the middle. Shown is the swiss-cheese top plate with large holes for each wheelchair motor mount along with the small 4-40 screws bolted into the 1/4" tapped stiffener plate.
Here's an up-close shot of this assembly. Nominally this works well for an arbitrairy plate thickness, assuming an associated square-nut exists. I was a little wary with the holding force of just 4-40 screws, so i opted to just use this as jigs for holding the frame together and weld the square cutouts to ensure the rover didn not 'rapidly disassemble' during roving. Before welding I opted to mount the wheelchair motor temporairally to ensure everything fit. Its fairly comical how much heavier the motor assemblies are versus the frame, but i was opting for 'low speed & light weightish' over 'giant steel box-frame thing'
Lets weld

Tig welding 1/8 to 1/4" aluminum is not terrible, as each material has a different thermal mass, its important to pre-heat a bit before going to town with the tig torch. I generally opt for running the torch at 20-30A with the arc running and dance it around the area that will be welded. This has the added bonus of heating and slightly cleaning the area in question. If there is signficant surface contamination the torch will tell you. With the surface warmed up its also way easier  to start welding. In this case i started with the 1/4" insert cutout and worked my way to the 1/8" plate.
With the frame now one giant aluminum assembly, its time to cleanup and try and prevent those tires from rusting immediatley.

A clean welding bench is a happy welding bench :]  Special thanks to DLAB jack for such a wonderful welding space.
Lets prime and weld up some wheels. To prevent the tires from getting covered in primer and paint, I used some recycled printouts and tape to make a mask around the area to be painted. Tape was applied to prevent the valvestem and center bushing from getting paint debris. I started with two coats of zinc based primer, and managed to find enough space to paint all four tires during the same evening.
After 2 hours of setup, i finished with a coat of what was supposed to be matte black, and let them dry in a warm server room overnight.
I used the evening to print out a few wheel-timing-belt adapters.
These are 3d printed parts that transfer motor torque from the wheelchair motor to each wheel. Force is coupled through three 1/4-20 flat socket head cap screws. The prints were intentionaly dense as i was hoping to not run into issues with these failing under duress.
Time to tap some holes.
As was hopefully visible earlier, each wheel-hub adapter plate had three small centering holes, each of which needs to be drilled out and tapped to accept the adapters. As the drilling process was mostly a 'setup the drill press and go to town' the tapping was a bit slower. With the wheels tapped, it was now time to test out the timing belt adapters.
With the pulleys printed i removed associated support material and added the three 1/4-20 screws. Note that for the sake of testing I did not
At this point i noticed that while both of these tires were the same 'size' the footprint was significantly different. The newer style were a bit more 'round' while the aged, slightly dried out tires had a more square footprint. This nominally didnt change things much but it did result in some double-checking of dimensions. Its a bit visible on the lower angle shots.
Oh yeah, the wheelchair motor pulley adapters.
This was a peculiar one, I want to transfer force to two seperate pulleys, but also not spend 70$ per pulley on sdp-si. Behold these dorky things. Its actually a shaft-collar that transfers force to the 3d printed pulleys via two threaded 1/4-20 socket head cap screws. My logic was the shaft collar can grab the shaft and then transfer all the force to the 3d printed pulley. Comically the shaft collar didnt quite tighen down enough to grab the shaft, so i had to use a shim. 
I wasnt totally happy about a shim being the main thing that was transfering force from the motor to the wheels, along with the fact that i wasnt taking advantage of the existing keyway. It was a good first test part though and wasnt terribly difficult to improve.

VIDEO OF SANDING PROCESS:


Careful Welding

Some Bracket updates
As it turned out the tension to the front pulleys wasnt sufficient and the longer belt drive had a tendency to skip. To sort this, I drew up a trigangular brace.
Off to the big-jet as the hobbyshop jet was still asleep for the holiday break. Note the support hardware consists of brackets, as well as improvements for the drive pulley. Note that as these are smaller parts tabs are used to help keep the parts secure to the stock plate. If the tabs break the parts can fall out into the machine bed.
Fit wasnt amazing but after a bit of filing and hammering, the brackets were together.
I used a different TIG setup than usual and had some mixed results but ended up with two sets of front and center brakcets. These solve two issues actually, the u-clamps used to hold the two solid axles in place ended up bending the 1/8" plate that was used on the front and back of the rover. These are 1/4" and help provide a linkage point between the drive pulley and the wheel pulleys.
Some other upgrades were the 'universal sensor mount' plate, which was just a bunch of 1/4-20 holes that would pickup existing 4-40 screws. To make the process easier, i undersized the holes with the hobbyshop jet, then drilled & power tapped them for 1/4-20.



Thoughts on Sensors
Going to get a little in the weeds here, outdoor obstacle avoidance is pretty bad in the snow. For optical systems (stereo vision) glare is a killer. IR projector based setups are not viable, as they have to compete with the sun on a very IR reflective surface (white). Lets do some analysis here and see what options are available on the visual side of the fence. Not having to fully diy from scratch would be nice, but nominally I'm still cost constrained so the $10k SICK module isnt going to work well.
What are my goals?
Good question, i'm starting with a fairly basic 'avoid driving into a tree/person/car'. I have no intention of running hyper-complex blade server computation either on-robot or remotely, as nominally im more or less after a sonar plot of whats ahead of me / behind me.
Stereo Vision based sensors
Some background:
A great paper on the subject of Stereo Vision in artic applications is detailed in this paper In the Dead of Winter: ChallengingVision-Based Path Followingin Extreme Conditions [online]  [local link]. Lets make some notes about issues and suggested solutions.
  • A test vehicle [Multi-Agent Tacti-cal Sentry] struggled to do autonomous navigagation, up in Nunavut,Canada. Nominally this paper does dive into using vision for position estimation along with obstacle avoidance, so i'm going to target areas around obstacle path prediction.

#freeform_thought:
can you benefit from more than 2 cameras? It looks like one of the issues in early vision is the generation of keypoints. Can you cheat and just have a focal length depenant array? (i'm imagining a lens that adjusts focal length? This seems like a Shack–Hartmann wavefront sensor thing right? Have 'n' images of variying focal length? Can the old lytros be used? [link] performance evaulation pdf.

Maybe its just easier to have a spinning warning light thats very directional and just use the differential light for a scan. Its cheating but also simple and double functional. Could choose an visible source and just use filtered optics to do depth matching. (imagine a simple rotating like 1hz led thats fairly beam-formed. What frequencies work well for snow reflection?  Nominally this only really needs to work front-facing. It could be infared?

are there seriously no ultrasonic contraptions?  checkout [link]

interesting list of sensors @ ROS [link]
One of the heavy hitters in this realm is Intel. Their realsense department seems to be actually trying and as such there are a few of stereo vision obstacle avoidance sensors. Unfortunatley their website is fairly bad at providing useful metrics about each model, so i'm going to summarize below my findings.
D435
This is
D415
what the heck is active IR
Some thoughts on vision:
Having a clear visual path from the visual sensors along with adequate lighting is fairly improtant, even moreso given the reliance on vision. I should look into better lighting. Lighting may actually be required for a majority of the day due to the immense affect of the lighting of low sun.
Radar Land
TOF sensors
Holdon, is there a phased-array sonar-plot possibility?

Really Dorky Servo Eyes. 
This is un-related to testbot but, I did have some smaller sized led lights from last year and it would be a bit comical if the eyes indicated the direction the robot was about to turn.
Shown (right) is the 2019 googley eye headlight (8") vs a smaller light fixture (6").
I really liked the two led retrofit high-lights from last year. For some backstory, the actual headlights are a very thin led strip that illuminates a reflector disk which provides a fairly equally illumiated surface. My only qualm with the previous year was how 'warm' in color they were, which generally confused the camera quite effectivley.
Given that I knew how well these worked i had some thoughts. It would be kinda nifty to go for a blue-er white, which may photograph better. Adding a second set of leds in the strip as well (red) would also be fairly interesting, as it could add a jokingly terminator mode. Nominally the headlight brightness driver takes in an RC signal and a 24v battery feed, then interpolates the RC signal such that different positions on the controller potentiometer equate to different brightness's. As such end-of-range can be set to be red, while the controller pot can scale the brightness otherwise. Grabbing servo feed from the propulsion ppm could also be used to set the eye servo position.

Sevcon Details
I'm honestly not sure if these files can be posted publicly, but, nominally these were scrapped from MIT, so may as well make some details available. 


N


S


(There's other photos in the photo gallery)
Concluding Remarks:
From the sponsors:


If you have questions or comments, ask below or send over an email.
Comments:
HTML Comment Box is loading comments...

Stay safe when working with electrons in aqueous / semi-aqueous environments. Also wear sunscreen, I'm not responsible for your newly aquired winter-farmers tan : ]

Dane.Kouttron
Rensselaer Polytechnic Institute 
Electrical & Electrical Power
631.978.1650