LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Converting paralel data into serial from FIFO

Solved!
Go to solution

Greetings!

 

 

I have an input stream of an array[2] of U32 coming from a FIFO which is being serially converted and written to another FIFO of U32 datatype, one element at a time. I would like to expand my data bus to an input array[8] of U32 (increasing the no. of elements to 8 from 2). But I am unable to figure how to serially convert it and then write it element by element.

 

ZainAli02_0-1721028515250.png

The Expand Pulse sub VI simply expands the impulse to ensure that it gives 2 valid bits when the input to it is changed from 'T' to 'F', ensuring that both elements of the array can be written to the new FIFO. I have already expanded this logic to give me a pulse of 8 valid bits. Here's the ExpandPulse2 Sub VI:

ZainAli02_1-1721028678627.png

 

And here's the 8 bit version of it:

ZainAli02_2-1721028724240.png

 

 

0 Kudos
Message 1 of 6
(9,814 Views)

I have implemented it by reading the first element and then rotating the array (i.e to delete the first element and append it at the end of the array) over 8 iterations. Here's a snapshot of it, if anyone else is able to come up with a better solution, feel free to post it.

ZainAli02_0-1721051914598.png

 

 

0 Kudos
Message 2 of 6
(9,769 Views)
Solution
Accepted by ZainAli02

That array rotating sounds utterly inefficient. Why not just incrementing an index in a feedback node that is then applied to the Index Array Element without the loop?

 

Also it all feels a bit asynchronous. Are you sure there is not a new VI::DDC_IQ array coming in before the 8 VI::DDQ_IQ_U32 elements have been generated?

Rolf Kalbermatter
My Blog
Message 3 of 6
(9,761 Views)

I'm really not understanding what you are trying to do here.  In the end, your code is just sending the last element.  If you are trying to send all of the elements one at a time, then your FIFO Write should be inside of a FOR loop using the autoindexing tunnel for the element to write.


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
Message 4 of 6
(9,744 Views)

@rolfk wrote:

That array rotating sounds utterly inefficient. Why not just incrementing an index in a feedback node that is then applied to the Index Array Element without the loop?


Thank you, sir! I'm not sure why my brain couldn't come up with that, it's more efficient. I have implemented it with a counter which resets the index when it reaches 8 and it works perfectly!

 


@rolfk wrote:

Also it all feels a bit asynchronous. Are you sure there is not a new VI::DDC_IQ array coming in before the 8 VI::DDQ_IQ_U32 elements have been generated?


Yes, no new array will be coming in unless all of the previous 8 samples have been read, the handshake ensure that. 

0 Kudos
Message 5 of 6
(9,675 Views)

@crossrulz wrote:

I'm really not understanding what you are trying to do here.  In the end, your code is just sending the last element.  If you are trying to send all of the elements one at a time, then your FIFO Write should be inside of a FOR loop using the autoindexing tunnel for the element to write.


I wanted to read the 8 samples from the first FIFO and then write them one at a time into a new FIFO (sort of converting it from parallel into serial). I suppose putting the FIFO in FOR loop works as well. Thank you for your reply!

0 Kudos
Message 6 of 6
(9,670 Views)