On 02/28/2018 12:06 PM, Stern, Joseph via USRP-users wrote:

I have a couple specific questions I am hoping someone can answer, after this FYI:

I finally found the level of block diagram I wanted when Googling for "ettus ddc undersampling." On the page, http://www.analog.com/en/products/rf-microwave/integrated-transceivers-transmitters-receivers/wideband-transceivers-ic/ad9361.html, I came across the link to https://github.com/analogdevicesinc/iio-oscilloscope/blob/master/block_diagrams/AD9361.svg. This clearly shows the functionality I was trying to describe in my previous post; I believe that, if HB3 is disabled, this diagram matches the B200mini exactly.

So, what is the maximum decimation that the B200mini can perform?

You generally don't need to worry about how many stages of decimation are involved, except when there's some half-band rolloff at odd decimations. You simply ask UHD for the desired sample-rate, and it arranges everything under the covers. But you can certainly get very high effective decimation values by fixing the master-clock rate (which basically sets the ADC sample rate), at some high value, like 40MHz, and then asking for a low
  sample-rate, like 250kHz.

The samples are already complex-baseband by the time the AD9361 as dealt with them, so I'm not sure that I understand your final question below.

I'm getting the impression (and PLEASE correct me if I'm wrong), that this may turn into what we call an "X-Y" type question. You have a problem, X, and rather than describe that problem, you've already decided that 'Y' (or understanding Y) is the right solution, and are asking about 'Y' instead.

Are you concerned that the B210 doesn't "correctly" produce samples at the correct (decimated) rate? Do you have some very-special requirement that causes you to understand the B210 internal signal-processing chain in agonizing detail? (If so, I'll point out that the DSP chain within the B210 has changed considerably several times in its lifecycle, so getting a "at the molecular level" understanding of it may be a fleeting thing).


And, is undersampling performed at the final stage, in order to send baseband samples to the host?

------------------------------------------------------------------------
*From:* USRP-users [usrp-users-boun...@lists.ettus.com] on behalf of Stern, Joseph via USRP-users [usrp-users@lists.ettus.com]
*Sent:* Wednesday, February 28, 2018 8:28 AM
*To:* usrp-users@lists.ettus.com
*Subject:* Re: [USRP-users] USRP-users help needed

Thank you all for your help. I have been going through both the FPGA and host-side driver code for the B200mini and, in my still very limited understanding of SDRs in general, have come up with the following DDC chain:

 1. multiplex 12-bit I and Q into 24-bit value
 2. phase align with the NCO
 3. use the CORDIC functionality to perform the down-shifting math to
    some IF or possibly baseband
 4. apply the CIC algorithm to FIR filter and decimate
 5. apply up to two half band filters, further decimating
 6. clip I and Q by one bit due to the potential, maximum gain in the
    previous algorithms

I discovered the following:

  * using an even (or unit) decimation prevents CIC rolloff
  * two half band filters (abbreviated hb0 and hb1 in the Verilog and
    C++ code) are available, and each one decimates by a factor of two
  * (half band filters are used as LPFs, when the signal is shifted
    all the way down to baseband)
  * the only data being poked into the USRP interface are { hb0
    enabled, hb1 enabled, remaining decimation }

I'm sure you have spotted several misunderstandings in the above. I'm still fuzzy on why the decimation is being set the way that it is. It feels like the host-side driver code independently calculates all the filter and decimation properties that will be reflected on the FPGA side. Please feel free to clarify for me the down-shifting and the inherent decimation when using half band filters (and anything I am completely oblivious to).

Thanks again for your help and guidance.

------------------------------------------------------------------------
*From:* USRP-users [usrp-users-boun...@lists.ettus.com] on behalf of Marcus D. Leech via USRP-users [usrp-users@lists.ettus.com]
*Sent:* Monday, February 26, 2018 1:20 PM
*To:* usrp-users@lists.ettus.com
*Subject:* Re: [USRP-users] USRP-users help needed

On 02/26/2018 12:07 PM, Stern, Joseph via USRP-users wrote:

Dear USRP users:

We have been trying to understand the low-level details of the USRP architecture (namely, for the B200mini); there seems very little explicit insight provided on the Ettus web site into how decimation is performed in the FPGA (and commanded from the driver side). I also cannot locate the open-source and freely available FPGA code. Could someone assist me in gaining this insight?

Thank you very much!

Joe Stern

Ettus don't provide detailed design documents, but the source-code, as you say, is freely available:

Get the source from here:

https://github.com/EttusResearch/uhd

The do a "git submodule init"

The source bits of source code are somewhat separate, the the FPGA source code being a GIT sub-module.

In terms of "how is decimation commanded", that's the host-side driver in setting sample rates. The job is divided between the capabilities of the AD9361 chip, and the FPGA. In many cases, almost the entirety of decimation/filtering is done inside the AD9361 chip, since it effectively has an internal ADC that samples at 750Msps (can't remember the precise number), and the sample rate offered on its data interface is relatively to that, so in many cases, there is NO decimation performed within the FPGA. This is all in the source code a shown above.


This message and any enclosures are intended only for the addressee. Please notify the sender by email if you are not the intended recipient. If you are not the intended recipient, you may not use, copy, disclose, or distribute this message or its contents or enclosures to any other person and any such actions may be unlawful. Ball reserves the right to monitor and review all messages
and enclosures sent to or from this email address.


_______________________________________________
USRP-users mailing list
USRP-users@lists.ettus.com
http://lists.ettus.com/mailman/listinfo/usrp-users_lists.ettus.com

This message and any enclosures are intended only for the addressee. Please notify the sender by email if you are not the intended recipient. If you are not the intended recipient, you may not use, copy, disclose, or distribute this message or its contents or enclosures to any other person and any such actions may be unlawful. Ball reserves the right to monitor and review all messages
and enclosures sent to or from this email address.
This message and any enclosures are intended only for the addressee. Please notify the sender by email if you are not the intended recipient. If you are not the intended recipient, you may not use, copy, disclose, or distribute this message or its contents or enclosures to any other person and any such actions may be unlawful. Ball reserves the right to monitor and review all messages
and enclosures sent to or from this email address.


_______________________________________________
USRP-users mailing list
USRP-users@lists.ettus.com
http://lists.ettus.com/mailman/listinfo/usrp-users_lists.ettus.com

_______________________________________________
USRP-users mailing list
USRP-users@lists.ettus.com
http://lists.ettus.com/mailman/listinfo/usrp-users_lists.ettus.com

Reply via email to