По совету присутствующего тут коллеги поигрался с разрядностями:
Оригинальная структура:
Сигнал 16 бит множится на 17 бит выход NCO, затем младшие 32 бита идут на CIC - выход которого (32 бит) на FIR.
Была попытка усечь на 10 бит вход CIC (ещё отбросить младшие 10 бит после умножения), с соответствующим изменением параметров данного блока в megawizard) - появилась постоянная составляющая на выходе CIC (где-то на -60 дБ от full scale, значение приблизительное).
Оригинальная структура:
Сигнал 16 бит множится на 17 бит выход NCO, затем младшие 32 бита идут на CIC - выход которого (32 бит) на FIR.
Была попытка усечь на 10 бит вход CIC (ещё отбросить младшие 10 бит после умножения), с соответствующим изменением параметров данного блока в megawizard) - появилась постоянная составляющая на выходе CIC (где-то на -60 дБ от full scale, значение приблизительное).
Из-за отсечения действительно должно создаваться смещение, хотя -60dB мне кажется многовато. Чтобы смещения не было, и обеспечить максимальную разрядность, можно использовать отсечение или округление с переносом всей ошибки в следующий такт и сложением с ошибкой из предыдущего такта. Типа дельта-сигма модуляции первого порядка.