Source code for ltfatpy.fourier.fftreal

# -*- coding: utf-8 -*-
# ######### COPYRIGHT #########
# Credits
# #######
#
# Copyright(c) 2015-2018
# ----------------------
#
# * `LabEx Archimède <http://labex-archimede.univ-amu.fr/>`_
# * `Laboratoire d'Informatique Fondamentale <http://www.lif.univ-mrs.fr/>`_
#   (now `Laboratoire d'Informatique et Systèmes <http://www.lis-lab.fr/>`_)
# * `Institut de Mathématiques de Marseille <http://www.i2m.univ-amu.fr/>`_
# * `Université d'Aix-Marseille <http://www.univ-amu.fr/>`_
#
# This software is a port from LTFAT 2.1.0 :
# Copyright (C) 2005-2018 Peter L. Soendergaard <peter@sonderport.dk>.
#
# Contributors
# ------------
#
# * Denis Arrivault <contact.dev_AT_lis-lab.fr>
# * Florent Jaillet <contact.dev_AT_lis-lab.fr>
#
# Description
# -----------
#
# ltfatpy is a partial Python port of the
# `Large Time/Frequency Analysis Toolbox <http://ltfat.sourceforge.net/>`_,
# a MATLAB®/Octave toolbox for working with time-frequency analysis and
# synthesis.
#
# Version
# -------
#
# * ltfatpy version = 1.0.16
# * LTFAT version = 2.1.0
#
# Licence
# -------
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program 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
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
# ######### COPYRIGHT #########


"""Module of FFT for real valued data computation

Ported from ltfat_2.1.0/fourier/fftreal.m

.. moduleauthor:: Florent Jaillet
"""

from __future__ import print_function, division

import numpy as np


[docs]def fftreal(f, N=None, dim=0): """FFT for real valued input data - Usage: | ``c = fftreal(f)`` | ``c = fftreal(f, N, dim)`` - Input parameters: :param numpy.ndarray f: Real valued input array :param int N: FFT length :param int dim: Axis over which to compute the FFT. By default the first axis is used. - Output parameters: :returns: Discrete Fourier coefficients of **f** for positive frequencies :rtype: numpy.ndarray ``fftreal(f)`` computes the coefficients corresponding to the positive frequencies of the FFT of the real valued input signal **f**. The function takes the same arguments as :func:`numpy.fft.rfft`. See the help on this function for a thorough description. .. note:: This Python port doesn't use the C core of LTFAT to implement the FFT for real arrays as in the Octave version. Instead it direclty uses the implementation available in numpy. This can lead to sightly different results when comparing the results of the Octave and Python versions of fftreal. .. seealso:: :func:`~ltfatpy.fourier.ifftreal.ifftreal`, :func:`~ltfatpy.fourier.dft.dft` """ # Note: There is a bug in fftreal in ltfat 2.1.0 for Octave. It has been # reported and confirmed here: # http://sourceforge.net/p/ltfat/bugs/118/ # This Python port is not subject to this bug. return np.fft.rfft(f, N, dim)