Polarshield v1.4 ideas

The 2.2 inch screen that I use for the Polarshield is now unavailable, so I’m switching to the 2.4 inch screen instead.  Not much difference, but it does mean the PCB needs to be revisited so that it fits in the same footprint.  I only have a couple of the 2.2 inch panels left.

New sized screen for polargraph machines

The 2.4 inch screen has a higher resolution, so in principle it can fit more stuff on.  But in practice, I will keep the two designs aligned for as long as possible.

So I am planning to remove the XBee socket, and the hardware that goes with it.  I don’t think anybody uses it, and I’ll leave some pins open so that I can wire it up again in the future.

I would quite like to have space for a third stepper driver, for doing some like this lissograph drawing machine which I covet deeply.  If that happened it would be a mostly unpopulated blank, cos it’s a pretty niche idea.  It’s also true that a machine like that could easily fit into an arduino uno sized board, and there’s already plenty of multi-stepper shields out there to choose from.

Apart from that, I’m blank.  Does anybody have any feelings about the direction of the cables, locations of the sockets, or the types of connectors, things like that?  Drop me an email (sandy dot noble at gmail), or go on the forum.

Cheers!

Sandy

 

A flurry of activity

So you wait months for an update and then three come along at once:

Controller updated to v1.42

Main new feature is live drawing from webcam.  This is pretty cool actually, almost better than I expected.  There is a new tab in the controller, labelled CAMERA, and by default, it’ll show a vectorised version of your webcam’s live feed.  There are a couple of settings that simplify the raw video in order to make for faster drawings.

live-trace-example

It works by grayscaling, then posterising each frame, then performing a vector trace on each layer of colour.

The simplify control works  to remove complexity from the resulting vectors, and creates some amazing abstracted forms at higher levels.  Posterise controls how many different layers of colour the image is reduced to, and blur reduces the actual detail.

Hit capture to snap a frame, and get to see (to some extent) the drawing sequence too – darker lines are drawn first.   Cancel capture discards the snap and returns to the live feed.  Add caption doesn’t work yet! Oops!  Draw capture confirms the snap and converts it to commands, and packs them into the command queue.  It also saves the image as a SVG somewhere too, in case you need to repeat it.

The drawing is scaled to fit into the picture frame.  You know, the picture frame.  Everyone uses that, right?

Path length cutoff throws away paths below a certain number of points.  This was intended as a way of trying to filter out rubbish single point, or single line paths, but actually simplify works better.  The problem with the cutoff is that it counts points in the path rather than actual path length, so you could have a path that forms one whole edge of the snap, but it’d get thrown away because it only had two points in it.  Doesn’t make much sense.

Good fun, and good results, I took and gave away portraits all day at the Mini Maker Faire here in Edinburgh week before last, people seemed to like it.

On windows it can be a bit of a cow to get running, it requires the infernal Quicktime, and WinVDIG.

The Firmware updated v1.61 for Arduino MEGA based systems (aka Polarshield / PolargraphSD).

So, Accelstepper, the wonderful library that I use to control the stepper movements in Polargraph got a couple of fixes, unfortunately fixing bugs it looks like I was relying on!  So at least one person encountered issues using the new versions, and the main part of this update is to fix that.  Vector drawing works again, three cheers.

It was a bit of a weird problem (that I went into briefly on the forum), but while I was there I “fixed” a few other things, the main one being the spiral pixel drawing style (aka circular pixel)!  It is very working, very quick, and very handsome indeed.

Grace Kelly in spirals
It’s the first “polargraph” style new feature for a long time, and is now quick enough to actually experiment with.  Gorgeous.

The code no longer fits on an Arduino Duemilanove, and I think probably not on an Uno either, so I have not included any updates for polargraph_server_a1.

Pen lift height

The servo positions were hard-coded into the firmware previously, but not all servos are created equally, and what was logically a 90 degree move often only turned out to be a 45 degree move (or less!).  I have made the servo up and down positions settable and saveable.  There is a test lift range button on the setup tab of the controller, along with two number spinners to set up and down position.  The test lift range will wiggle to both extremes a couple of times.  Once you are happy with the range, press save lift range to load it to the non-volatile EEPROM on the machine.  Remember to test it with pen lift and pen drop on the input tab to make sure you’ve got them the right way around.  There might be some foibles around that.

Finally, re-upload your machine spec

Maybe you always do this anyway after loading new firmware, but the EEPROM addresses of the various values that get saved there has changed, so they’ll be all over the place.  So you need to upload machine spec after updating the firmware.

Speedy chat!

The serial comms handling on the arduino end is now significantly quicker.  Very good!

Oddness on the mega line

