coder.fftw.StandaloneFFTW3Interface class

Пакет: coder.fftw
Суперклассы:

Абстрактный класс для определения библиотеки FFTW для FFTW вызывает в сгенерированном коде

Описание

coder.fftw.StandaloneFFTW3Interface абстрактный класс для определения класса коллбэка библиотеки FFT. Класс коллбэка библиотеки FFT задает библиотеку FFT, чтобы использовать для кода C/C++, сгенерированного для MATLAB® функции быстрого преобразования Фурье. Чтобы задать класс коллбэка БПФ для библиотеки FFTW, версии 3.2 или позже, используют coder.fftw.StandaloneFFTW3Interface класс. Например, чтобы задать класс коллбэка библиотеки FFT с именем useMyFFTW, сделайте эту линию первой линией вашего файла определения класса:

classdef useMyFFTW < coder.fftw.StandaloneFFTW3Interface
Для получения информации о библиотеке FFTW смотрите www.fftw.org.

Функции быстрого преобразования Фурье MATLAB включают fft, fft2, fftn, ifft, ifft2, и ifftn. Генератор кода производит призывы библиотеки FFTW к этим функциям, когда все эти условия верны:

  • Вы генерируете автономный код C/C++ (статическая библиотека, динамически подключаемая библиотека или исполняемая программа) с MATLAB Coder™ или генерируете код C/C++ от блока MATLAB Function с Simulink® Кодер.

  • У вас есть доступ к установке библиотеки FFTW, версии 3.2 или позже.

  • Вы задаете установку библиотеки FFTW в классе коллбэка библиотеки FFT, который выводит из coder.fftw.StandaloneFFTW3Interface.

  • Вы устанавливаете соответствующий параметр конфигурации на имя класса коллбэка.

    • Для генерации кода с MATLAB Coder codegen команда, набор CustomFFTCallback.

    • Для генерации кода с приложением MATLAB Coder, набор Custom FFT library callback.

    • Для генерации кода для блока MATLAB Function при помощи Simulink Coder, набор Custom FFT library callback.

Необходимо реализовать updateBuildInfo и getNumThreads методы.

Опционально, можно реализовать эти методы:

  • getPlanMethod

  • lock и unlock

Все методы являются статическими.

Методы

getNumThreads Возвратите количество потоков, чтобы использовать для вызовов библиотеки FFTW
getPlanMethodВозвратите FFTW планирование метода
блокировка Заблокируйте доступ к планированию FFTW
разблокировать Разблокируйте доступ к планированию FFTW
updateBuildInfo Обновите информацию о сборке для соединения с определенной библиотекой FFTW

Примеры

свернуть все

Задайте определенную установленную библиотеку FFTW в классе коллбэка библиотеки FFT.

Используйте этот класс коллбэка библиотеки FFT в качестве примера в качестве шаблона.

% copyright 2017 The MathWorks, Inc.

classdef useMyFFTW < coder.fftw.StandaloneFFTW3Interface
     
    methods (Static)
        function th = getNumThreads
            coder.inline('always');
            th = int32(coder.const(1));
        end
                
        function updateBuildInfo(buildInfo, ctx)
            fftwLocation = '/usr/lib/fftw';
            includePath = fullfile(fftwLocation, 'include');
            buildInfo.addIncludePaths(includePath);
            libPath = fullfile(fftwLocation, 'lib');
            
            %Double
            libName1 = 'libfftw3-3';
            [~, libExt] = ctx.getStdLibInfo();
            libName1 = [libName1 libExt];
            addLinkObjects(buildInfo, libName1, libPath, 1000, true, true);
            
            %Single
             libName2 = 'libfftw3f-3';
            [~, libExt] = ctx.getStdLibInfo();
            libName2 = [libName2 libExt];
            addLinkObjects(buildInfo, libName2, libPath, 1000, true, true);
        end
    end           
end

Измените шаблон.

  • Замените useMyFFTW с именем вашего класса коллбэка.

  • Если ваша установка FFTW использует несколько потоков, измените getNumThreads метод, чтобы возвратить количество потоков, которые вы хотите использовать.

  • В updateBuildInfo метод, набор:

    • fftwLocation к полному пути для вашей установки библиотеки.

    • includePath к полному пути папки, которая содержит fftw3.h.

    • libPath к полному пути папки, которая содержит файлы библиотеки.

Введенный в R2017b