Getting started with 6i25+7i75+7i85s
- PCW
- 
				  
- Online
- Moderator
- 
				  
		Less
		More
		
			
	
		- Posts: 17345
- Thank you received: 5053
			
	
						13 Oct 2024 20:31				#312005
		by PCW
	
	
		
			
	
			
			 		
													
	
				Replied by PCW on topic Getting started with 6i25+7i75+7i85s			
			
				If you can jog Z faster than 150 mm/m the likely culprit
is the spindle encoder or spindle encoder interface.
(that is, it's probably not Z that has the issue but
encoder mis-counting above a certain RPM)
The lack of spindle sync also suggests encoder issues.
You might do some basic encoder checks:
Is the encoder RPM correct at all speeds?
If you enable quadrature error checking, do you ever get errors?
if you check the index, does it always zero the position and the index location?
 			
					is the spindle encoder or spindle encoder interface.
(that is, it's probably not Z that has the issue but
encoder mis-counting above a certain RPM)
The lack of spindle sync also suggests encoder issues.
You might do some basic encoder checks:
Is the encoder RPM correct at all speeds?
If you enable quadrature error checking, do you ever get errors?
if you check the index, does it always zero the position and the index location?
Please Log in or Create an account to join the conversation.
- Kirvesmies
- Offline
- New Member
- 
				  
		Less
		More
		
			
	
		- Posts: 10
- Thank you received: 0
			
	
						15 Oct 2024 18:06				#312187
		by Kirvesmies
	
	
		
			
	
	
			
			 		
													
	
				Replied by Kirvesmies on topic Getting started with 6i25+7i75+7i85s			
			
				Spindle speed feedback is correct for any rpm, though erratic, as seen in the screenshot. (100 rpm)
What's quadrature error checking? I did try adding FERROR to to the spindle, but that does seem to do anything, even if the spindle gets stalled.
Which pins exactly should it zero? It does not zero spindle.0.revs at least.
In the second screenshot, you can see the perhaps relevant signals when the photogate is a the index position. When moved, hm2_5i25.0.encoder.02.input-index changes, but the other ones do not.
I do have
					What's quadrature error checking? I did try adding FERROR to to the spindle, but that does seem to do anything, even if the spindle gets stalled.
Which pins exactly should it zero? It does not zero spindle.0.revs at least.
In the second screenshot, you can see the perhaps relevant signals when the photogate is a the index position. When moved, hm2_5i25.0.encoder.02.input-index changes, but the other ones do not.
I do have
In the hal file, but clearly it does not nothing since hm2_5i25.0.encoder.02.index-enable does not change state when the index is active. Is this where my problem lies?net spindle-index-enable <=> hm2_5i25.0.encoder.02.index-enable
net spindle-index-enable <=> spindle.0.index-enable
Please Log in or Create an account to join the conversation.
- Kirvesmies
- Offline
- New Member
- 
				  
		Less
		More
		
			
	
		- Posts: 10
- Thank you received: 0
			
	
						15 Oct 2024 18:35				#312190
		by Kirvesmies
	
	
		
			
	
			
			 		
													
	
				Replied by Kirvesmies on topic Getting started with 6i25+7i75+7i85s			
			
				Found the problem now lol. My encoder and spindle index are connected through an original pcb within the spindle housing, and I got my wires crossed and read the index coming from the encoder, which is connected with a 3:1 ratio, giving me 3 index pulses per spindle revolution.
That's that mystery. I will see if fixing that also takes care of the low maximum speed.
					That's that mystery. I will see if fixing that also takes care of the low maximum speed.
Please Log in or Create an account to join the conversation.
- PCW
- 
				  
- Online
- Moderator
- 
				  
		Less
		More
		
			
	
		- Posts: 17345
- Thank you received: 5053
			
	
						15 Oct 2024 19:48				#312195
		by PCW
	
	
		
			
	
			
			 		
													
	
				Replied by PCW on topic Getting started with 6i25+7i75+7i85s			
			
				OK glad that's at least partially sorted out.