The version of firmware for the Arduino MEGA using the adafruit shield (polargraph_server_mega) is almost identical to the polarshield variety, but I was getting some really weird results when doing vector drawings on my little machine here last night. It was badly dropping or gaining steps.  It works fine on the polarshield machine, but on this one, with a adafruit motorshield, no dice.  I think it must be down to the speed that I was driving it at (too high), but I’d be interested to hear if anyone has success with it, or otherwise.  Drop me a line please.  Thanks!

Github

All the cool kids are using github now, so I am too.  The main code packages (polargraph_server_* and polargraphcontroller) are there at https://github.com/euphy. For the time being, the google code project will continue to be the official hub of the project though, but that might change.

Get the bundle at https://code.google.com/p/polargraph/downloads/list

 

Polargraphstamatic

Just a preview of the quality of scribbling that you will encounter if you stumble past the Polargraph stall at the Mini Maker Faire in Edinburgh next weekend.

New polargraph experiments

The portrait is created from a webcam video feed, is A5 sized, and takes about 10 or 15 minutes.  I’ve added functions to do that, and to control it with a wireless gamepad to the controller so you can stand back. I was going to do a whole page feed thing, but one thing didn’t lead to another (though I have a dismembered printer here as evidence of trying).

I’ve also been updating the github project rather than the google code SVN repo.  Still getting used to github.  Github for windows seldom works for me, but tortoisegit is doing ok.  This project now requires JMyron, Diewald CV kit and Procontroll as dependencies.

The other drawing on that image is an export of an image created with Abel Dewitz’s beautiful Silk Blossom processing sketch.  I would love to have something like that algorithm built in as a polargraph roving feature.

Hanging-V myths, or I’m not very good at geometry

Well, I am stupid.

Martian Sharpie polargraph

When I designed the first polargraph gondola (above) I thought I was being clever by making the gondola arms (the cords) pivot around a central axis. So this is what I did:

hanging-v-fig1There’s no room for error.  The physical machine reflects the mathematical model.  Sure it’d be much easier to make the cords pivot from points just outside the pen itself.  Easier to design, easier to build, and cheaper, far, far cheaper.  But surely, says I, to do that would end in madness! Dogs and cats living together indeed!:

hanging-v-fig2

 

I mean! How could anyone accept that.  The distance from the notional tip of the hanging triangle and the actual pen itself changes constantly!  Puny humans!

Well, I knew that couldn’t really be true, otherwise how come those gondolas didn’t exhibit hideous geometric distortions?  Like when I used Stuart Childs’s gondola on the Spectrum Arts window?  Ah, don’t think about that, revel in your technical superiority with your elegant radially symmetrical design.  It must have been some weird abberation to do with the size of the surface.  Well done lad.

And maybe just think for a moment, or better still, draw some diagrams to prove the theory:

hanging-v-fig3

 

Aw nuts.  The offset arms fallacy (as I’m calling it) relies on a deeply brainless piece of thinking.  The idea that the hanging triangle always exists, but that the gondola is somehow squeezed up the cords until it finds equilibrium, suspended in that V (fig 2).  As fig 3 shows, that’s cart-before-horse stuff.

AHA, but I still have you! The gondola won’t hang straight all the time – as it traverses the surface, its orientation will change.  It’ll be all over the place! HA!

hanging-v-fig4

 

Double nuts.  BUT, well.  Ha, you thought you had me.  Well, what happens when you’ve got one swing arm joint slightly looser than the other?  Now that’s dangerous territory.

hanging-v-fig5

 

Ok, that’s the worst case I can think up.  With an offset swing-arm design, for any given pair of cord lengths, the actual position of the axis could be off by half the intra-arm-pivot distance.

So forgive me.  This was prompted by Makerblock’s lucid response to my childish chest-beating on his blog.  I don’t know why it took me so long to actually figure this out.

The reason it took so long to figure this out:

Well, the reason this fallacy stuck so long in my head is that I was thinking badly.  I worked on the basis that the machine knows the shape of the triangle.  Therefore it knows the angles of the sides, and the positions of the intersections.   But of course it doesn’t.  All it knows is the length of the sides, and it’s got to figure the rest out from that.

If it somehow knew the angles of the hanging strings, then my misconception would be entirely apt.  It would entirely miscalculate the position of the gondola, based on where it thought the tip of the triangle way.  So it does make sense, after a fashion.

This is an interesting case that illustrates one of the problem with the kind of naive (or isolated) engineering that I do.  It provides the opportunity to simplify things, and get by on “just good enough to work”, but also tolerates faulty thinking (for better or for worse), and if anything gets built on top of faulty thinking, that can end up messy.

I’m still not changing it though.  Central axis FTW!

 

Assemble your own Polarshield.

I’m not sure how many more of these polarshields I’ll be making, I’ve got nine left that I’ve just soldered up, and need a couple for my stand at the Edinburgh Mini Maker Faire at the beginning of April.

