But why? "[I][PLAT]reset sys pos and WCO because disabling motor [I][PLAT]reset coordoffset"

I posted my issue on Lightburn forum but it’s now becoming too much downtime. In the Lightburn console after every Move action it’s resetting position and coordinates. This means I cannot move the laser head to a position and mark/save it’s coordinates for repeat burns. I’ve tried setting the material up to be under a specific coordinate but this has never been ideal. Without the Ray having a mounted immobile laser bed it’s nearly impossible to use this method. I’m constantly switching from the rotary to bed so I can never place the bed/material in the same place. Without a camera on the Ray I cannot line up the design to the materials either.

If anyone can help I’d REALLY appreciate it.
Here is the output from the console after every head movement:

$H
ok
[I][PLAT]reset sys pos and WCO because disabling motor
[I][PLAT]reset coordoffset
?
<Idle|WPos:0.000,400.000,0.000,0.000|FS:0,0|WCO:0.000,-400.000,0.000,0.000>
ok
Starting stream
G21 G54
G91
G1  X0 Y-100 F6000 S0
G90
M2
[I][PLAT]Program End
Stream completed in 0:01
[I][PLAT]reset sys pos and WCO because disabling motor
[I][PLAT]reset coordoffset
?
<Idle|WPos:0.000,400.000,0.000,0.000|FS:0,0|WCO:0.000,-400.000,0.000,0.000>
ok
Starting stream
G21 G54
G91
G1  X0 Y100 F6000 S0
G90
M2
[I][PLAT]Program End
Stream completed in 0:01
[I][PLAT]reset sys pos and WCO because disabling motor
[I][PLAT]reset coordoffset

https://forum.lightburnsoftware.com/t/snapmaker-ray-positioning-issues-after-new-pc/144272?u=chogardjr

$S
$Sta/SSID=GTAX11000
$Sta/Password=******
$Sta/IPMode=DHCP
$Sta/IP=0.0.0.0
$Sta/Gateway=0.0.0.0
$Sta/Netmask=0.0.0.0
$AP/SSID=RAY2023
$AP/Password=******
$AP/IP=192.168.0.1
$AP/Channel=1
$System/Hostname=ray
$Http/Enable=ON
$Http/Port=80
$Telnet/Enable=ON
$Telnet/Port=23
$Radio/Mode=STA
$Message/Enable=Off
$Message/Level=Info
$User/Macro0=
$User/Macro1=
$User/Macro2=
$User/Macro3=
$Homing/Cycle0=Z
$Homing/Cycle1=XY
$Homing/Cycle2=
$Homing/Cycle3=
$Homing/Cycle4=
$Homing/Cycle5=
$Report/StallGuard=
$Stepper/Enable/Delay=50000
$Stepper/Direction/Delay=0
$Stepper/Pulse=1
$Stepper/IdleTime=100
$Stepper/StepInvert=
$Stepper/DirInvert=Y
$Stepper/EnableInvert=Off
$Limits/Invert=Off
$Probe/Invert=Off
$Report/Status=0
$GCode/JunctionDeviation=0.006
$GCode/ArcTolerance=0.002
$Report/Inches=Off
$Firmware/Build=
$Limits/Soft=Off
$Limits/Hard=On
$Homing/Enable=On
$Homing/DirInvert=X
$Homing/Squared=
$Homing/Feed=300.000
$Homing/Seek=3000.000
$Homing/Debounce=250.000
$Homing/Pulloff=2.000
$GCode/MaxS=1000.000
$GCode/MinS=0.000
$Laser/FullPower=1000
$GCode/LaserMode=On
$GCode/Line1=
$GCode/Line0=
$Spindle/Enable/Invert=Off
$Spindle/Enable/OffWithSpeed=Off
$Coolant/Delay/TurnOn=1.000
$Spindle/Delay/SpinDown=0.000
$Spindle/Delay/SpinUp=0.000
$Spindle/PWM/Invert=On
$Spindle/PWM/Frequency=5000.000
$Spindle/PWM/Off=0.000
$Spindle/PWM/Min=0.000
$Spindle/PWM/Max=100.000
$Spindle/Type=LASER
$X/StepsPerMm=80.000
$Y/StepsPerMm=80.000
$Z/StepsPerMm=100.000
$A/StepsPerMm=888.889
$B/StepsPerMm=100.000
$C/StepsPerMm=100.000
$X/MaxRate=30000.000
$Y/MaxRate=12000.000
$Z/MaxRate=1000.000
$A/MaxRate=1500.000
$B/MaxRate=1000.000
$C/MaxRate=1000.000
$X/Acceleration=2000.000
$Y/Acceleration=200.000
$Z/Acceleration=200.000
$A/Acceleration=500.000
$B/Acceleration=200.000
$C/Acceleration=200.000
$X/Home/Mpos=-1.000
$Y/Home/Mpos=401.000
$Z/Home/Mpos=0.000
$A/Home/Mpos=0.000
$B/Home/Mpos=0.000
$C/Home/Mpos=0.000
$X/MaxTravel=600.000
$Y/MaxTravel=400.000
$Z/MaxTravel=300.000
$A/MaxTravel=3600.000
$B/MaxTravel=300.000
$C/MaxTravel=300.000
$X/Current/Run=1.100
$Y/Current/Run=1.100
$Z/Current/Run=0.800
$A/Current/Run=1.100
$B/Current/Run=0.800
$C/Current/Run=0.800
$X/Current/Hold=0.800
$Y/Current/Hold=0.800
$Z/Current/Hold=0.400
$A/Current/Hold=0.400
$B/Current/Hold=0.400
$C/Current/Hold=0.400
$X/Microsteps=16
$Y/Microsteps=16
$Z/Microsteps=16
$A/Microsteps=16
$B/Microsteps=16
$C/Microsteps=16
$X/StallGuard=16
$Y/StallGuard=16
$Z/StallGuard=16
$A/StallGuard=16
$B/StallGuard=16
$C/StallGuard=16
$Errors/Verbose=Off
$I
[VER:V1.7.4.20240702:]
[OPT:PHSW]
[I][PLAT]Machine: Snapmaker Ray Controller```

I have this problem too on 1.7.4
firmware 1.6.8 works properly

2 Likes

Thanks for you response. I was using v1.7.2 with no issues before my laptop melted down. When I installed everything on the new PC I had this issue out of the gate. I learned they released a new firmware version the day after my issue was discovered.
I guess it wouldn’t hurt to rollback the firmware to see if anything changes. At least then I might be a little closer to the root cause of the problem. Right now it’s just speculation on my part that the issue was with Lightburn and the Ray since Luban works as expected.

It would be really nice to get this fixed today. My IR module is being delivered today. I supposed I could use it on the SM2 or use the Ray with Luban. I’ve spent all my time and energy learning Lightburn so without it I feel like I’m working without arms.

You sir are fantastic. 1.6.8 does indeed work as expected. Looks like this is a Snapmaker firmware issue not Lightburn.

It would be really nice if some of the Snapmaker Team members could chime in.
I now have reason to believe the new A>B feature that was introduced is the cause of the newer firmware resetting the coordinate position in Lightburn. I wonder if there’s a way they can add a toggle to switch between A>B and Manual Modes. They have this option within Luban but nothing in Lightburn to make that switch and it appears to default to A>B.

  1. With every move of the head in Lightburn the console says the position and coordinates are being reset because “disabling motor” expressed as:
[I][PLAT]reset sys pos and WCO because disabling motor
[I][PLAT]reset coordoffset
  • So with the offset required to work with the ray (I’m talking about having to enter “G10 L2 P1 X0 Y-400” into the console in Lightburn) my home and start position is X0, Y400 (upper left). If I set the move steps to 100mm and move Y-100 when it gets there it resets back to X0, Y400. Lightburn will show the position as X0, Y300 because it’s calculating the last move into the start position.
  • Now if I move along Y the same direction it will show X0, Y300.
  • If I move the opposite direction it will say X0, Y500.
  • If I move along X it will say X100, Y400.
  • If I move the opposite along X it will say X-100, Y400.
  • No matter where the head is in the bed, if I hit Get Position it will tell me X0, Y400 so it is indeed resetting after each move.
  1. When using the rotary with the IR module (which requires using the crosshair) it’s not aligning with the laser start position. When I set the crosshair exactly where I need it to be and start the burn the gantry doesn’t move to account for the crosshair offset. What’s more strange is once the burn is done the gantry moves back as if accounting for the crosshair offset. This means when I start a burn it starts burning on the edge tapering off the side of, let’s say, a cup rather than the gantry moving up and over to put the laser where the crosshair was located. Then when it finishes burn the edge of the cylinder the gantry moves the head’s crosshair to the location where it was incorrectly engraving.

I don’t know who I need to reach out to in order to get this addressed. I’ve attached the IR to the SM2 and it too has some really weird quirks itself like asking to calibrate but then when running a job that calibration meant nothing. You have to manually move the head to the job origin in order for it to burn the correct location. This is without using A>B which I also had trouble with. When I first got the IR and tested it on the SM2, I used their make something template and used the A>B and it worked perfect the first time. Now that I put it back on the SM2 to test a custom job and tried to A>B the work area the head took off and ended up in a completely wrong location. That’s when I had to find out I had to manually set the job origin location.

I feel like I’m either doing something completely wrong (I highly doubt but it’s not impossible) or the firmware for the IR is still in a beta 1.0 state. If it wasn’t truly ironed out before release then please work with me and I will do whatever I need to get this thing ready for primetime. Snapmaker machines are great but the pre-order and first run experience needs more polishing…critical feedback.

I’m afraid people are selling their machines and choosing to go with the multitude of other machines out there now that are unfortunately innovating significantly more in a shorter time.

Here is an example of the offset inconsistencies between Luban and Lightburn

Luban

Lightburn
Screenshot 2024-07-23 005455

Why are these two different and which one is actually correct? The numbers are so close and the crosshair lens is so large I cannot just measure it to find out unless I do it while the laser is installed, powered on and the crosshair is turned on.

Here is a link to the rotary issue in my GroPro studio if anyone is interested to see what it’s doing.

I am wondering why there is a M2 every time before program end, it means a reset so I am not wondering about the upcoming reset.

Is this processed in Lightburn and could be found in your gcode, correct?
Not familiar with lightburn but I think this could be a setting.

Anyway, I would suggest to set it up like in the lightburn guide or recently there was a official guide published:

https://wiki.snapmaker.com/en/general/manual/use_ray_with_lightburn_guide

Yes this is in Lightburn and there is a place where the start and end gcode can be edited. I too noticed this in the end code. I looked into the IBDEV files Snapmaker provided for both the 40w and 2wIR and the end code was only set in the newest 2wIR IBDEV file. I thought about taking it out but I’m going to wait for support to take a look at it. Just looking through the IBDEV files the most recent 2wIR files don’t really look…right? Not sure what the correct word would be. It doesn’t really compare to the other IBDEV files they’ve made. There shouldn’t be much difference between the modules.

Just so you know, I have an updated guide. :slight_smile: It was specifically for the IR, but it works flawlessly with the 40W as well, and the other lasers as long as you get your initial focus height correct.

1 Like

That’s a really good tutorial. Is there anything different than what is found in the IBDEV files? You can use Notepad++ to see what the settings are in the IBDEVs. This also lets you set your own macros in the console tab :sunglasses:

{
    "DeviceList": [
        {
            "Checklist": "",
            "DefaultCutList": [
            ],
            "DefaultToolCutList": [
            ],
            "DisplayName": "snapmaker-2.0-2W(1064nm)-v1",
            "EnableLaser2Offset": false,
            "EnableProcessOffset": true,
            "GUID": "jOGJkNTM1L",
            "Height": 350,
            "HomeOnStartup": false,
            "Info": "",
            "Laser2OffsetX": 0,
            "Laser2OffsetY": 0,
            "LastCamera": "",
            "LastDevLibraryPath": "",
            "MirrorX": false,
            "MirrorY": false,
            "Name": "Marlin",
            "ProcessOffsetX": 21.5,
            "ProcessOffsetY": -11,
            "ProfilePath": "Marlin",
            "ReverseIntervalCompensation": true,
            "ReverseIntervals": [
                {
                    "LineShift": 0.10000000149011612,
                    "Speed": 8.333333015441895,
                    "StartAdjust": 0
                },
                {
                    "LineShift": 0.10000000149011612,
                    "Speed": 16.66666603088379,
                    "StartAdjust": 0
                },
                {
                    "LineShift": 0.10000000149011612,
                    "Speed": 33.33333206176758,
                    "StartAdjust": 0
                },
                {
                    "LineShift": 0.10000000149011612,
                    "Speed": 66.66666412353516,
                    "StartAdjust": 0
                },
                {
                    "LineShift": 0.10000000149011612,
                    "Speed": 100,
                    "StartAdjust": 0
                }
            ],
            "Settings": {
                "AirAssistM7": false,
                "AlignH": 0,
                "AlignV": 2,
                "BaudRate": 115200,
                "Checklist": false,
                "CommPort": "COM5",
                "ContinuousFrame": false,
                "CutOrigin": 1,
                "DockState_ArtBrowser": false,
                "DockState_Camera": false,
                "DockState_Console": true,
                "DockState_CutLibrary": true,
                "DockState_LaserFiles": true,
                "DockState_Move": true,
                "DockState_ShapeProperties": true,
                "DockState_VariableText": false,
                "EnableBoundsCheck": false,
                "EnableDTR": false,
                "EnableGrblJCommand": false,
                "EnableU": false,
                "EnableUserFinish": false,
                "EnableZ": true,
                "EndGCode": "",
                "ForceSValueOutput": false,
                "GCodeClustering": false,
                "LaserFire_Enable": true,
                "LaserFire_Power": 0,
                "LaserFrame_Enable": false,
                "LastExportExt": "gc",
                "LastMachineFileExtension": "",
                "LastMachineFilePath": "C:/Users/congo/Desktop",
                "Macro0_Content": "M2002 T3 P1\n",
                "Macro0_Label": "Crosshair On",
                "Macro1_Content": "M2002 T3 P0\n",
                "Macro1_Label": "Crosshair Off",
                "Macro2_Content": "\n",
                "Macro2_Label": "-",
                "Macro3_Content": "\n",
                "Macro3_Label": "-",
                "Macro4_Content": "\n",
                "Macro4_Label": "-",
                "Macro5_Content": "\n",
                "Macro5_Label": "-",
                "MarlinToolIndex": 0,
                "MarlinUseInlinePower": false,
                "MarlinUseM3": true,
                "NegativeWorkspace": false,
                "NegativeZ": false,
                "OMTechPolar": false,
                "OptimizeZ": false,
                "RelativeZOnly": true,
                "S_Scale": 255,
                "Sim_CornerTolerance": 0.009999999776482582,
                "Sim_FastWhiteScan": false,
                "Sim_FastWhiteScanSpeed": 0,
                "Sim_GlobalFactor": 1,
                "Sim_MaxAccelX": 3000,
                "Sim_MaxAccelY": 3000,
                "Sim_MaxSpeedX": 500,
                "Sim_MaxSpeedY": 400,
                "Sim_MinCornerSpeed": 1,
                "Sim_RapidSpeed": 400,
                "Sim_ScanAccelX": 3000,
                "Sim_ScanAccelY": 3000,
                "Sim_SpeedFactor": 1,
                "SkipWhiteFlag": false,
                "SkipWhiteSpeed": 0,
                "StartGCode": ";header_type: laser\n:machine: artisan\n:gcode_flavor:marlin\n:max_power: 255\nM2000 L30 PO\nG4S5\n",
                "SwapXYOutput": false,
                "TabPulseWidth": 0.05000000074505806,
                "TransferMode": 0,
                "UseG0ForOverscan": false,
                "UserFinishX": 0,
                "UserFinishY": 0,
                "UserOriginX": 78.75,
                "UserOriginY": -74.05000305175781,
                "overwriteFileByDefault": false
            },
            "Type": "Serial",
            "Width": 320
        }
    ]
}

Or you can simply right click the macro button in Lightburn and it opens a window for customization. :wink:

I’ve always built my own profiles before they began offering any. The main difference is they keep changing the profile type, they did “snapmaker” then “GRBL” and now apparently “Marlin” (technically the snapmaker system in Marlin except the Ray, which is grbl). I always used grbl, which removes a lot of fluff and works fine, it just breaks the control buttons in Lightburn (as they’re using grbl specific $ commands which marlin doesn’t understand) I don’t use those buttons, however.

1 Like

Snapmaker Support has provided a solution for the rotary (I haven’t tried yet due to being at work). I will confirm this works later this afternoon.

Edit: Confirmed this will work until they create a permanent solution.



1 Like

It would be nice if they actually defined what those two lines do.

Indeed, it would be amazing if they gave the full M-xxxx list to us with what description of what each one does. From what I understand GBRL has a ton of “extra” code that can be issued proprietary and it seem Snapmaker is using a lot of it.