Wednesday, July 28, 2010

The user manual for the Tetrix mill

This should explain the main functions of the Mill.

The axis description is realized by applying the (machinery) “right hand rule”:
*positive x axis is from the left to the right
*positive y axis is from the front to the back
*positive z axis is from the bottom to the top

The hardware setup:
-the Tetrix controllers are plugged in at NXT port 1
-z axis motor is on the first controller
-x&y axes are on the second controller

On every axis we have a LEGO encoder
x: NXT port 2
y: NXT port 3
z: NXT port 4
x&y have additional Tetrix encoders.
The LEGO encoders are mainly for the safety-control.

Then on the software site we have also 2 different types of vis: the difference is between the encoder type (Lego or Tetrix).
At first, I only worked with the Lego encoders, because I wanted to spend less money as possible. But after a while, I wanted to find out if the mill would be working better with higher resolution encoders. The second cause to use Tetrix encoders was to use the constant speed mode on the Tetrix vis.
At the beginning, I measured the “power to speed curve” of the motors and approximate a mathematical curve to this curve. I was able to run the motors in a proportional way so that the motions are getting smoother. About this proportional controller you can read in an earlier post.
With the Tetrix encoders the speed control is easier to manage, because the vi has the constant speed mode with allowed you to run the motors at the exact speed you need.

With the Tetrix encoder you can run the motors in two different ways: distance move or read the encoder like the Lego encoders. The main problem of the distance vi is that the controller tries in alternating the directions to reach the real encoder positions until the watchdog (which one you can setup manually) cut the motors off. This is very annoying so I decided to write the vis like the Lego encoders.

After hitting several times the borders or the end of one axis, I wrote a safety program. This program allows the different axis only to run in a box of 4"x 4"x 2". This box is controlled by the Lego encoders, which are very good for this job, because you cannot reset them during the program. The program has to run if you want to move an axis; flags control this. You have to start each time at the initial position, which is at the left for side point on the desk and at the maximum height. On the front panel of the safety program is a back to initial position switch, hitting this button the mill goes back to the beginning point.
The border control switch is, if you have to run to a position, which is out of the safety box, you have to push this button; if not the safety program is running back to his initial position.


After running the safety program you can start the B-code or the manual move vi.
This program is similar to the G-code (CNC programming) only that it is written in a spreadsheet and not text-like.
You have 7 fields to fill in: x;y;z;r;a1;a2;power.
X,y and z are the different axis in the desired inch length; r is the radius (also in inch) of the desired circle and a1 and a2 are the begin and end angle if you want an arc.
All the axis have to be 0 if you want to draw an arc or a circle. A positive radius gives you the arc in clockwise direction and the negative radius in counterclockwise.

You can combine the different programs with "build an array" like you want. Here is an example of the program “draw a circle” and above CEEO. Don't forget to choose "concatenate Inputs" on the "build an array" vi.

With setting up the flag #1 the mill move back to the initial positions.

This is the movie of the program above.

Tuesday, July 27, 2010

Speed controlled circle

This is a speed-controlled circle which means that the speed of x and y are changed continuously, and so drawing a circle.
But convince yourself:



Wednesday, July 21, 2010

My Tetrix LIKE and DISLIKE list #2

This time I will focus on the Tetrix vis (software), because programming a Tetrix robot is a little trickier than a Lego one.

What are the basic issues on the Terix vis? (NEGATIVE)
1)first of all you have to find out that the Tetrix motors and servos have to be configured in a the Labview motor configurator. This is not difficult but you have to know it.
2)to use every Tetrix configuration (speed, distance) you need a encoder witch are expensive. Without the encoder you can run the motors only in the constant power mode.
3)with every program you write you have to pay attention on the watchdog and that could be very annoying.
4)if the connection (PC-NXT) breaks the motors are continuing the last command (until the watchdog stops them)
5)the "move a distance" vi is not my favorite one, it works pretty solid but the controller try to catch the exact encoder position what definitely not possible is, that makes the vi very slow because the controller tries it until the watchdog stops it. You can adjust the watchdog time direct on the vi but if you want to use the same configuration but 2 different length it is still very slow for one or the longer distance don't come until the end.


But there are still a few positive aspects on the Tetrix vis.
1)the vis are very complete, you can program a lot of things.
2)it's easy to run more motors at the same time and at different speeds (with arrays)
3)after working a while with the Tetrix vis you get used to use them correctly and it becomes as easy than the LEGO ones.


So all in all the vis are not perfect but they are useful and programmable but you have to work a little bit with them to know how to use them right, so don't be afraid....:)

Friday, July 9, 2010

Beach beast (like Theo Jansen's Strandbeest)

I'm really impressed by the "Strandbeests" which are living on dutch beaches, so I started to build one. Their "father" is Theo Jansen, please check his home page: www.strandbeest.com.

The biggest challenge was to find the right proportions between the joints and then to combine the legs to a whole robot.

The first movie shows that the beast can turn and restart walking in a synchronic manner.


The second movie shows that the beast can change his way to walk during his promenade.
The beast begins with 0 offset of the motors then it begins to change the walking mode:
1st beep: 90º motor offset
2nd beep: 180º motor offset
3rd beep: 360º motor offset



Following are the programs:
the walking mode





and the turning mode





-----------------------------------------------------------

Here is the new design of the beast:
and the Jansen mechanism: