Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Doesn't balance well... What's the wheel size? #8

Open
pipothy opened this issue Jun 28, 2017 · 57 comments
Open

Doesn't balance well... What's the wheel size? #8

pipothy opened this issue Jun 28, 2017 · 57 comments

Comments

@pipothy
Copy link

pipothy commented Jun 28, 2017

Just ran it on my EV3 and unfortunately it doesn't seem to balance well.

Trying to find out why, I think the wheel sizes may be different? Are you aware of what size wheels are needed for this program to work? I am using the ones that came with my EV3 Education kit, but they look different to those pictured in the link given. If the wheels are different sizes, that's probably the issue!

@laurensvalk
Copy link
Owner

laurensvalk commented Jun 30, 2017

I'm using the wheels that come with the EV3 31313 kit. They're 43 mm in diameter.

You could also retune the feedback gains to make it work with your wheels.

But perhaps a first attempt --- which amount to changing the gains all at once rather than individually:

Just before applying it to the motors, try scaling the duty cycle like this:

motorDutyCycle * 43 / D

D is your diameter, in milimeters.

@laurensvalk
Copy link
Owner

laurensvalk commented Jun 30, 2017

Those wheels are in the Education Expansion kit too, in case you have it.

@pipothy
Copy link
Author

pipothy commented Jun 30, 2017

Hi,

Thanks a lot. I don't have the education expansion kit. I tried retuning them myself but it rarely lasts longer than 30 seconds. Is that expected?

I'll try scaling the duty cycle and let you know!

@laurensvalk
Copy link
Owner

You mean it falls down within 30 seconds? Once tuned well, it should balance until the batteries run out.

Given that yours already "almost balances", you have a nice starting point for tuning. It's harder if it doesn't balance at all to begin with.

@pipothy
Copy link
Author

pipothy commented Jun 30, 2017

Hi,

Unfortunately, scaling it didn't seem to do the trick, still falls over within 30 seconds.

I've ordered some new wheels, I'll see if before then I can find some good changes to the values that allow it to balance with the 56 wheels, and can post them here for other people.

@laurensvalk
Copy link
Owner

It certainly can be done with the bigger wheels as well, [see, for example, the old version of this code for GyroBoy] but tuning can take a while.

I've also found that the EV3-G code gives very reproducible results, allowing many people to get it to work without tuning at all. The Python version isn't as robust somehow, which seems largely related to the variability of the loop time, which varies greatly especially when the kernel decides to do something important.

@pipothy
Copy link
Author

pipothy commented Jul 25, 2017

Hi, sorry for the long delay.

