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

    RepRapFirmware 3.01beta1 released

    Scheduled Pinned Locked Moved
    Beta Firmware
    16
    60
    3.5k
    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.
    • dc42undefined
      dc42 administrators @gtj0
      last edited by

      @gtj0 said in RepRapFirmware 3.01beta1 released:

      @dc42 said in RepRapFirmware 3.01beta1 released:

      Thanks for confirming. FWIW, maximum GCode line length excluding leading white space, line number and checksum (if present) and comments is currently 160 characters.

      Are you sending them via text message??? 🙂

      Hadn't you noticed your smartphone bills going up every time you print? 😉

      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

      gtj0undefined 1 Reply Last reply Reply Quote 1
      • gtj0undefined
        gtj0 @dc42
        last edited by

        @dc42 said in RepRapFirmware 3.01beta1 released:

        @gtj0 said in RepRapFirmware 3.01beta1 released:

        @dc42 said in RepRapFirmware 3.01beta1 released:

        Thanks for confirming. FWIW, maximum GCode line length excluding leading white space, line number and checksum (if present) and comments is currently 160 characters.

        Are you sending them via text message??? 🙂

        Hadn't you noticed your smartphone bills going up every time you print? 😉

        Ah that makes sense now. I though it was the cat texting his buddy across the street.

        1 Reply Last reply Reply Quote 0
        • garyd9undefined
          garyd9 @kraegar
          last edited by

          @kraegar said in RepRapFirmware 3.01beta1 released:

          Here is the version that works well:

          I like this, but it seems unnatural to have to repeat the same G30 commands twice in the same script. This is more significant with a delta printer (that often has many more probe points.)

          I'm wondering what alternatives might exist. I see there's no do/while (which would be my first thought), but I'm wondering if it would work to put the list of G30 gcodes in a different file (bed-probes.g)

          @dc42, do the variables from the object model available survive across different scripts? For example, if I had file called "bed-ProbePoints.g" that contained something like:

          G30 P0 Xn Yn 
          ...
          G30 P18 X0 Y0 S6
          

          And then my bed.g contained:

          M561
          G28
          M98 P"bed-ProbePoints.g" 
          while true
              if iterations > 5
                  abort "something needs tightening..."
              if abs(move.initialDeviation.deviation - move.calibrationDeviation.deviation) <= 0.01
                 break
              M98 P"bed-ProbePoints.g"
              
          

          Would this work? Would the deviation values be updated across the scripts?

          Thank you
          Gary

          "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

          kraegarundefined 1 Reply Last reply Reply Quote 0
          • kraegarundefined
            kraegar @garyd9
            last edited by

            @garyd9 This was my very rough first iteration (and still is early, room for improvement, etc etc). Only posted in this thread due to the bugs I was noticing.

            Anyway, see my post here where I did split the G30 segment out into a macro:
            https://forum.duet3d.com/topic/13890/auto-tramming-a-railcore-using-conditional-gcode

            Co-Creator of the RailcoreII CoreXY printer
            https://www.thingiverse.com/thing:2407174

            garyd9undefined 1 Reply Last reply Reply Quote 1
            • garyd9undefined
              garyd9 @kraegar
              last edited by

              @kraegar That is great (and answers my question.)

              thank you

              "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

              1 Reply Last reply Reply Quote 0
              • insertnamehereundefined
                insertnamehere @dc42
                last edited by

                @dc42 said in RepRapFirmware 3.01beta1 released:

                You've found a bug (the property table wasn't ordered alphabetically after I renamed a property, so the binary search failed). I've fixed it in the latest build at https://www.dropbox.com/sh/3azy1njy3ayjsbp/AACquxr2m00eV568RZg5QG5wa?dl=0. I also added a compile-time check to prevent this happening in future, and an extra property state.upTime.

                Firstly, thanks for the quick response. I've tried the fixed firmware and it works great.

                Another thing, I use an ATX type 24V supply controlled by the PS_ON pin.
                After all axis are homed, if I turn of the 24V supply, the axis remain homed "Blue" on the DWC. If I turn on the ATX supply again I can move all axis as if they are homed. Shouldn't turning of the 24V supply automatically mark all axis as homed : false?

                m409
                {"key":"","flags":"","result":{"boards":[{"firmwareFileName":"Duet2CombinedFirmware.bin","firmwareVersion":"3.01-beta1+1","iapFileNameSD":"Duet2CombinedIAP.bin","mcuTemp":{"current":39.6,"max":39.9,"min":38.0},"name":"Duet 2 WiFi","shortName":"2WiFi","vIn":{"current":0.7,"max":24.4,"min":0.4}}],"heat":{"coldExtrudeTemperature":160.0,"coldRetractTemperature":90.0,"heaters":[{"current":22.0,"sensor":0,"state":"Off"},{"current":23.2,"sensor":1,"state":"Active"}],"sensors":[{"lastReading":22.0,"name":"","type":"Thermistor"},{"lastReading":23.2,"name":"","type":"Thermistor"}]},"job":{"file":{"filament":[],"firstLayerHeight":0.0,"generatedBy":"","height":0.0,"lastModified":"28115-10-29T03:41:51","layerHeight":0.0,"numLayers":0,"printTime":0,"simulatedTime":0,"size":0},"lastFileName":"","layer":0,"timesLeft":{"filament":0.0,"file":0.0,"layer":0.0}},"move":{"axes":[{"homed":true,"letter":"X","max":300.0,"min":0.0,"userPosition":70.000,"visible":true},{"homed":true,"letter":"Y","max":300.0,"min":0.0,"userPosition":265.000,"visible":true},{"homed":true,"letter":"Z","max":350.0,"min":0.0,"userPosition":4.213,"visible":true}],"calibrationDeviation":{"deviation":0.000,"mean":0.000},"currentMove":{"requestedSpeed":0.0,"topSpeed":0.0},"daa":{"enabled":false,"minimumAcceleration":10.0,"period":0.0},"idle":{"factor":0.7,"timeout":30000},"initialDeviation":{"deviation":0.004,"mean":0.014},"meshDeviation":{"deviation":0.032,"mean":0.099},"printingAcceleration":10000.0,"speedFactor":100.0,"travelAcceleration":10000.0},"network":{"interfaces":[{"actualIP":"192.168.1.142","firmwareVersion":null,"gateway":"0.0.0.0","subnet":"0.255.255.255","type":"wifi"}]},"state":{"currentTool":0,"machineMode":"FFF","status":"Off","upTime":193}}}

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

                  @insertnamehere said in RepRapFirmware 3.01beta1 released:

                  After all axis are homed, if I turn of the 24V supply, the axis remain homed "Blue" on the DWC. If I turn on the ATX supply again I can move all axis as if they are homed. Shouldn't turning of the 24V supply automatically mark all axis as homed : false?

                  Yes. I will fix that.

                  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

                  garyd9undefined 1 Reply Last reply Reply Quote 0
                  • garyd9undefined
                    garyd9 @dc42
                    last edited by

                    @dc42
                    With the build from your dropbox...

                    Error: in file macro, line 18 column 12: unknown value abs

                    The line in question:

                    if abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.02

                    "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

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

                      @garyd9, try enclosing the whole expression in { } so that the round brackets are not treated as enclosing comments.

                      The deviation value is RMS so it is always positive, unlike the mean.

                      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

                      dc42undefined garyd9undefined 2 Replies Last reply Reply Quote 0
                      • dc42undefined
                        dc42 administrators @dc42
                        last edited by dc42

                        I've just put 3.01-beta1+1 (2020-01-17b3) binaries at https://www.dropbox.com/sh/3azy1njy3ayjsbp/AACquxr2m00eV568RZg5QG5wa?dl=0. These support additional OM variables, including extruder parameters such as pressure advance.

                        The format for driver IDs may change in future beta releases. I am currently returning strings such as "3.1" for driver 1 on board 3; but I may change this to return 301 in this case, i.e. 100*board_id + driver_number. Whichever I choose, I will allow the format returned by the OM variable to be used in M584, M569 etc.

                        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 1
                        • Danalundefined
                          Danal
                          last edited by

                          @dc42 said in RepRapFirmware 3.01beta1 released:

                          but I may change this

                          If you are taking votes/opinions, overall compatibility with the pin labeling nomenclature seems desirable.

                          Delta / Kossel printer fanatic

                          1 Reply Last reply Reply Quote 0
                          • garyd9undefined
                            garyd9 @dc42
                            last edited by garyd9

                            @dc42 said in RepRapFirmware 3.01beta1 released:

                            @garyd9, try enclosing the whole expression in { } so that the round brackets are not treated as enclosing comments.

                            The deviation value is RMS so it is always positive, unlike the mean.

                            About being positive, that's true, but the difference between means might be negative, so I want to get the absolute value of the difference...

                            As for using curly braces, I'm not having much luck with that. Perhaps because I'm not quite sure where, exactly, the curly braces should be. Here's some of the things I tried, followed by the resulting error:

                            if {abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}
                            Error: in file macro, line 16 column 91: expected ')'

                            if abs{(move.calibrationDeviation.deviation - move.initialDeviation.deviation)} < 0.002
                            Error: in file macro, line 16 column 11: unknown value abs

                            if abs{move.calibrationDeviation.deviation - move.initialDeviation.deviation} < 0.002
                            Error: in file macro, line 16 column 11: unknown value abs

                            if abs({move.calibrationDeviation.deviation - move.initialDeviation.deviation}) < 0.002
                            Error: in file macro, line 16 column 12: unknown value abs

                            {if abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}
                            Error: Bad command: {if abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}

                            To be absolutely clear, my intention is to get the absolute value of the difference of the two deviations, and compare that to 0.002

                            "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

                            1 Reply Last reply Reply Quote 0
                            • Danalundefined
                              Danal
                              last edited by

                              @garyd9 said in RepRapFirmware 3.01beta1 released:

                              if {abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}

                              I get no error with the format above. Running:

                              Firmware: RepRapFirmware for Duet 3 MB6HC v0.6 or 1.0 3.01-beta1+1 (2020-01-17b3)

                              Delta / Kossel printer fanatic

                              garyd9undefined 2 Replies Last reply Reply Quote 0
                              • garyd9undefined
                                garyd9 @Danal
                                last edited by

                                @Danal said in RepRapFirmware 3.01beta1 released:

                                @garyd9 said in RepRapFirmware 3.01beta1 released:

                                if {abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}

                                I get no error with the format above. Running:

                                Firmware: RepRapFirmware for Duet 3 MB6HC v0.6 or 1.0 3.01-beta1+1 (2020-01-17b3)

                                Odd. I'm also running "3.01-beta1+1 (2020-01-17b3)". Perhaps because I'm running it on a Duet2 (duet wifi)?

                                I'll try again in 5-6 hours (if I'm still awake) when my current print finishes...

                                I will say that I'm starting to wonder if I should "upgrade" to a duet3. While I really don't need the extra ports or capabilities, the newer versions of RRF3 seem to bog down the older boards. I started to get hiccups on my delta at even only 150mm/sec movements now. 😞

                                "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

                                1 Reply Last reply Reply Quote 0
                                • Danalundefined
                                  Danal
                                  last edited by

                                  Yeah, and I'm running a Pi. It is very unclear to me how much gcode is processed on the DSF on the Pi vs actually being passed to the Duet.

                                  Delta / Kossel printer fanatic

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

                                    @Danal said in RepRapFirmware 3.01beta1 released:

                                    Yeah, and I'm running a Pi. It is very unclear to me how much gcode is processed on the DSF on the Pi vs actually being passed to the Duet.

                                    GCodes commands are pre-parsed on the Pi, but most of them are just passed in the parsed state to the Duet. A few such as M98 and M32 are processed partly on the Pi.

                                    I am currently looking at the why RRF3 has hiccups at lower step rates than RRF2.

                                    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
                                    • garyd9undefined
                                      garyd9 @Danal
                                      last edited by

                                      @Danal said in RepRapFirmware 3.01beta1 released:

                                      @garyd9 said in RepRapFirmware 3.01beta1 released:

                                      if {abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}

                                      I get no error with the format above. Running:
                                      Firmware: RepRapFirmware for Duet 3 MB6HC v0.6 or 1.0 3.01-beta1+1 (2020-01-17b3)

                                      I've confirmed that I DO get an error similar to "Error: in file macro, line 22 column 90: expected ')'" with the same statement (followed by a newline, tab, and 'break' statement':

                                      if{abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation) < 0.002}
                                      

                                      I'm using a Duet Wifi 1.04 with firmware "RepRapFirmware for Duet 2 WiFi/Ethernet 3.01-beta1+1 (2020-01-17b3)" (No SBC option exists.) I wonder if the same problem exists for non-SBC Duet3 users.

                                      "I'm not saying that you are wrong - I'm just trying to fit it into my real world simulated experience."

                                      1 Reply Last reply Reply Quote 0
                                      • kraegarundefined
                                        kraegar
                                        last edited by

                                        I couldn't get abs to work either, so just nested the if statements. Ugly, but I figured it was something I was doing wrong. Also testing on a duet2.

                                        Co-Creator of the RailcoreII CoreXY printer
                                        https://www.thingiverse.com/thing:2407174

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

                                          @garyd9 said in RepRapFirmware 3.01beta1 released:

                                          abs(move.calibrationDeviation.deviation - move.initialDeviation.deviation)

                                          I confirm there is a problem with functions. Looking into it now.

                                          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
                                          • appjawsundefined
                                            appjaws
                                            last edited by

                                            When I am running my macro " Conditional auto bed levelling using 3 Z motors" an error message is displayed during execution, "RESPONSE TOO LONG SEE CONSOLE".
                                            Nothing is reported in the console log and the macro continues anyway.
                                            Just thought you should know.

                                            ; Conditional auto bed levelling using 3 Z motors

                                            M561 ; clear any existing bed transforms

                                            if heat.heaters[0].current <60
                                            M291 P"Preheating to bed to 65 and nozzle to 195 for accurate probing"
                                            M140 S60 ; Set bed temperature to 60
                                            M116 ; waiting for bed to reach temperature
                                            if heat.heaters[0].current <65 || heat.heaters[1].current <190
                                            M140 S65 ; Set bed temperature to 65
                                            G10 S195 ; Set current tool temperature to 195C
                                            M116 ; waiting for bed and nozzle to reach temperature

                                            ; If the printer hasn't been homed, home it
                                            if !move.axes[0].homed || !move.axes[1].homed || !move.axes[2].homed
                                            G28

                                            G1 Z7.5

                                            ;Run an initial 3-point Probe

                                            M291 P"auto bed levelling using 3 Z motors started"

                                            M98 P"0:/macros/Conditional/bedlevel.g"

                                            while true
                                            if iterations = 5
                                            abort "Too many auto calibration attempts"
                                            echo "iterations = ", iterations
                                            if move.initialDeviation.deviation < 0.01
                                            if move.calibrationDeviation.deviation < move.initialDeviation.deviation + 0.005
                                            if move.calibrationDeviation.deviation > move.initialDeviation.deviation - 0.005
                                            break
                                            echo "Repeating calibration because initial deviation (" ^ move.initialDeviation.deviation ^ "mm) must be < 0.01"
                                            echo "and (" ^ move.calibrationDeviation.deviation ^ "mm) must be within 0.005 of initialDeviation"

                                            M98 P"0:/macros/Conditional/bedlevel.g"

                                            echo "Auto calibration successful, deviation", move.calibrationDeviation.deviation ^ "mm"
                                            echo "Auto calibration successful, initialDeviation", move.initialDeviation.deviation ^ "mm"

                                            M140 S0 ; Set bed temperature to 0C
                                            G10 S0 ; Set current tool temperature to 0C
                                            G1 X150 Y100; Move to bed centre
                                            G30; reset Z0

                                            G1 X50 Y230 F24000 ; move the head to park
                                            M291 P"auto bed levelling using 3 Z motors completed"

                                            appjaws - Core XYUV Duet Ethernet Duex5
                                            firmware 3.5.0-rc.4 Web Interface 3.5.0-rc.4
                                            Ormerod 1-converted to laser engraver, Duet wifi
                                            OpenSCAD version 2024.03.18
                                            Simplify3D 5.1.2

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