Note that the index signal does nothing unless index enable is set true
(LinuxCNC sets index enable true when it wants to search for index)
You can test index operation by hand running LinuxCNC, and
halcmd sets spindle-index-enable true
Then rotating the spindle by hand. When the index is detected, 2 things should happen:
1. spindle-index-enable should change to false
2. the spindle position should be set to 0
					Note that the index signal does nothing unless index enable is set true
(LinuxCNC sets index enable true when it wants to search for index)
You can test index operation by hand running LinuxCNC, and
halcmd sets spindle-index-enable true
Then rotating the spindle by hand. When the index is detected, 2 things should happen:
1. spindle-index-enable should change to false
2. the spindle position should be set to 0
Please Log in or Create an account to join the conversation.
- Kirvesmies
- Offline
- New Member
- 
				  
		Less
		More
		
			
	
		- Posts: 10
- Thank you received: 0
			
	
						17 Oct 2024 10:15				#312353
		by Kirvesmies
	
	
		
			
	
			
			 		
													
	
				Replied by Kirvesmies on topic Getting started with 6i25+7i75+7i85s			
			
				I connected the correct index and the machine threads beautifully with no problems when restarting a program or running at higher speed.
I still have another complication with the encoder, though. As it has quite a high resolution for the application (I don't know why they used such a high-resolution encoder and made it even higher with the 3:1 transmission), the pulse frequency maxes out at about 2200 rpm, after which no signal is sent. This of course means that linuxcnc stops feeding motions, since it reads the spindle speed at 0.
The problem would be easily solved if I could tell linuxcnc that beyond, say, 2000 prm of commanded spindle speed, it would switch to reading the speed from the index.
But I am also considering removing the encoder and installing an encoder disk directly on the spindle. The belt does not track too well anyway and makes some extra noise. A couple hundred ppr should be plenty for threading, so I'm not really losing anything by lowering the resolution, right? I doubt I would ever be doing indexing on the machine, as there is no spindle brake and it is driven by a pretty flimsy v-belt.
					I still have another complication with the encoder, though. As it has quite a high resolution for the application (I don't know why they used such a high-resolution encoder and made it even higher with the 3:1 transmission), the pulse frequency maxes out at about 2200 rpm, after which no signal is sent. This of course means that linuxcnc stops feeding motions, since it reads the spindle speed at 0.
The problem would be easily solved if I could tell linuxcnc that beyond, say, 2000 prm of commanded spindle speed, it would switch to reading the speed from the index.
But I am also considering removing the encoder and installing an encoder disk directly on the spindle. The belt does not track too well anyway and makes some extra noise. A couple hundred ppr should be plenty for threading, so I'm not really losing anything by lowering the resolution, right? I doubt I would ever be doing indexing on the machine, as there is no spindle brake and it is driven by a pretty flimsy v-belt.
Please Log in or Create an account to join the conversation.
- PCW
- 
				  
- Online
- Moderator
- 
				  
		Less
		More
		
			
	
		- Posts: 17345
- Thank you received: 5053
			
	
						17 Oct 2024 17:48				#312418
		by PCW
	
	
		
			
	
			
			 		
													
	
				Replied by PCW on topic Getting started with 6i25+7i75+7i85s			
			
				If the index had a high enough duty cycle that you could use the software encoder
you could use a little hal magic to switch the RPM source from hardware encoder to
index only software encoder at some specific commanded RPM.
					you could use a little hal magic to switch the RPM source from hardware encoder to
index only software encoder at some specific commanded RPM.
Please Log in or Create an account to join the conversation.
- Kirvesmies
- Offline
- New Member
- 
				  
		Less
		More
		
			
	
		- Posts: 10
- Thank you received: 0
			
	
						20 Oct 2024 13:49				#312674
		by Kirvesmies
	
	
		
			
	
			
			 		
													
	
				Replied by Kirvesmies on topic Getting started with 6i25+7i75+7i85s			
			
				I played around with an oscilloscope, and it turns out the encoder outputs pulses just fine regardless of exceeding the maximum frequency described by the datasheet.
So I set the encoder filter to 0, and now it reads the rpm correctly.
					So I set the encoder filter to 0, and now it reads the rpm correctly.
Please Log in or Create an account to join the conversation.
		Moderators: cmorley	
		Time to create page: 0.090 seconds	
 
													 
	