No luck it seems. I've got the wheels that are included in the normal kit and they don't work. Can you just confirm that you did this using the 30.4mm diameter wheel with 43.2mm diameter tyre? EDIT: (Scratch that, you've already confirmed that above). I've tried lots of tricks with nothing getting better results, only worse. I played with the accumulated motor error gain and that improved things marginally but nowhere near the results one would expect.

Are you supposed to initialise the robot with the angular sensor pointing straight up (i.e. the robot at a completely straight position) or at the robot's balance point? I've tried both, but it could perhaps be that the robot is built slightly differently to the one in the tutorial? Even then, I can't see why small changes to the body would make a noticeable difference.

Beyond the wheel size being wrong, I can only think some of the parts are faulty? I can test for that but I'd be surprised if the motors are below functional. The battery is fully charged so it's not lacking in power.

Exactly how do you instantiate the robot? Perhaps I am doing something wrong there.

@laurensvalk
Copy link
Owner

Are you supposed to initialise the robot with the angular sensor pointing straight up (i.e. the robot at a completely straight position) or at the robot's balance point?

The robot's balance point is preferred. (A slight deviation shouldn't matter, but that's your best bet.)

could perhaps be that the robot is built slightly differently to the one in the tutorial?

Could you share a picture of your design? You can just drag/drop it into one of these comments.

Are you using 6xAA batteries or are you using the rechargeable battery? Either should be fine, but maybe my Python code isn't as robust as my EV3-G code. Could you perhaps try that code?

You'll also find some instructions how to start the robot there.

@pipothy
Copy link
Author

pipothy commented Jul 27, 2017

Hi, just ran the EV3-G code (Balancer basic) and it was fine. Hard to instantiate and quite fragile to if it was started even a bit off the balance point, but when it was, it worked very well. No random jerking or falling over.

As such, it's unlikely to be any of the parts being broken (motor/sensors) or the build being substantially different.

Any idea why Python might be playing up like that? All I did was download segway.py, change the input ports to the ones I am using and then ran it. Could it be that? I'll give it a shot changing Gyro back to 2. It could be that something doesn't like the gyro sensor being in another port, possibly...

Any other suggestions?

@pipothy
Copy link
Author

pipothy commented Jul 27, 2017

Just tried changing it back to port 2 and it helped, but it still doesn't last long.

It's fine at the start, but starts oscillating quite quickly, and eventually this topples it over... implying maybe some kind of integral or predictive term is building up in the code?

Want me to send you a video of it so you can see what I am on about? Any ideas what might be causing this?

@laurensvalk
Copy link
Owner

Hi, just ran the EV3-G code (Balancer basic) and it was fine. (...) As such, it's unlikely to be any of the parts being broken (motor/sensors) or the build being substantially different.

Good to know!

Any idea why Python might be playing up like that?

I haven't tried my code on the latest ev3dev build. I do know that the run speed of a Python program can change performance drastically. I'm wondering if any recent kernel changes are making any significant differences here. I'd have to retry with the latest version, but I'm not sure when I'll be able to do this.

All I did was download segway.py, change the input ports to the ones I am using and then ran it. Could it be that?

The ports shouldn't matter. However, when you unplug and plug the sensor back in, even in the same port, it resets itself, so that might explain why the response looked a little different.

It also helps to keep the sensor still when you plug the sensor (or when you boot the EV3). It doesn't have to be vertical, just stationary. But since you've had it working with the other code, this shouldn't be the cause.

@pipothy
Copy link
Author

pipothy commented Jul 27, 2017

I'll try play around. Unsure if I can jump back to an earlier EV3Dev build, but would be keen to know if the current one messes it up. When you eventually get time to try it, let me know. I'd be grateful!

@laurensvalk
Copy link
Owner

Some findings with regards to ev3dev loop times are here.

That was C++ rather than Python, but I can imagine similar things happening (Likely worse).

On the other hand, the LEGO byte code interpreter also runs on Linux, so absolute speed should not be the issue.

The main developer of ev3dev is also working on a version of the LEGO interpreter. In essence, it lets you run EV3-G code on top of ev3dev. It would be interesting to run the EV3-G segway code with that.

@pipothy
Copy link
Author

pipothy commented Jul 27, 2017

Hi,

Interesting read! Any idea where I can find a date estimate on the LEGO interpreter being released?

I'm unsure if it is the loop time, the oscillations seem quite consistent. I'll give it some more runs and get back to you, I'll try dig to find out what it is.

@laurensvalk
Copy link
Owner

It's already available for testing.

If you install the latest ev3dev-stretch image from here using the normal procedure, you can try out the interpreter by following the steps in the readme of this repository to activate it.

@pipothy
Copy link
Author

pipothy commented Jul 31, 2017

It was incredibly slow... Not sure if this was just the specific environment with the lms2012 addition, or it is indeed indicative of Python being much slower as a result of something they've recently added to EV3Dev. I assume you've found it to be slower on their lego interpreter version too?

As such, I'm unsure where to go from here and how to fix the code to be more responsive.

@laurensvalk
Copy link
Owner

I hadn't tried the segway code on the lms2012 addition myself yet. It looks like you've found that that's too slow. Sorry about that.

I will let you know in this thread when I've tried the Segway again with the most recent version of the Python code and the most recent ev3dev build.

@pipothy
Copy link
Author

pipothy commented Aug 4, 2017

Great, thanks :) Do you have any idea how long in the future that might be? Doing some work with the robot so could do with planning other projects to fit in in the mean time!

@laurensvalk
Copy link
Owner

laurensvalk commented Aug 4, 2017

Practically speaking, due to current deadlines and upcoming holidays, hopefully the end of september.

By all means, go ahead and build some other robots in the mean time :)

@pipothy
Copy link
Author

pipothy commented Sep 21, 2017

Hi there! Just a bump to remind about looking into this!

@laurensvalk
Copy link
Owner

Thanks for the reminder :)

Not sure it should make any difference, but would you mind checking which sensor hardware revision you have? See slides 6, 7, 8 of this document.

@laurensvalk
Copy link
Owner

I've been updating the code. Looks a bit different now, but the controller is still the same.

Running the program and tuning should be much easier now.

I've done some preliminary tuning, but it isn't quite there yet.

@laurensvalk
Copy link
Owner

I've tuned it for a robot that's pretty close to BALANC3R's design. There is now also some scaling for battery level, which might help.

Curious to hear how this works for you.

@pipothy
Copy link
Author

pipothy commented Sep 24, 2017

Hi,

I own 38N4.

I'll give it a run tomorrow and let you know! Do you know what exactly changed in this code and the previous edition?

