# Source code for deltasigma._ds_freq

# -*- coding: utf-8 -*-
# _ds_freq.py
# This module provides the ds_freq 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.

"""This module provides the ds_freq() function, used to generate a frequency
vector suitable for plotting the frequency response of an NTF.
"""

from __future__ import division

import numpy as np

[docs]def ds_freq(osr=64., f0=0., quadrature=False):
"""Frequency vector suitable for plotting the frequency response of an NTF
"""
f_left = -0.5
f_special = (f0, -f0)
else:
f_left = 0.
f_special = (f0, )
f = np.linspace(f_left, 0.5, num=100)
# Use finer spacing in the vicinity of the passband
for fx in f_special:
f1 = max(f_left, fx - 1./osr)
f2 = min(0.5, fx + 2./osr)
dels = np.where(np.logical_and(f <= f2, f >= f1))
f = np.delete(f, dels)
f = np.sort(np.concatenate((f, np.linspace(f1, f2, num=100))))
return f