Source code for deltasigma._mapQtoR
# -*- coding: utf-8 -*-
# _mapQtoR.py
# Module providing the mapQtoR function
# Copyright 2013 Giuseppe Venturini
# This file is part of python-deltasigma.
#
# python-deltasigma is a 1:1 Python replacement of Richard Schreier's
# MATLAB delta sigma toolbox (aka "delsigma"), upon which it is heavily based.
# The delta sigma toolbox is (c) 2009, Richard Schreier.
#
# python-deltasigma is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# LICENSE file for the licensing terms.
"""Module providing the mapQtoR() function
"""
from __future__ import division
import numpy as np
[docs]def mapQtoR(ABCD):
"""Map a quadrature ABCD matrix to a real one.
Each element z in ABCD is replaced by a 2x2 matrix in ``ABCDr``, the
return value.
Specifically:
.. math::
z \\rightarrow
\\begin{bmatrix}
x & -y \\\\
y & x \\\\
\\end{bmatrix}
\\mathrm{where}\\ x = Re(z)\\ \\mathrm{and}\\ y = Im(z)
The non-quadrature topology can be simulated with :func:`simulateDSM`.::
import numpy as np
from deltasigma import *
nlev = 9
f0 = 1./16.
osr = 32
M = nlev - 1
ntf = synthesizeQNTF(4, osr, f0, -50, -10)
N = 64*osr
f = int(np.round((f0 + 0.3*0.5/osr)*N)/N)
u = 0.5*M*np.exp(2j*np.pi*f*np.arange(N))
# Instead of calling simulateQDSM
# v = simulateQDSM(u, ntf, nlev)
# it's faster to run:
ABCD = realizeQNTF(ntf, 'FF')
ABCDr = mapQtoR(ABCD)
ur = np.vstack((np.real(u), np.imag(u)))
vr = simulateDSM(ur, ABCDr, nlev*np.array([[1],[1]]))
v = vr[0,:] + 1j*vr[1, :]
Notice the example above requires the function :func:`synthesizeQNTF`,
which is not part of the current release of python-deltasigma.
"""
A = np.zeros((2*ABCD.shape[0], 2*ABCD.shape[1]))
A[::2, ::2] = np.real(ABCD)
A[1::2, 1::2] = np.real(ABCD)
A[::2, 1::2] = -np.imag(ABCD)
A[1::2, ::2] = +np.imag(ABCD)
return A