@laurensvalk
Copy link
Owner

laurensvalk commented Sep 24, 2017 via email

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Hi there,

Invalid Syntax on Line 26 of segway.py at the *args
print(*args, file=sys.stderr, **kwargs)

Am I missing something? Read the readme, seemed to be identical to before. Anything differently to running the code?

@laurensvalk
Copy link
Owner

Are you running the latest ev3dev stretch from 2017 sept 14?

@laurensvalk
Copy link
Owner

Also, how are you currently starting the program?

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Yep, latest stretch.

And I transferred the files over, SSH'd in, chmod the segway.py file then ran python segway.py.

I don't need to do python3 segway.py do I? Dumb question maybe?

@laurensvalk
Copy link
Owner

laurensvalk commented Sep 26, 2017

then ran python segway.py.

That means you ran the code as Python 2, which explains the error.

You can either do:

python3 segway.py

Or simply

./segway.py

Because of the first line in the file (#!/usr/bin/env python3), the latter command will automatically select Python 3 for you.

@laurensvalk
Copy link
Owner

laurensvalk commented Sep 26, 2017

There is also a neat VS Code extension for ev3dev. A nice IDE with easy transferring files to the EV3 and running them.

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Traceback (most recent call last):
File "segway.py", line 63, in
irRemote.mode = irRemote.MODE_IR_REMOTE
File "/usr/lib/python3/dist-packages/ev3dev/core.py", line 1711, in mode
self._mode = self.set_attr_string(self._mode, 'mode', value)
File "/usr/lib/python3/dist-packages/ev3dev/core.py", line 224, in set_attr_string
return self._set_attribute(attribute, name, value)
File "/usr/lib/python3/dist-packages/ev3dev/core.py", line 211, in _set_attribute
raise Exception('Device is not connected')
Exception: Device is not connected

Any idea on this one? Sorry for all the bothering!

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Just found your thread about an IDE, can't seem to find the actual VS code extension, mind throwing me a link to it?

@laurensvalk
Copy link
Owner

Any idea on this one?

Just to help you debug this a little:

irRemote.mode = irRemote.MODE_IR_REMOTE
...
Exception: Device is not connected

Any thoughts on what that might imply? Sometimes error messages really are helpful :)

@laurensvalk
Copy link
Owner

actual VS code extension, mind throwing me a link to it?

I linked to it in my previous comment.

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Sorry, I am being very slow! I'm rather unwell today so thanks for your patience.

I checked and all the sensors are connected. The connection to the robot is fine, and an internet connection isn't needed. As such, I had no further ideas.

I clicked every word in your comment about it, but none of them linked. Am I being oblivious? Couldn't find anything else on it in this thread. Do you mean your message that stated "There is also a neat [VS Code] extension for ev3dev. A nice IDE with easy transferring files to the EV3 and running them."?

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

Oh Derp, I'm not using an infrared sensor.

I apologise, I'm very slow today -_-

@laurensvalk
Copy link
Owner

As for the link, try refreshing this page. Maybe my edit didn't get through yet.

@pipothy
Copy link
Author

pipothy commented Sep 26, 2017

It seems to work! The ability to stop and start it with the touch sensor is amazingly useful, thanks for the work!

It seems better, but I haven't had chance to run it for extended sessions. I will likely be doing so on Wednesday/Thursday when I have time to do proper tests. But at the moment, it seems to be performing well!!!

@laurensvalk
Copy link
Owner

laurensvalk commented Sep 26, 2017

The ability to stop and start it with the touch sensor is amazingly useful

Yes, it's the only way to stay sane while tuning. I originally developed it for the ballbots/BB8-robot which took a lot longer to tune 😄

It seems to work!

That's awesome!

@pipothy
Copy link
Author

pipothy commented Sep 29, 2017

Hi, alas it seems I was simply lucky. The controller still seems to struggle and oscillates a lot. I tried 10 times, it lasted at most 40 seconds.

Was yours more reliable than this? If so, I'll have to examine differences in our build or technique for starting the robot I guess....

@laurensvalk
Copy link
Owner

I haven't tuned this latest code revision extensively, so it's possible it's not as robust as it could be.

However, having it balance for more than 10 seconds or so is a useful starting point for further tuning. (Getting to this point is the trickiest.)

@pipothy
Copy link
Author

pipothy commented Oct 3, 2017

Hi, Great, wasn't sure how much you'd tuned it. I'll have a play and let you know! If you haven't extensively tuned it, I'll give it a go and see if I can get any improvements :) Wish me luck! I'll let you know the winning numbers, if I find them...

@laurensvalk
Copy link
Owner

laurensvalk commented Oct 3, 2017

