В этом примере показано, как сгенерировать MATLAB с одинарной точностью® код из кода MATLAB с двойной точностью.
Чтобы завершить этот пример, установите следующие продукты:
MATLAB
Fixed-Point Designer™
Компилятор C
См. поддерживаемые компиляторы.
Можно использовать mex -setup
изменить компилятор по умолчанию. См. Компилятор Значения по умолчанию Изменения.
Создайте локальную рабочую папку, например, c:\ex_2ndOrder_filter
.
Превратитесь в docroot\toolbox\fixpoint\examples
папка. В командной строке MATLAB, введите:
cd(fullfile(docroot, 'toolbox', 'fixpoint', 'examples'))
Скопируйте ex_2ndOrder_filter.m
и ex_2ndOrder_filter_test.m
файлы к вашей локальной рабочей папке.
Ввод | Имя | Описание |
---|---|---|
Код функции | ex_2ndOrder_filter.m | Функция MATLAB точки входа |
Тестовый файл | ex_2ndOrder_filter_test.m | Скрипт MATLAB, который тестирует |
Создайте объект настройки с одинарной точностью. Задайте имя тестового файла. Проверьте код с одинарной точностью с помощью тестового файла. Постройте ошибку между кодом с двойной точностью и кодом с одинарной точностью. Используйте значения по умолчанию для других свойств.
scfg = coder.config('single'); scfg.TestBenchName = 'ex_2ndOrder_filter_test'; scfg.TestNumerics = true; scfg.LogIOForComparisonPlotting = true;
Преобразовывать функцию MATLAB с двойной точностью, ex_2ndOrder_filter
, к коду MATLAB с одинарной точностью используйте convertToSingle
convertToSingle -config scfg ex_2ndOrder_filter
convertToSingle
анализирует код с двойной точностью. Процесс преобразования выводит типы путем выполнения тестового файла, потому что вы не задавали входные типы для ex_2ndOrder_filter
функция. Процесс преобразования выбирает типы с одинарной точностью для переменных с двойной точностью. Это выбирает int32
для индексных переменных. Когда преобразование завершено, convertToSingle
генерирует отчет предложения по типу.
Чтобы видеть типы что процесс преобразования, выбранный для переменных, откройте отчет предложения по типу для ex_2ndOrder_filter
функция. Щелкните по ссылке ex_2ndOrder_filter_report.html
.
Отчет открывается в веб-браузере. Процесс преобразования преобразовал:
Переменные с двойной точностью к single
.
Индекс i
к int32
. Процесс преобразования бросает переменные индекса и размерности к int32
.
Просматривать отчет для генерации кода MATLAB с одинарной точностью, в Командном окне:
Прокрутите к Generate Single-Precision Code
шаг. Щелкните по ссылке View report.
В панели MATLAB Source нажмите ex_2ndOrder_filter_single
.
Отчет генерации кода отображает код MATLAB с одинарной точностью для ex_2ndOrder_filter
.
Когда вы генерируете код с одинарной точностью, convertTosingle
позволяет подсветить потенциальных проблем типа данных в отчетах генерации кода. Если convertTosingle
не может удалить операцию с двойной точностью, отчет подсвечивает выражение MATLAB, которое приводит к операции. Кликните по вкладке Code Insights. Отсутствие потенциальных проблем типа данных указывает, что никакие операции с двойной точностью не остаются.
Вы видите графики сравнения для входа x
и выход y
потому что вы выбрали, чтобы регистрировать вводы и выводы для графиков сравнения.
coder.SingleConfig
| coder.config
| convertToSingle