Duet3D Logo Duet3D
    • Tags
    • Documentation
    • Order
    • Register
    • Login

    Firmware wishlist and priorities for Duet WiFi and Duet Ethernet

    Scheduled Pinned Locked Moved
    Firmware wishlist
    113
    236
    50.8k
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • Dougal1957undefined
      Dougal1957
      last edited by

      It works for me I have both my Router and wifi AP listed so wherever the printer is in the house it works

      1 Reply Last reply Reply Quote 0
      • sverrebundefined
        sverreb
        last edited by

        Printers may experience a slight tilt of their carriage for their movement. Tilts that are small enough that they do not matter for actual printing may still cause problems during bed probing as the probe is often significantly offset from the pivot center (where the hot-end tend to be) This causes errors when probing the bed in which probes done when travel approaches from one side along the sensive axis vs. the other creating a bed height map with ripples that do not correspond to an actual imperfection in the bed.

        To minimize this the carriage should ideally approach each probe point from the same direction on both axis during probing.

        As a simpler but mostly good enough solution it is suggested to allow the user to select if the g29 command traverses X first or Y. While not a perfect solution it does solve any situation there tilting occurs on only one axis

        1 Reply Last reply Reply Quote 0
        • jmjcoke2undefined
          jmjcoke2
          last edited by

          10
          11
          12

          1 Reply Last reply Reply Quote 0
          • dc42undefined
            dc42 administrators
            last edited by

            Time to review the wish list. Here is the original one, in order of decreasing votes, and a note of which ones have been implemented:

            (24 votes) 7. Dynamically-varying microstepping. This will allow you to configure 256x microstepping most cases, because the microstepping will be reduced automatically during high-speed moves.

            (19 votes) 1. Reworked WiFi server code, including configuration using files on the SD card, automatic retry if the connection is lost, live reporting of signal strength and status, more reliable support of multiple concurrent connections, and optional FTP and Telnet support. Done, although multiple concurrent clients can be problematic when one of them goes offline without disconnecting first.

            (17 votes) 6. Live monitoring of TMC2660 driver status and reporting of problems (e.g. overheat warning). Done.

            (17 votes) 16. Feed-forward temperature control to predict the effect of turning the print cooling fan on or increasing the extrusion rate, and therefore reduce the temperature fluctuation.

            (14 votes) 14. Support for powering off during a print, then resuming it when the printer is powered up again. Done, and being improved in 1.20.

            (13 votes) 3. Logging of various events, including print start/pause/resume/cancel/end, and error messages. Done in 1.20

            (13 votes) 17. Filament and printing time odometers.

            (13 votes) 18. Ability to update PanelDue firmware via the web interface. PanelDue version 3 has the hardware to support this but the firmware support needs to be written.

            (12 votes) 5. True bed levelling using 2, 3 or possibly 4 independently-driven Z motors and a Z probe. Done.

            (10 votes) 15. Support for PanelOne 20x4 text displays, or possibly 12864 mono graphics displays.

            (9 votes) 12. Better support for CNC machines. Partly done (M3/M4/M4 commands implemented in 1.20).

            (9 votes) 20. Ability to control an electronics cooling fan thermostatically based on CPU temperature and driver overheat warning. Done.

            (8 votes) 8. Standstill current reduction, which will allow higher motor currents to be used when the motors are moving.

            (8 votes) 19. Ability to wait for cool down before turning off ATX power.

            (7 votes) 11. Better support for laser cutters. Partly done (M3/M4/M4 commands implemented in 1.20).

            (6 votes) 13. Automatic advance of changes in the colour mix when using a mixing hot end. See deckingman's blog.

            (5 votes) 2. Better network security, including SSL if it can be made to work fast enough.

            (4 votes) 4. Independent homing switches for multiple Z motors. Largely superseded by #5, but can be done by defining additional axes.

            (4 votes) 9. Auto-park of motors when power is lost. This will help prevent motors getting out of sync when multiple motors are used to drive a single axis.

            (4 votes) 10. Axis hysteresis compensation.

            In addition, some new features have been requested:

            (requested and seconded) Filament monitor In beta

            (requested and seconded) Heater fault to pause print instead of aborting it Coming in 1.20beta2

            Automatic firmware update I would be reluctant to do this, because firmware updates sometimes require changes to the configuration files

            Email notifications of e.g. print complete

            Print start/stop macros There is already stop.g which is called when M0 is executed at the end of your print, and you can use the slicer start/end gcode to call your own macros

            Automatic XY skew compensation (using Mk42 bed)

            Use Stallguard for bed probing See recent thread on this subject

            Probe the bed multiple times at each point and take an average

            Allow file uploads to be requested during a print, defer them until the print has completed

            When bed probing, allow the probe point to be approached from the same direction each time, to mitigate the effect of combined tilt and backlash when positioning the head

            As many of the items have been completed now, I'll stat a new wishlist soon. Top of that list will be the highest-voted items that haven't yet been implemented. But before I create a new thread for the new wishlist, are there any other items that should be on it - for example, using StallGuard to detect printing problems?

            Duet WiFi hardware designer and firmware engineer
            Please do not ask me for Duet support via PM or email, use the forum
            http://www.escher3d.com, https://miscsolutions.wordpress.com

            DocTruckerundefined 1 Reply Last reply Reply Quote 0
            • Mikeundefined
              Mike
              last edited by

              Using StallGuard to detect possible print collisions and layer shifts is probably the coolest feature in Prusa's new i3. I realize it's much easier for them since Prusa Research controls which motors they have, but an option to configure that would be really nice.

              1 Reply Last reply Reply Quote 0
              • deckingmanundefined
                deckingman
                last edited by

                David,

                I'd kind of hold fire on "13 - advancing tool change commands" due to my recent discoveries about PLA hydrolysing which means it still needs to be purged. Granted, advancing the tool change command would reduce the amount of purge required, but that purge would still need to happen at the original tool position - not the new (advanced) one. So it all gets a bit complicated. You'd need to do something like move the tool command forward but keep the original in place, then do the (small) purge on the second (the original) instance of that tool command. Having said all that, filaments which don't hydrolyse may benefit but I need to do more testing.
                Ian

                Ian
                https://somei3deas.wordpress.com/
                https://www.youtube.com/@deckingman

                1 Reply Last reply Reply Quote 0
                • Vladundefined
                  Vlad
                  last edited by

                  5
                  7
                  9
                  12
                  14

                  Not the most popular options, but that would really be a next big step forward in this board and allow us to build more complex machines using it.

                  1 Reply Last reply Reply Quote 0
                  • Vladundefined
                    Vlad
                    last edited by

                    How about

                    1. an iPhone/Android APP to control the board remotely? I think that would be awesome. Seems like an obvious choice, but I believe there is no app available yet.

                    2. Make UI more eye pleasing/tap friendly.

                    I know aesthetics is definitely less important than functional part, but shouldn't be overlooked too in my opinion 🙂 Just purchased your board, haven't received yet. Very excited to start my new build with it. Would loved to have purchased two boards, one for my CNC router, but I am unsure if it can deliver solid CNC functionality at this point. SO stayed with MACH4 controlled breakout board from "PoKeys" company. Would really prefer to switch to your board at some point in future though.

                    1 Reply Last reply Reply Quote 0
                    • adavidmundefined
                      adavidm
                      last edited by

                      @Vlad:

                      How about

                      1. an iPhone/Android APP to control the board remotely? I think that would be awesome. Seems like an obvious choice, but I believe there is no app available yet.

                      The web interface works really nicely as a full screen web app on Android ("Add to Home Screen" on Chrome menu). It's responsive and full-featured, including access to the web-cam display. I use it to keep an eye on the printer from a different room in the house.

                      I don't think there is anything technically stopping the web interface from being accessed over the Internet using port-forwarding or reverse-proxying. I'd personally be very nervous about doing that though for, hopefully obvious, safety and security reasons.

                      1 Reply Last reply Reply Quote 0
                      • resamundefined
                        resam
                        last edited by

                        I'm using DWC over the Internet via a reverse proxy + TLS + HTTP-Basic-Auth - and it works just fine!
                        Got my webcam, a wifi-enabled power socket, and DWC: all controlled & managed from my phone.

                        Just make sure your proxy doesn't add weird HTTP headers, as the Duet RRF limits headers to 16 at most (memory reasons?)

                        1 Reply Last reply Reply Quote 0
                        • dc42undefined
                          dc42 administrators
                          last edited by

                          We can support more HTTP headers if it helps.

                          Duet WiFi hardware designer and firmware engineer
                          Please do not ask me for Duet support via PM or email, use the forum
                          http://www.escher3d.com, https://miscsolutions.wordpress.com

                          1 Reply Last reply Reply Quote 0
                          • resamundefined
                            resam
                            last edited by

                            @dc42: great! I'm still not sure how I ended up hitting this limit, but my typical nginx config adds at least 4 additional headers. Chrome (or probably any other browser) adds 9 (when POST-upload). HTTP-Basic-Auth is one more header.
                            So we are pretty close to the current limit.

                            If there is enough RAM / resources available, I would recommend bumping [c]MaxHeaders[/c] to maybe at least 24 or 32.
                            (not sure what happens if somebody sends a really large cookie…?)

                            1 Reply Last reply Reply Quote 0
                            • dc42undefined
                              dc42 administrators
                              last edited by

                              I've increased it to 30 for the Duet WiFi/Ethernet in the next beta. The other limit is that a complete HTTP request (excluding any postdata) must fit in 1460 bytes. A really large cookie could cause this limit to be exceeded, however DWC hasn't used cookies for a long time.

                              Duet WiFi hardware designer and firmware engineer
                              Please do not ask me for Duet support via PM or email, use the forum
                              http://www.escher3d.com, https://miscsolutions.wordpress.com

                              1 Reply Last reply Reply Quote 0
                              • JohnOCFIIundefined
                                JohnOCFII
                                last edited by

                                @Mike:

                                Using StallGuard to detect possible print collisions and layer shifts is probably the coolest feature in Prusa's new i3. I realize it's much easier for them since Prusa Research controls which motors they have, but an option to configure that would be really nice.

                                Seconded. I have read the other thread, and realize that there may be limitations, but the concept is sure interesting.

                                1 Reply Last reply Reply Quote 0
                                • jmg123undefined
                                  jmg123
                                  last edited by

                                  MQTT - so the printer can send out it’s status to MQTT compatible services, not so it can be controlled. Basically the printer reports as an mqtt sensor.

                                  Personally I would use it to send me a text message via IFTTT , or flash my living room lights when a print has stopped/finished. Though other things like show hot end temperature via the colour of. A Philips hue lightbulb would also be possible.

                                  Reference designs based on LWIP stack are available. I reckon %complete, finished state and temperatures would be the info to broadcast.

                                  https://home-assistant.io/components/sensor.mqtt/

                                  1 Reply Last reply Reply Quote 0
                                  • ultrasonic2undefined
                                    ultrasonic2
                                    last edited by

                                    10. Axis hysteresis compensation. Backlash compensation
                                    Please please please do this… without it 3d printing will never be that good without every expensive hardware..

                                    I have a number of printers of different kinematics but ALL suffer from backlash ... Seeming the only way to get rid of 99% of it is to go with ball screws on the X/Y access but that will massively increase cost, weight and inertia leading to a slow print..

                                    Also it seems like Marlin is finally implementing this... so..

                                    Thanks in advance

                                    1 Reply Last reply Reply Quote 0
                                    • deckingmanundefined
                                      deckingman
                                      last edited by

                                      @ultrasonic2:

                                      10. Axis hysteresis compensation. Backlash compensation
                                      Please please please do this… without it 3d printing will never be that good without every expensive hardware..

                                      I have a number of printers of different kinematics but ALL suffer from backlash ... Seeming the only way to get rid of 99% of it is to go with ball screws on the X/Y access but that will massively increase cost, weight and inertia leading to a slow print..

                                      Also it seems like Marlin is finally implementing this... so..

                                      Thanks in advance

                                      That's an unusual observation and request. Have you got any pictures or other evidence of how this backlash \ axis hysteresis manifests itself on all your printers? From a basic engineering point of view, backlash is a known phenomenon with screw driven systems and gear trains but not with belted systems, so I'm curious as to why you think that going from a (presumably) belt driven system to a screw driven system would eliminate 99% of the backlash.

                                      Ian
                                      https://somei3deas.wordpress.com/
                                      https://www.youtube.com/@deckingman

                                      1 Reply Last reply Reply Quote 0
                                      • jmlundefined
                                        jml
                                        last edited by

                                        My votes in order of priority, though may be too late:

                                        4. Independent homing switches for multiple Z motors.

                                        18. Ability to update PanelDue firmware via the web interface.

                                        7. Dynamically-varying microstepping. This will allow you to configure 256x microstepping most cases, because the microstepping will be reduced automatically during high-speed moves.

                                        10. Axis hysteresis compensation.

                                        8. Standstill current reduction, which will allow higher motor currents to be used when the motors are moving.

                                        1 Reply Last reply Reply Quote 0
                                        • Alex.crundefined
                                          Alex.cr
                                          last edited by

                                          My Vote, though probably too late:

                                          10. Axis hysteresis compensation.

                                          7. Dynamically-varying microstepping.

                                          I am sure Ian knows this but … in order to make the firmware more CNC friendly i would suggest 3 additional things.

                                          G2/G3 circular movement support
                                          Pitch error comp on the axis (for lead screw/ball screw support)
                                          Change M0/M1 to follow CNC convention with stop and option stop that doesn't necessarily cancel the job or turn the heaters off. Just performs a "feed hold"

                                          My 2 cents

                                          Voron2.4/Duet3 SBC+6HC+3HC+1LC+1HCL(x2) - Delta/Duet2 Wifi - CubePro/Duet2 Wifi+Duex5 - Laser/Duet3 Mini5+ - Cel Robox - U̶p̶3̶0̶0̶+/D̶u̶e̶t̶3̶ ̶6̶H̶C̶+̶LC1̶ - F̶T̶-̶5̶/̶D̶u̶e̶t̶2̶ ̶W̶i̶f̶i̶ - S̶o̶l̶i̶d̶o̶o̶d̶l̶e̶

                                          1 Reply Last reply Reply Quote 0
                                          • dc42undefined
                                            dc42 administrators
                                            last edited by

                                            G2 and G3 are already supported.

                                            Please explain what exactly you mean by "Pitch error comp".

                                            What exactly is the behaviour you would like to see for M0 and M1?

                                            Duet WiFi hardware designer and firmware engineer
                                            Please do not ask me for Duet support via PM or email, use the forum
                                            http://www.escher3d.com, https://miscsolutions.wordpress.com

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Unless otherwise noted, all forum content is licensed under CC-BY-SA