 gagamehl
		
			gagamehl
		
		
		
		
		
		
		
		
	
			03-23-2018 06:06 AM
Hi everybody,
I have an external encoder wired to a 9423 module on a 9185 chassis, where i count the impulses of the encoder using channel A and B.
I also have some sensors connected to a 9205 analog Input module. Now I want to use the counter as a sample clock on the PFI on the 9205 module. So basically I have to route the counter signal to the PFI. At least I think that is the best approach. No idea how though. Probably easy with LabView, however I am not using it. Instead I am using Matlab or VS\C++.
If I connect one channel (A or B) ´from the encoder to PFI on the 9205, I can set up the clock without a problem as an external clock connection. Then I wait until x-samples are gathered and execute some functions.
So basically my question is, if it is possible to use the counter from the digital input module (I have an output module too, it that helps) as a means of controlling the sampling rate of the analog module? Or am I looking at this wrong?
Here the basic set up in Matlab, if it will do any good.
s = daq.createSession('ni'); % Create session
ch1 = s.addAnalogInputChannel('cDAQ9185-1C7CD64Mod1','ai0', 'Voltage'); % analog Input channel
cc = addClockConnection (s,'External','cDAQ9185-1C7CD64Mod1/PFI0','ScanClock'); % set an external clock (e.g. channel A from the encoder)
Cheers
Solved! Go to Solution.
 Kevin_Price
		
			Kevin_Price
		
		
		
		
		
		
		
		
	
			03-23-2018 08:28 AM
I don't know that much about internal wiring options on the cDAQ, but you could always just parallel wire one of the A,B channels to both modules externally.
-Kevin P
03-26-2018 01:50 AM
I could, and basically that is how it is set up right now. Using the PFI Input on the 9205. However I actually wanted to use the internal counter from the DI module as a trigger source. Not only as a start trigger, but as a continous trigger (like an external clock)
 Kevin_Price
		
			Kevin_Price
		
		
		
		
		
		
		
		
	
			03-28-2018 08:26 AM
Sure, you can generate a pulse train from another counter and use it as an AI sample clock in the other module. I don't know if you can route the clock signal internally or whether you'll need to do physical wiring.
Often, using the pulse train as a sample clock is enough by itself. Start triggering the AI task may not be necessary.
-Kevin P
04-26-2018 06:27 AM
First of all thanks for your answers. I was out of office for quite some time, but now I should be able to focus on the task at hand. That for sure will require some patience, as I am still trying to figure out, what is possible and what is not. And also what the best solution in my case is.
Some things probably are easy to achive in LabView, however I am a bloody beginner on this topic. That's why I am using Matlab, as mentioned before.
What I can do so far:
If that is the best way to achieve my goal, so be it. Then the counter basically only is used for the distance measurement and there is no need for my DO module at all. My original idea was to convey the "ticks" of the counter (1,2,3,...) to the DO module (NI 9474) and from there link it with the 9205 module.
Well, of course I can set a pulse train on my DO module, however as I understand it, only with a given frequency. The impulses of my encoder come as they like. For experimental reasons, I tried it anyway. I then linked the blinking DO with the PFI0 of the analogue module (just like I did it with channel A from the Encoder), to no avail. I expected it to acquire analogue data with the set frequency.
I apologize if my post seems a bit confused to you. In fact I am. At the beginning the range of opportunities can be a bit overwhelming. Maybe I have to take a look into LabView, as internal routing seems straight forward there.
04-26-2018 07:24 AM
I made one slight modification. There was no need to physically connect a wire to the PFI0 on the analogue module.
My Destination of my clock Connection is already connected to the DI module, therefore I just use that. Pretty obvious in retrospect
For now, the system cannot distinguish between directions. It just Counts flanks. In order to achieve this I would need channel B too. Therefore the counter would come in handy.
In Matlab that looks as follows:
cc = addClockConnection (s,'External','cDAQ9185-1C7CD64Mod2/PFI0','ScanClock'); % Mod2 is the DI module
 Kevin_Price
		
			Kevin_Price
		
		
		
		
		
		
		
		
	
			04-26-2018 09:31 AM
I think I need a little more "big picture" description about your end goal.
What are the sensors you're measuring? What do the measurements mean for you? Are you also generating signals in response? What important about the timing relationships among all the inputs and any outputs?
So far I gather that you have an encoder and an analog signal. As you've found, you can use the digital encoder signals as an external sample clock for your analog task. I don't follow what mean about "conveying ticks of the counter (1,2,3,...) to DI and AI modules".
The numerical count value is distinct from the TTL signals that the counter task uses to increment the count value. The count value cannot be routed (conveyed) as though it were a hardware signal. If you want to react at a specific count value, that would have to happen through software. In order to get a faster response, you'd have to run a fast software loop that kept querying the count value and deciding what to do about it.
-Kevin P
04-27-2018 04:50 AM
Your last paragraph explains quite a lot. A misconception was, that I can use the count value in order to generate signals (pulses) on the DO module and then use that as my sample clock.
I will try to answer your questions:
I have several laser distance sensors which continously send the measured analogue values to the NI module. The acquisiton of the data is controlled by a rotary encoder. So basically every sampled value of the laser sensors corresponds to a specific encoder position. It should sample only in one direction though.
I am not generating any signals in response.
The sensor values should be sampled simultaneously.
The solution for me right now is acceptable. The direction issue I can solve through software using the counter value. I just wondered if it was possible using the DO module.
Cheers
 Kevin_Price
		
			Kevin_Price
		
		
		
		
		
		
		
		
	
			04-27-2018 03:59 PM - edited 04-27-2018 04:02 PM
Since it sounds like you have a quadrature encoder (you referenced channels A & B), there's a neat trick that might work for you.
If you look carefully at a quadrature pattern, you'll find that for one direction of rotation, rising edges on A occur when B is low. For the other direction of rotation, rising edges on A occur when B is high.
So for your analog input task, you could use rising edges of channel A as a sample clock while using the digital state of channel B as a "Pause Trigger." With a Pause Trigger, sampling is enabled/disabled based on the digital state of the trigger signal.
- Kevin P
04-30-2018 03:56 AM
I indeed have a quadrature encoder and yes, your idea with the pause trigger works like a charm.
There doesn't seem to be a proper command for the pause trigger in Matlab, though. However it is really no problem to implement it in C++, for instance. As I only use Matlab for optimization it doesn't really concern me any further.
Big thanks for the input and I consider this topic as solved (for now ;))