nine polarshields, SMT'd

Amazingly, that means I’ve made up and sent out 70 (SEVENTY!!!) Polarshields! Almost exactly half polarshield vitamin kits, and half PolargraphSD full machines.  It’s so weird!

In case I never order up another batch of PCBs, I’ve made a couple of videos that show the technical build process, soldering etc.  They are long, and very very boring.

Soldering:

Testing:

Making cables:

What about that?!

The wonder of a sharp blade and the right tool for the job

When I use my array of scalpels and box cutters, they get blunt.  I don’t notice so much, but slowly, I’m applying more pressure to get the same cut done, I’m tolerating sub optimal performance.

It’s such a good feeling when I put a new blade in, cutting like butter, and every time I do (every time) I reflect that I mustn’t leave it so long next time – the benefits of having the right tool for the job outweighs any notional benefit of being a cheapskate.

As with soldering.  I can do the surface mount stuff easily and quickly en masse, but I dread the through-hole stuff, the pin headers and sockets.  It just seems to take forever, and is a battle.

I looked at the iron tip, which has slowly been getting narrower and narrower.  It was initially thin to do 0804-scale surface mount soldering, but I now use hot air for that.  It’s no longer the right tool for the job, and it’s terrible corrosion makes it even worse.  I looked for a replacement, but remembered I had got a multipack of tips last time, containing a mixture of sizes.  Grumbling, I put the next smallest one I had on, and after the first joint, wished I’d done it months ago.

soldering iron tips

Bigger tip = more heat = quicker joints.  Obvious.

As an amateur, economy plays a large part in my reluctance to snap off a blade segment, or unwrap a new blade, and also storage and access (trying to remember where I put the spares months ago).

As a professional (which I suppose I am) I have to balance cost with speed and quality.  And as an employer (employing myself albeit) I have to balance cost with quality of life.

Right tool for the job.

Assembly notes for Polarshield

The location of the motor terminals on the polarshield is a bit awkward.  One of them is fine, but the other is directly above the USB socket on the arduino board underneath.  So that’s fine for the PolargraphSDs I make because they use arduino boards with micro-USB connectors.

But for anything else, the pins from the connector will come into the contact with the big USB-B shell on the arduino below, and that’ll short, and that’s not cool.  I always almost always do the following to a Polarshield to get around it:

P1040642

First snip off the protruding pins and file then down almost flat.  I make extra sure there plenty of solder lining the holes for these ones.

P1040646

Stick a couple of pieces of electrical tape over the little nubs that are left.

P1040647So now it fits flush, that’s good.

I saw this mentioned on Julio Terra’s blog where he mentioned putting a bit of tape over the USB shell to insulate it.  I scratched my head because I always do the above operation for the polarshields I sell as part of vitamin kits.  Except obviously I missed this one!  Tsk! I know, shameful.

Close up on the Polarshield

I haven’t really explained anything about how the polarshield works, except that it does.

Polarshield with headers annotated

Having a close look, you’ll notice there are very few active components.  The Polarshield is largely just an interface board that lets a bunch of regular-shaped things plug into an arduino, so it’s mostly pin headers and passives.

The XBee port switch (top left, next to the servo pins) bears a mention:  The up (or right, in this pic) position disconnects the XBee port and allows programming and comms via the USB port.  Switching down (left in this pic) connects the XBee port that allows serial comms from that module.  If there is an XBee plugged in then having it switched in prevents reprogramming via the USB.

I’ve detailed the connectors on here too, most interestingly (I bet) is the END STOP connectors.  These are input pins for four switches that would be used as limit switches for self-calibration, or for emergency stops.  The code doesn’t really use them yet, but it will soon, I’m working on it!

The good news is, those pins are available on all polarshields, so it’ll be pretty easy to add retrofit the self-calibration / limit switches to any vintage of board.

Black Stripes

Kongorilla let me know about this great new bot, or rather a great new service / business – it’s a Dutch company called Black Stripes, who offer a poster / drawing production service that offers a very handsome web-based input and preview system (go to “shop”) and output the artwork using a very covetable hanging-v plotter machine

 

Beautiful results and a really nice, industrial-quality setup.  Big steppers, big drivers.  They seem to be using a Raspberry Pi + arduino combo with discrete CNC style stepper drivers, and toothed belts for suspension.  A solenoid raised or lowers the pen.

It’s great to see an actual product based on this process, and some degree of automation going on too, in the image upload process.  I like best that the form of the output, the direction of the lines is a succinct expression of the form of the machine – the drawings could only come out of a machine like this, and the angles at the intersections and the and centre points of the arcs are all fingerprints tied to this particular machine too.

They have their counterweights running on little tracks too!  That’s a good idea.