Good luck. It should be less time consuming than before at least 😄

Depending on how you're currently doing it, there may be pretty convenient ways to speed it up.

  • Go wireless (Bluetooth)
  • Use a tool that just lets you keep the parameters file open, so you can just edit, press save, and press the Touch Sensor to start and try those values out, and keep doing this; here are a few options
    • On Mac/Ubuntu it's pretty easy to access the EV3 file system straight from the file manager, and then use any text editor you like
    • If I recall correctly you can open the file in filezilla without downloading it first. When you hit save, it's just saved back to the EV3
  • Because it's Python, you can keep doing steps like this to finetune:
GyroAngle                  = 5000*1.5*1.1 
  • Makes the steps easier, plus it's easy to undo if you don't like the new response.

@pipothy
Copy link
Author

pipothy commented Oct 6, 2017

Hi,

Just to clarify, why 1.51.1? As in, why two multipliers? Also, 1.5 seems a rather large increment...

@laurensvalk
Copy link
Owner

This was just an example of two incremental adjustments (e.g. 50% first and then 10% because you feel like you need some more gain).

By writing the increments like this, you have more or less a history of what you have been doing, and you can easily undo recent changes or return to the "original" values.

@perkinbr
Copy link

perkinbr commented Oct 8, 2017

I had similar issues using the Hitechnic gyro

This commit in my fork seems to solve the issue for me:
perkinbr@838ae21

The code was using time.clock() as a time reference, which gives cpu time used by the program. I switched to time.time() and got much better results once I decreased the gyro angle gain by a factor of two. I didn't do any extensive tuning.

@laurensvalk
Copy link
Owner

The code was using time.clock() as a time reference, which gives cpu time used by the program. I switched to time.time() and got much better results

Ah, yes. I had done this for the ballbot extension of this code, but forgot to update it on this repository.

Thank you for pointing this out!

I'll make those changes and have another look at the tuning parameters this week.

Combined with the voltage scaling in the recent update, we'll hopefully see some more consistent performance across our robots, with less dependence on the tuning parameters.

@pipothy
Copy link
Author

pipothy commented Oct 10, 2017

Great. Is the HiTechnic Gyro much better? Should I be buying one of those?

@laurensvalk
Copy link
Owner

The HiTechnic sensor has have a slightly higher resolution than the EV3 gyro, but it's not that noticable.

The HiTechnic gyro was originally made for the NXT, at a time when LEGO didn't make that type of sensor. LEGO introduced their own gyro sensor with the EV3, more or less making the HiTechnic sensor obsolete.

@laurensvalk
Copy link
Owner

I built an exact copy of BALANC3R yesterday; stay tuned for the updated parameters.

@laurensvalk
Copy link
Owner

Just made the timer changes and did some preliminary tuning. I ended up returning (more or less) to the parameters I had before the recent changes.

Like @perkinbr I choose 30ms for the loop time to make it all fit. This is pretty close to what I'm using in the EV3 software, so that should not be an issue.

It seems to be doing pretty well*. I'd be interested to test the sensitivity to small changes more systematically. Same thing for trying regular batteries instead of the LEGO battery. And various levels of discharge. But that's for later.

*You should never trust a control theorist who tells you this, but it's LEGO so it's okay 😄

@yaniv4345
Copy link

Hi.
After the recent changes do I still need to take the wheel size into consideration?

@laurensvalk
Copy link
Owner

After the recent changes do I still need to take the wheel size into consideration?

Yes. Now that most of the issues we encountered are fixed, I think you can try what I've said initially.

I would recommend to try it out with the example design (43mm wheels) if you can, to make sure it all works.

@laurensvalk
Copy link
Owner

@pipothy just curious if you tried the latest updates?

@pipothy
Copy link
Author

pipothy commented Oct 27, 2017

Hi! Sorry, had a big thesis deadline...

Just got it running. I don't use the infrared sensor, so I had to delete that and also any reference to the "speed" parameter. It was reasonably good, I then put back in the "- motorAngularSpeedReference" and it was even better. Now, it lasts to a minute most of the time.

There was the odd jerk here and there but it recovered. I'll try see if I can get it reliably lasting a minute!

@laurensvalk
Copy link
Owner

had a big thesis deadline...

I sympathize 😄

I don't use the infrared sensor, so I had to delete that and also any reference to the "speed" parameter.

Setting speed = 0 should be sufficient.

There was the odd jerk here and there but it recovered.

Sounds good. There's another issue currently open for that sudden disturbance, so hopefully we can iron that out too.

When that's fixed, it should be possible to achieve infinite run times... at least until the batteries run out.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants