-
Notifications
You must be signed in to change notification settings - Fork 270
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
A simulator for the farmbot #1194
Comments
Hi @Bracewind It's a busy day for me here at FarmBot, so it will be some time before I can provide a full response, but this is a very interesting idea. I will provide a longer response some time this week. Thanks for reaching out to us! |
Ok, thanks for giving me an answer despite your workload, |
@Bracewind OK- sorry for the delay. Here is a more in-depth response.
This is a really fun idea, and we've had quite a few folks request it in the past. I think this would be fun for people who are passively curious about FarmBot.
I could see the feature being useful to non-developers, but for a software developer that is not concerned with visualization or aesthetics, it is already possible to simulate a FarmBot by purchasing a RAMPS board on Amazon (~$25 USD), flashing the FarmBot firmware to it, and running FBOS on a host laptop. This is how I do most local development for FarmBot features. It might also be a good way for you to test things out as you build the simulator.
I am happy to continue the discussion in this Github thread. If it looks like you are very serious about the project, I can hop on a call with you later on. We also were contacted by some folks this week that had a similar interest and are using IsaacSim, I'm not sure if you've heard of that before (I have not). From the perspective of a developer, I'd be happy to share advice on the parts of the stack that would be best suited for simulation.
FarmBot has two software developers (including myself) so that's not an option for us. It's also worth mentioning that our ability to change FarmBot source code to meet the needs of this project would be limited as well, since our main focus is meeting the needs of paying customers. There are ways that a simulator could be built without changes to the FarmBot codebase. Since I don't know how your idea fits in to the roadmap or our coding standards, I can't promise any changes to existing FarmBot code to meet the needs of a simulator. I am fairly certain a simulation could be built unobtrusively, though I would need to know more about your tool chain to provide options, though. I look forward to learning more about the tools you plan on using. I hope this helps! Speak soon. |
@RickCarlino No problem, this is a low priority improvement, so take all the time you need
I think that more than asthetics, it also helps to simulate what would happen when there is physical inconstencies, for instance if there is less friction between two links, and see if the measures taken by the program are enough to deal with that case. A simple stub may do the trick, but having a physical engine doing the job for you is reassuring. Anyway, considering what you said, it would probably be more useful to have a beautiful simple model than an ugly complex one.
Thanks for the tip, I will definitely use this.
I don’t know the simulators used in the industry, as most of them are expensive. I made a little search about IssacSim, and the version useful for manipulative robot is still at an early stage. It seems it is a good choice when the robot is controlled using machine learning, as the simulator is probably faster than other simulators, since it is developed by Nvidia. But when it comes to real simulation, I think it will be less realistic than others, and allow for less options. Moreover, I’m not sure it will be completely free when it will be released... There are three simulators I found interesting : V-rep, Gazebo and Webots. I know well Gazebo, so I’m keen on using it, but it is probably not the right choice for something easy to use.
Changing FarmBot source code never crossed my mind. I think a good way to do this would be to get the g-code generated for arduino and transfer it to the computer, then parse and execute it so it does the movements asked on the simulator. However, this won’t truly be the movements of the farmbot if PID controller or other control systems are executed by the firmware and not the OS, which is probably the case. But I think it’s not really relevant for this project. If you have anything you want to add or correct, feel free to do so. I will come back after analyzing a little more each simulator |
This is a good idea. If you need a starting point (or just want to see how GCode interactions occur), you could flash FarmBot OS onto a RaspberyPi. FBOS can handle the Arduino being unplugged (or not having an Arduino at all). This might be the fastest way to get test data. Please let me know if you have any questions. |
A summary of the available choices is given after this paragraph if you are in a hurry I've tested the three simulators and.... it will be more complex than what I thought ;)
You are the one that needs to choose :
To be honest, I don't really know who will use the simulator (except me) and I think you know that better than me, this is why I cannot make this decision myself. Since a parser will be needed for the project, I also was wondering if a g-code parser had already been implemented somewhere. If you want more details or need more information, feel free to ask. |
Since it sounds like you are doing this as a side project for fun, I would definitely pick the one that you find most rewarding / enjoyable to work with. With that being said, from a "usefulness" perspective, I think a simulator is best suited for non-technical users (as I mentioned in a previous message, there are already a variety of tools available for software developers). Having something that is visual and Windows based is probably the best fit for a non-technical user base. On the flip side, we only use Linux for software development here at FarmBot.
It sounds like you are familiar with the design of parsers. One thing to keep in mind about this parser is that it will most likely be one of the most simple you have ever written. The official FarmBot G-Code parser is here. Depending on your programming background, there is an old Ruby-based GCode parser that can be found here. The GCode spec has not changed too much in 5 years, aside from some new additions. FarmBot Gcode is easily parsed using string splitting and case statements. Use of more advanced techniques (such as regex or string scanners) might be overkill. What language are you using for the parser? A good experiment to try would be to flash FarmBot firmware onto an Arduino Mega and view the output in a serial terminal, such as Hyperterm. |
I’ve seriously tried to use webots, and I could load the model whithout materials using plugins. But I regularly experiment crashes, and I think the cause is huge memory leak in the software… So I will use Gazebo, even though it is clearly not the optimal choice :/ I’ve started to create the visual, but to add physical properties such as collisions, I would need models with less mesh than what is available on Onshape. I suppose it has not been done so I will try to do it.
I looked at the parsers you gave me and you’re right it is quite simple. The code will be done in c++ in the whole project because I think it will be easier to interoperate with the arduino, and because it will be easier to optimize the code if needed. To be consistent, the parser will also be in c++. Since it will probably not be very difficult, and since I still don’t have the Arduino (shipping is longer right now), I will do the parser later. |
@Bracewind |
@gueux I worked on other things the last year, and could not really find time to develop the simulator. For now, I only did a very simple graphical control with no physics and no gcode. |
Hello everyone,
I contacted Rory Aronson some time ago about the potential creation of a simulator for the farmbot. I take advantage of the coronavirus to find some free time at last.
First, I would like to know your opinion on the subject, especially if it will be useful for you, and if yes what do you need most. For instance, a simulation could be used to test/debug the code, or it could be released and used as a marketing tool to let anyone play with the web interface. Depending on your answer, the technology and the way it is put together with the current code could be different.
To me, the simulator would be a way to play with the code and see how it works before eventually buying the real robot in the years to come.
If you want to go further, i will give you more details about which simulator will be used, where to link the simulator to the code… There is also some details that I need to discuss with you. And obviously, all that will depend on what you want.
Finally, I must be honest, I will not work on it a lot of time and it won’t be ready before 5 to 6 months minimum. If you think you will be able to dispatch someone to work on the simulator, please let me know, as it will influence the technologies used.
Best regards,
Grégoire Pichereau
The text was updated successfully, but these errors were encountered: