A few issues with the qtdragon (Linuxcnc 2.9)
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
24 Sep 2022 16:06 #252666
by Eyecon
A few issues with the qtdragon (Linuxcnc 2.9) was created by Eyecon
Hello,
I've been away for a few weeks and I just cloned and compiled the latest version of linuxcnc 2.9. Here are a couple of issue that I noticed:
1) Tool window add/delete tool button no longer do anything
2) While I noticed that the probe routine error checking is now implemented, for some probe routines(e.g. ridges and valleys) the error is triggered(according to the debug messages) but it doesn't trigger a UI notification error until you try to run the routine again. For example: starting a ridge probing routing when the first part of the routine and having it fail(e.g. the probe completed reached the max distance without being triggered) just kills the rest of the routine which is great but doesn't produce any UI notifications. When you try and run it again, the error is triggered in the UI at that point. The same is not true for other routines, just reporting what I managed to try so far.
I've been away for a few weeks and I just cloned and compiled the latest version of linuxcnc 2.9. Here are a couple of issue that I noticed:
1) Tool window add/delete tool button no longer do anything
2) While I noticed that the probe routine error checking is now implemented, for some probe routines(e.g. ridges and valleys) the error is triggered(according to the debug messages) but it doesn't trigger a UI notification error until you try to run the routine again. For example: starting a ridge probing routing when the first part of the routine and having it fail(e.g. the probe completed reached the max distance without being triggered) just kills the rest of the routine which is great but doesn't produce any UI notifications. When you try and run it again, the error is triggered in the UI at that point. The same is not true for other routines, just reporting what I managed to try so far.
Please Log in or Create an account to join the conversation.
- cmorley
- Offline
- Moderator
Less
More
- Posts: 7777
- Thank you received: 2073
25 Sep 2022 02:31 #252693
by cmorley
Replied by cmorley on topic A few issues with the qtdragon (Linuxcnc 2.9)
Thanks for the report - pushed a fix for the buttons just now.
When the error shows late, does it abort the new routine or is it just the message post late?
When the error shows late, does it abort the new routine or is it just the message post late?
Please Log in or Create an account to join the conversation.
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
25 Sep 2022 10:16 - 25 Sep 2022 14:04 #252700
by Eyecon
Replied by Eyecon on topic A few issues with the qtdragon (Linuxcnc 2.9)
Thanks Chris!
Yes, so when it silently fails the first time and you try the same routine button, the message pops up at this time and the routine doesn’t run. So if first press=silent fail->2nd press=error message only, routine does not run->3rd press=restart the routine.
Yes, so when it silently fails the first time and you try the same routine button, the message pops up at this time and the routine doesn’t run. So if first press=silent fail->2nd press=error message only, routine does not run->3rd press=restart the routine.
Last edit: 25 Sep 2022 14:04 by Eyecon.
Please Log in or Create an account to join the conversation.
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
26 Sep 2022 17:52 #252793
by Eyecon
Replied by Eyecon on topic A few issues with the qtdragon (Linuxcnc 2.9)
Another issue with basic probing in addition to the error handling behavior:
In edge angle mode: 1) setting edge angle seems to offset the WCS origin to the last point probed regardless of the measurement mode when "set rotation angle" is selected 2)when "set rotation angle" and "auto zero" are selected, the WCS offsets seem to reset to zero.
In edge angle mode: 1) setting edge angle seems to offset the WCS origin to the last point probed regardless of the measurement mode when "set rotation angle" is selected 2)when "set rotation angle" and "auto zero" are selected, the WCS offsets seem to reset to zero.
Please Log in or Create an account to join the conversation.
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
26 Sep 2022 18:47 #252796
by Eyecon
Replied by Eyecon on topic A few issues with the qtdragon (Linuxcnc 2.9)
Also @cmorley, is there a place that I can lookup how the calibration function is supposed to work? I did my best to understand the routines from the prob_routines.py file but I can't figure out
Please Log in or Create an account to join the conversation.
- cmorley
- Offline
- Moderator
Less
More
- Posts: 7777
- Thank you received: 2073
28 Sep 2022 03:23 #252907
by cmorley
Replied by cmorley on topic A few issues with the qtdragon (Linuxcnc 2.9)
Sorry been very busy at work.
I'll try to find time to actually test the routines on a machine to see what you mean.
Which calibration routines?
I'll try to find time to actually test the routines on a machine to see what you mean.
Which calibration routines?
Please Log in or Create an account to join the conversation.
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
28 Sep 2022 04:30 #252909
by Eyecon
Replied by Eyecon on topic A few issues with the qtdragon (Linuxcnc 2.9)
no worries Chris, we all appreciate your work on qtdragon!
I was referring to the calibration page of the basic probe screen. I can't seem to figure out how I'm supposed to calibrate my probe offsets
I was referring to the calibration page of the basic probe screen. I can't seem to figure out how I'm supposed to calibrate my probe offsets
Please Log in or Create an account to join the conversation.
- cmorley
- Offline
- Moderator
Less
More
- Posts: 7777
- Thank you received: 2073
28 Sep 2022 04:50 #252911
by cmorley
Replied by cmorley on topic A few issues with the qtdragon (Linuxcnc 2.9)
I think I got the late error message fixed - pushed to master.
The following user(s) said Thank You: Eyecon
Please Log in or Create an account to join the conversation.
- Eyecon
- Offline
- Senior Member
Less
More
- Posts: 79
- Thank you received: 17
28 Sep 2022 17:26 #252956
by Eyecon
Replied by Eyecon on topic A few issues with the qtdragon (Linuxcnc 2.9)
Thanks Chris, I ran a few tests with the new code on my sim machine and the fixes work perfectly!
If you are able to provide more clarity on the edge angle probing mechanism/logic that would be great. The issue I've observed are as follows:
1) setting edge angle seems to offset the WCS origin to the last point probed regardless of the measurement mode when "set rotation angle" is selected. For example when selecting the corner y plus edge angle routing, the XY origin is always shifted to the point where the probe made last contact.
2)when "set rotation angle" and "auto zero" are selected, the WCS offsets seem to reset to zero.
Also if you are able to provide some clarity on how the calibration page of the basic probe is supposed to be used that would be great!
Thanks for everything!!
If you are able to provide more clarity on the edge angle probing mechanism/logic that would be great. The issue I've observed are as follows:
1) setting edge angle seems to offset the WCS origin to the last point probed regardless of the measurement mode when "set rotation angle" is selected. For example when selecting the corner y plus edge angle routing, the XY origin is always shifted to the point where the probe made last contact.
2)when "set rotation angle" and "auto zero" are selected, the WCS offsets seem to reset to zero.
Also if you are able to provide some clarity on how the calibration page of the basic probe is supposed to be used that would be great!
Thanks for everything!!
Please Log in or Create an account to join the conversation.
- cmorley
- Offline
- Moderator
Less
More
- Posts: 7777
- Thank you received: 2073
29 Sep 2022 02:11 #252978
by cmorley
Replied by cmorley on topic A few issues with the qtdragon (Linuxcnc 2.9)
I didn't make the basic probe routines Jim. Qtdragons creator did that work.
I adapted Versa probe over but Jim has since worked on both.
So what I am saying is - I don't know much about them.
But looking at the code (basic probe and probe routines):
rotate_coord_system() function requires a setting 'allow_auto_skew' which doesn't seem to be settable in basic probe (versa probe has a button for it)
calibrate round boss:It takes the probe calibration diameter entry number
probes it twice and sets 'Delta' on the screen
My guess is probing a (for instance) bearing diameter and using it as a standard to test the probing accurac.
Delta can be x offset, y offset or average of x and y - depending on the buttons selected.
calibration offset entry is used to compensate? the calculation of delta.
code is here:
I adapted Versa probe over but Jim has since worked on both.
So what I am saying is - I don't know much about them.
But looking at the code (basic probe and probe routines):
rotate_coord_system() function requires a setting 'allow_auto_skew' which doesn't seem to be settable in basic probe (versa probe has a button for it)
calibrate round boss:
def probe_cal_round_pocket(self):
self.data_side_edge_length = self.data_cal_diameter / 2
error = self.probe_xy_hole()
if error != 1: return error
# repeat but this time start from calculated center
error = self.probe_xy_hole()
if error != 1: return error
self.status_delta = self.get_new_offset('r')
return error
probes it twice and sets 'Delta' on the screen
My guess is probing a (for instance) bearing diameter and using it as a standard to test the probing accurac.
Delta can be x offset, y offset or average of x and y - depending on the buttons selected.
calibration offset entry is used to compensate? the calculation of delta.
code is here:
def get_new_offset(self, shape):
if shape == 'r':
base_x = base_y = self.data_cal_diameter
elif shape == 's':
base_x = self.data_cal_x_width
base_y = self.data_cal_y_width
else: return 0
xcal_error = abs(base_x - self.status_lx)
if base_x > self.status_lx:
newx_offset = self.data_calibration_offset - xcal_error
else:
newx_offset = self.data_calibration_offset + xcal_error
ycal_error = abs(base_y - self.status_ly)
if base_y > self.status_ly:
newy_offset = self.data_calibration_offset - ycal_error
else:
newy_offset = self.data_calibration_offset + ycal_error
new_cal_avg = (newx_offset + newy_offset) / 2
if self.cal_x_error is True: return newx_offset
elif self.cal_y_error is True: return newy_offset
else: return new_cal_avg
Please Log in or Create an account to join the conversation.
Moderators: cmorley
Time to create page: 0.079 seconds