-
Notifications
You must be signed in to change notification settings - Fork 22
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
Comments
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. |
Those wheels are in the Education Expansion kit too, in case you have it. |
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! |
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. |
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. |
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. |
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. |
The robot's balance point is preferred. (A slight deviation shouldn't matter, but that's your best bet.)
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. |
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? |
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? |
Good to know!
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.
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. |
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! |
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. |
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. |
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. |
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. |
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. |
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! |
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 :) |
Hi there! Just a bump to remind about looking into this! |
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. |
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. |
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. |
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? |
You can view all the changes here on Github if you're interested.
I do recommend that you use the latest build (ev3dev stretch 2017 sept 14)
Briefly, I modified the code to:
- Use the standard ev3dev Python library (in the past, it didn't come
installed by default but now it does). This simplifies things like
configuring sensors and resetting motors.
- Add an outer loop so you can stop and restart the balancing loop with a
Touch Sensor. Just for convenience.
- Put the tuning parameters in a separate class file. Just edit the file
after you stopped the robot with the Touch Sensor. Next time you start it,
it uses the new parameters. This saves a lot of time since you don't need
to restart the whole program, which can take up to 8 seconds each time.
There are also a few minor changes to the balancing code:
- Scale the duty cycle by voltage. In theory, this reduces the need to
retune when the battery drains.
- Add a fixed offset to add or subtract from the calculated duty cycle.
This compensates for some friction.
- Added an IR control example.
…On Sun, 24 Sep 2017 at 22:09, pipothy ***@***.***> wrote:
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?
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#8 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ALwVYX1VqDtJHLLwuYH4LxVgSNaKzzI3ks5slrb9gaJpZM4OIQVg>
.
|
Hi there, Invalid Syntax on Line 26 of segway.py at the *args Am I missing something? Read the readme, seemed to be identical to before. Anything differently to running the code? |
Are you running the latest ev3dev stretch from 2017 sept 14? |
Also, how are you currently starting the program? |
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? |
That means you ran the code as Python 2, which explains the error. You can either do:
Or simply
Because of the first line in the file (#!/usr/bin/env python3), the latter command will automatically select Python 3 for you. |
There is also a neat VS Code extension for ev3dev. A nice IDE with easy transferring files to the EV3 and running them. |
Traceback (most recent call last): Any idea on this one? Sorry for all the bothering! |
Just found your thread about an IDE, can't seem to find the actual VS code extension, mind throwing me a link to it? |
Just to help you debug this a little:
Any thoughts on what that might imply? Sometimes error messages really are helpful :) |
I linked to it in my previous comment. |
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."? |
Oh Derp, I'm not using an infrared sensor. I apologise, I'm very slow today -_- |
As for the link, try refreshing this page. Maybe my edit didn't get through yet. |
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!!! |
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 😄
That's awesome! |
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.... |
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.) |
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... |
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.
|
Hi, Just to clarify, why 1.51.1? As in, why two multipliers? Also, 1.5 seems a rather large increment... |
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. |
I had similar issues using the Hitechnic gyro This commit in my fork seems to solve the issue for me: 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. |
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. |
Great. Is the HiTechnic Gyro much better? Should I be buying one of those? |
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. |
I built an exact copy of BALANC3R yesterday; stay tuned for the updated parameters. |
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 😄 |
Hi. |
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. |
@pipothy just curious if you tried the latest updates? |
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! |
I sympathize 😄
Setting speed = 0 should be sufficient.
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. |
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!
The text was updated successfully, but these errors were encountered: