Other ways to interface with LinuxCNC
- HerrNamenlos123
- Topic Author
- Offline
- New Member
Less
More
- Posts: 17
- Thank you received: 2
08 Sep 2023 21:10 #280293
by HerrNamenlos123
Other ways to interface with LinuxCNC was created by HerrNamenlos123
Hi there!
As per wiki.linuxcnc.org/cgi-bin/wiki.pl?LinuxCNC_Supported_Hardware, LinuxCNC does support a number of Hardwares, but all of them are kind of proprietary. I am asking if there is a more general way to interface with LinuxCNC. Let me explain.
In many of my projects, having a fully featured CNC controller core like LinuxCNC (with trajectory planning, PID tuning, homing cycles, etc...) would be very useful and I am not aware of LinuxCNC alternatives that are this advanced. The issue is that all of the listed Hardwares do not really allow to extend the system, they are just a bridge for a few motors and that's it. What I am thinking of is a solution that forwards the LinuxCNC outputs into a program of mine, where I can then control any hardware i like.
Think of it like a ROS node. Ideally there would be a way to connect LinuxCNC to a ROS node instead of a MESA card, and the ROS node would receive motor PWM values in realtime, and return encoder values in realtime, as needed by LinuxCNC. Once this bridge is created, any hardware can be controlled using the ROS node. Another option would be to have a non-ROS process running on the LinuxCNC computer that does what I just described, that simply sends this motor data to an Arduino. You see, as soon as I have a C++ program receiving the data from LinuxCNC I would be able to control ANY hardware with LinuxCNC (that is, small Arduino steppers, large BLDC servo motors, virtual CNC simulations, multi-axis robots, you name it).
See answers.ros.org/question/328506/creating...ontrolled-robot-arm/. Apparently there has already been interest in connecting LinuxCNC with ROS. I think what differentiates me from this post is that they want to receive just positions, and I am fine with dealing with PWM values and implementing PID controllers myself, if that's more realistic. Anything that works. I just want to outsource all the heavy kinematic calculations. I would be fine with a ROS solution, although I would prefer a non-ROS solution.
Now, are there already official solutions similar to ROS?
If not, what would be the easiest way to do it? Would it be easier to write a custom HAL driver that forwards the outputs via Ethernet, or to choose one of the already supported hardwares and reverse engineer its protocol to fake a real device?
As per wiki.linuxcnc.org/cgi-bin/wiki.pl?LinuxCNC_Supported_Hardware, LinuxCNC does support a number of Hardwares, but all of them are kind of proprietary. I am asking if there is a more general way to interface with LinuxCNC. Let me explain.
In many of my projects, having a fully featured CNC controller core like LinuxCNC (with trajectory planning, PID tuning, homing cycles, etc...) would be very useful and I am not aware of LinuxCNC alternatives that are this advanced. The issue is that all of the listed Hardwares do not really allow to extend the system, they are just a bridge for a few motors and that's it. What I am thinking of is a solution that forwards the LinuxCNC outputs into a program of mine, where I can then control any hardware i like.
Think of it like a ROS node. Ideally there would be a way to connect LinuxCNC to a ROS node instead of a MESA card, and the ROS node would receive motor PWM values in realtime, and return encoder values in realtime, as needed by LinuxCNC. Once this bridge is created, any hardware can be controlled using the ROS node. Another option would be to have a non-ROS process running on the LinuxCNC computer that does what I just described, that simply sends this motor data to an Arduino. You see, as soon as I have a C++ program receiving the data from LinuxCNC I would be able to control ANY hardware with LinuxCNC (that is, small Arduino steppers, large BLDC servo motors, virtual CNC simulations, multi-axis robots, you name it).
See answers.ros.org/question/328506/creating...ontrolled-robot-arm/. Apparently there has already been interest in connecting LinuxCNC with ROS. I think what differentiates me from this post is that they want to receive just positions, and I am fine with dealing with PWM values and implementing PID controllers myself, if that's more realistic. Anything that works. I just want to outsource all the heavy kinematic calculations. I would be fine with a ROS solution, although I would prefer a non-ROS solution.
Now, are there already official solutions similar to ROS?
If not, what would be the easiest way to do it? Would it be easier to write a custom HAL driver that forwards the outputs via Ethernet, or to choose one of the already supported hardwares and reverse engineer its protocol to fake a real device?
Please Log in or Create an account to join the conversation.
- cornholio
- Offline
- Platinum Member
Less
More
- Posts: 1101
- Thank you received: 367
08 Sep 2023 23:17 #280298
by cornholio
Replied by cornholio on topic Other ways to interface with LinuxCNC
All the Mesa FPGA source code is open source. I've playing around with running the firmware on 2 different Spartan 6 Dev boards.
There's a number of open source projects that have been using boards supported by the Litex project. Litexcnc is one, Litehm2 another and Linuxcnc-RIO supports lattice ICE40 boards and Tang boards as well.
Cyclone IV Dev boards should also work.
But the thing is dollar for dollar the Mesa cards are great value compared to "rolling your own".
Now none of this is meant to distract you, just pointing out realities.
Since linuxcnc is modular anything is possible and you will get support.
Good luck and keep us all updated.
The Remora project has quite a bit of hardware that it will run on.
There's a number of open source projects that have been using boards supported by the Litex project. Litexcnc is one, Litehm2 another and Linuxcnc-RIO supports lattice ICE40 boards and Tang boards as well.
Cyclone IV Dev boards should also work.
But the thing is dollar for dollar the Mesa cards are great value compared to "rolling your own".
Now none of this is meant to distract you, just pointing out realities.
Since linuxcnc is modular anything is possible and you will get support.
Good luck and keep us all updated.
The Remora project has quite a bit of hardware that it will run on.
The following user(s) said Thank You: tommylight
Please Log in or Create an account to join the conversation.
- tommylight
- Away
- Moderator
Less
More
- Posts: 19479
- Thank you received: 6532
08 Sep 2023 23:30 #280299
by tommylight
Replied by tommylight on topic Other ways to interface with LinuxCNC
Read this twice, still baffled at what you actually want!
You keep repeating "control anything", i am sure you do not want to control a space station, but still that is very wide and non descriptive term that adds to the confusion.
You also keep mentioning ROS, does ROS not have trajectory planning?
From what i gather, you actually want to have LinuxCNC and Mesa cards, so you can control anything with a power plug or batteries, right?
And yes, you can control even the washing machine and fridge and microwave and lawnmower using Mesa boards and only Mesa boards. Cables might be a bit hindering, though.
I do not mean controlling the on/off button on the washing machine, i mean everything, yanking out all the electronic boards and wiring Mesa stuff to control motors, pumps, valves, timings, heaters, temperature, water levels, etc and open a gcode file based on what clothes you are washing!
Add a touch screen and it would make Samsung or Bosch blush.
Actually, writing this, that is not a bad idea ....
You keep repeating "control anything", i am sure you do not want to control a space station, but still that is very wide and non descriptive term that adds to the confusion.
You also keep mentioning ROS, does ROS not have trajectory planning?
From what i gather, you actually want to have LinuxCNC and Mesa cards, so you can control anything with a power plug or batteries, right?
And yes, you can control even the washing machine and fridge and microwave and lawnmower using Mesa boards and only Mesa boards. Cables might be a bit hindering, though.
I do not mean controlling the on/off button on the washing machine, i mean everything, yanking out all the electronic boards and wiring Mesa stuff to control motors, pumps, valves, timings, heaters, temperature, water levels, etc and open a gcode file based on what clothes you are washing!
Add a touch screen and it would make Samsung or Bosch blush.
Actually, writing this, that is not a bad idea ....
Please Log in or Create an account to join the conversation.
- cornholio
- Offline
- Platinum Member
Less
More
- Posts: 1101
- Thank you received: 367
09 Sep 2023 00:37 #280302
by cornholio
Replied by cornholio on topic Other ways to interface with LinuxCNC
Household appliance should have a simple knob.
The bloody stove\hotplate combo at home has some weird setup that I can't get my head around.
All I want is 6 knobs that go lo-hi for the hot plates oven & grill and a mechanical timer.
Maybe I'm a Luddite hahaha
The bloody stove\hotplate combo at home has some weird setup that I can't get my head around.
All I want is 6 knobs that go lo-hi for the hot plates oven & grill and a mechanical timer.
Maybe I'm a Luddite hahaha
The following user(s) said Thank You: tommylight
Please Log in or Create an account to join the conversation.
- tommylight
- Away
- Moderator
Less
More
- Posts: 19479
- Thank you received: 6532
09 Sep 2023 01:26 #280304
by tommylight
Replied by tommylight on topic Other ways to interface with LinuxCNC
LOL
Gave me an idea about my above idea, have a touchscreen with "socks" "undies" "shirts" and "other cr@p" on that washing machine would simplify using it a lot more than what they are now at.
Gave me an idea about my above idea, have a touchscreen with "socks" "undies" "shirts" and "other cr@p" on that washing machine would simplify using it a lot more than what they are now at.
The following user(s) said Thank You: cornholio
Please Log in or Create an account to join the conversation.
- HerrNamenlos123
- Topic Author
- Offline
- New Member
Less
More
- Posts: 17
- Thank you received: 2
09 Sep 2023 06:23 #280307
by HerrNamenlos123
Replied by HerrNamenlos123 on topic Other ways to interface with LinuxCNC
Thank you for the reply!
I did not mean proprietary in that sense, what I meant is that all available systems do kind of their own thing, you either buy hardware A and run software A, or buy hardware B and run software B, etc.
My goal would be to have a piece of software running on the LinuxCNC PC, that has all the data, *without* any external hardware whatsoever.
Yesterday I finally got a huge leap forward by finding HAL2Arduino. It does about what I want, it is a HAL driver that forwards the data to a custom Arduino firmware, and then the Arduino can do its own thing. What I am imagining is just the HAL driver itself, but written in C++ and with a modern, well-documented API.
I did not mean proprietary in that sense, what I meant is that all available systems do kind of their own thing, you either buy hardware A and run software A, or buy hardware B and run software B, etc.
My goal would be to have a piece of software running on the LinuxCNC PC, that has all the data, *without* any external hardware whatsoever.
Yesterday I finally got a huge leap forward by finding HAL2Arduino. It does about what I want, it is a HAL driver that forwards the data to a custom Arduino firmware, and then the Arduino can do its own thing. What I am imagining is just the HAL driver itself, but written in C++ and with a modern, well-documented API.
Please Log in or Create an account to join the conversation.
- HerrNamenlos123
- Topic Author
- Offline
- New Member
Less
More
- Posts: 17
- Thank you received: 2
09 Sep 2023 06:32 #280310
by HerrNamenlos123
Replied by HerrNamenlos123 on topic Other ways to interface with LinuxCNC
I did look at ROS and found out that it is not good at all for realtime control or synchronized motion. I just mentioned it because I think it demonstrated the idea of an extensible interface. I do not have or want Mesa cards, that is the entire point of my project. Ideally the only hardware I need is an Arduino, that receives motor data via Ethernet in realtime.
As said, HAL2Arduino looks very promising, from my understanding it is a python program that is loaded as a HAL component, and this python program gets the data from LinuxCNC and passes it to an Arduino with a HAL2Arduino Firmware. This is exactly what I want, but JUST the part that talks to LinuxCNC, minus the Arduino Serial interface.
Talking about HAL: In the HAL2Arduino source code it states that this HAL solution is only for testing and has a lot more lag than a proper parallel port, and should never be used on a production machine. Now, is this always the case for HAL, or would it be as fast if i write the HAL component in C++ and load it as an RT component?
As said, HAL2Arduino looks very promising, from my understanding it is a python program that is loaded as a HAL component, and this python program gets the data from LinuxCNC and passes it to an Arduino with a HAL2Arduino Firmware. This is exactly what I want, but JUST the part that talks to LinuxCNC, minus the Arduino Serial interface.
Talking about HAL: In the HAL2Arduino source code it states that this HAL solution is only for testing and has a lot more lag than a proper parallel port, and should never be used on a production machine. Now, is this always the case for HAL, or would it be as fast if i write the HAL component in C++ and load it as an RT component?
Please Log in or Create an account to join the conversation.
- Aciera
- Offline
- Administrator
Less
More
- Posts: 4017
- Thank you received: 1732
09 Sep 2023 07:19 #280312
by Aciera
Also I believe that ROS 3 is real time capable and 'machinekit' (a now largely abandoned fork of linuxcnc) had an interface for ROS, although I'm not sure whether that was for ros2 or ros3.
Replied by Aciera on topic Other ways to interface with LinuxCNC
The problem is that python is an interpreted language and as such not suited for real time applications so, yes, you would want to use a compiled language like C++, compile it and load that as an rt component.Now, is this always the case for HAL, or would it be as fast if i write the HAL component in C++ and load it as an RT component?
Also I believe that ROS 3 is real time capable and 'machinekit' (a now largely abandoned fork of linuxcnc) had an interface for ROS, although I'm not sure whether that was for ros2 or ros3.
Please Log in or Create an account to join the conversation.
- rodw
- Offline
- Platinum Member
Less
More
- Posts: 10795
- Thank you received: 3556
09 Sep 2023 07:23 #280313
by rodw
Replied by rodw on topic Other ways to interface with LinuxCNC
I don't believe you can use your arduino for step generation becauuse the USB connection to the PC is not going to be real time (due to USB architecture limitations)
Please Log in or Create an account to join the conversation.
- Aciera
- Offline
- Administrator
Less
More
- Posts: 4017
- Thank you received: 1732
09 Sep 2023 07:29 #280314
by Aciera
Replied by Aciera on topic Other ways to interface with LinuxCNC
Yes, the hardware interface would have to be real time capable as well, which USB is not.
The following user(s) said Thank You: rodw
Please Log in or Create an account to join the conversation.
Time to create page: 0.120 seconds