Main Content
getErrorValue
Class: FunctionApproximation.LUTSolution
Package: FunctionApproximation
Get the total error of the lookup table approximation
Since R2019a
Syntax
memory = getErrorValue(solution)
Description
memory
= getErrorValue(solution
)
returns the total error of the lookup table approximation specified by
solution
.
Input Arguments
Output Arguments
expand all
error
— Total error of the lookup table approximation
struct
Total error of the lookup table approximation, returned as a struct.
The struct contains two fields. The MaxErrorInSolution
field
specifies the maximum difference between the original function or block and the lookup
table approximation. The ErrorUpperBound
field displays the maximum
error that was acceptable according to the tolerances specified on the
FunctionApproximation.Options
object.
Examples
expand all
Calculate the Total Error of a Lookup Table Approximation
Create a FunctionApproximation.Problem
object
defining a math function to approximate. Then, use the solve
method to
get a FunctionApproximation.LUTSolution
object.
Calculate the total error of the FunctionApproximation.LUTSolution
object using the getErrorValue
method.
problem = FunctionApproximation.Problem('sin')
problem = FunctionApproximation.Problem with properties FunctionToApproximate: @(x)sin(x) NumberOfInputs: 1 InputTypes: "numerictype(0,16,13)" InputLowerBounds: 0 InputUpperBounds: 6.2832 OutputType: "numerictype(1,16,14)" Options: [1×1 FunctionApproximation.Options]
solution = solve(problem)
solution = FunctionApproximation.LUTSolution with properties ID: 8 Feasible: "true"
error = getErrorValue(solution)
error = struct with fields: MaxErrorInSolution: 0.0073 ErrorUpperBound: 0.0078
Version History
Introduced in R2019a
Bryan1 0 / 0 / 0 Регистрация: 23.11.2012 Сообщений: 26 |
||||
1 |
||||
Погрешность аппроксимации02.12.2012, 19:07. Показов 14107. Ответов 3 Метки нет (Все метки)
Помогите разобраться! У меня задачи аппроксимации. Аппроксимировав функцию, нужно найти погрешность аппроксимации по методу наим квадратов. у меня вот на этом шаге ошибка. Помогите разобраться!
0 |
Зосима 5221 / 3552 / 372 Регистрация: 02.04.2012 Сообщений: 6,458 Записей в блоге: 17 |
||||
03.12.2012, 11:00 |
2 |
|||
Надо было сделать так:
1 |
Vramo 0 / 0 / 0 Регистрация: 04.02.2015 Сообщений: 2 |
||||
30.04.2016, 15:30 |
3 |
|||
Прошу прощения, если например мне нужно показать на графике, локальные ошибки МНК(полинома 3-го порядка) функцией errorbar. То для вычисленения значений, локальных ошибок, мне необходимо делать примерно так ?
Зарание спасибо.
0 |
Модератор 1583 / 1451 / 469 Регистрация: 13.09.2015 Сообщений: 4,997 |
|
01.05.2016, 08:48 |
4 |
Vramo, можно, только зачем вычисление е в цикл вводить? У вас каждую итерацию будет вычисляться один и тот же вектор. Выведите вычисление из цикла, цикл уберите
1 |
Информация в данной статье относится к релизам программы MATLAB ранее 2016 года, и поэтому может содержать устаревшую информацию в связи с изменением функционала инструментов. С более актуальной информацией вы можете ознакомиться в разделе документация MATLAB на русском языке.
В этой главе описаны функции системы MATLAB, которые предназначены для анализа и обработки данных, заданных в виде числовых массивов. Наряду с простейшими функциями вычисления среднего, медианы, коэффициентов корреляции элементов массива рассмотрены функции вычисления конечных разностей, градиента и аппроксимации Лапласиана. В отдельный раздел выделены функции аппроксимации и интерполяции. Представлены функции численного интегрирования, решения задачи Коши для систем ОДУ, а также минимизации функций одной и нескольких переменных. В состав функций обработки сигналов включены дискретное преобразование Фурье, функции свертки и фильтрации. В полном объеме функции обработки сигналов оформлены в виде специализированного пакета программ Signal Processing Toolbox.
Основные операции
- SUM, CUMSUM — суммирование элементов массива
- PROD, CUMPROD — произведение элементов массива
- SORT — сортировка элементов массива по возрастанию
- MAX — определение максимальных элементов массива
- MIN — определение минимальных элементов массива
- MEDIAN — определение срединных значений (медиан) элементов массива
- MEAN — определение средних значений элементов массива
- STD — определение стандартных отклонений элементов массива
- COV — определение ковариационной матрицы элементов массива
- CORRCOEF — определение коэффициентов корреляции элементов массива
- DIFF — вычисление конечных разностей и приближенное дифференцирование
- GRADIENT — конечные разности и приближенное вычислениеградиента функции от двух переменных
- DEL2 — пятиточечная аппроксимация Лапласиана
Аппроксимация и интерполяция данных
- POLYFIT — аппроксимация данных полиномом
- INTERPFT — аппроксимация периодической функции на основе быстрого преобразования Фурье
- ICUBIC — кубическая интерполяция функции одной переменной
- SPLINE, PPVAL, MKPP, UNMKPP — интерполяция функции одной переменной кубическим сплайном
- INTERP1 — одномерная табличная интерполяция
- INTERP2 — двумерная табличная интерполяция
- GRIDDATA — двумерная табличная интерполяция на неравномерной сетке
Численное интегрирование
- TRAPZ — интегрирование методом трапеций
- QUAD, QUAD8 — вычисление интегралов методом квадратур
Интегрирование обыкновенных дифференциальных уравнений (ОДУ)
- ODE23, ODE45 — решение задачи Коши для систем ОДУ
Вычисление минимумов и нулей функции
- FMIN, FORTIONS — минимизация функции одной переменной
- FMINS — минимизация функции нескольких переменных
- FZERO — нахождение нулей функции одной переменной
- FPLOT — построение графиков функции одной переменной
Преобразование Фурье
- FFT, IFFT — одномерное дискретное прямое и обратное преобразования Фурье
- FFT2, IFFT2 — двумерное дискретное прямое и обратное преобразования Фурье
- FFTSHIFT — перегруппировка выходных массивов преобразований Фурье
Свертка и фильтрация
- CONV, DECONV — свертка одномерных массивов
- CONV2 — свертка двумерных массивов
- FILTER — дискретная одномерная фильтрация
- FILTER2 — дискретная двумерная фильтрация
- UNWRAP — корректировка фазовых углов
Основные операции
Наверх
SUM, CUMSUM — суммирование элементов массива
Синтаксис:
sx = sum(X)
csx = cumsum(X)
Описание:
Функция sx = sum(X) в случае одномерного массива возвращает сумму элементов массива; в случае двумерного массива — это вектор-строка, содержащая суммы элементов каждого столбца.
Функция csx = cumsum(X), кроме того, возвращает все промежуточные результаты суммирования.
Пример:
Рассмотрим массив M = magic(3): M = magic(3)
M = | 8 | 1 | 6 | |
3 | 5 | 7 | ||
4 | 9 | 2 |
Сопутствующие функции: CUMPROD, PROD.
Наверх
PROD, CUMPROD — произведение элементов массива
Синтаксис:
px = prod(X)
cpx = cumprod(X)
Описание:
Функция px = prod(X) в случае одномерного массива возвращает произведение элементов массива; в случае двумерного массива — это вектор-строка, содержащая произведения элементов каждого столбца.
Функция cpx = cumprod(X), кроме того, возвращает все промежуточные результаты.
Пример:
Рассмотрим массив M = magic(3).
M = | 8 | 1 | 6 | |
3 | 5 | 7 | ||
4 | 9 | 2 |
Сопутствующие функции: CUMSUM, SUM.
Наверх
SORT — сортировка элементов массива по возрастанию
Синтаксис:
Y = sort(X)
[Y, I] = sort(X)
Описание:
Функция Y = sort(X) в случае одномерного массива упорядочивает элементы массива по возрастанию; в случае двумерного массива происходит упорядочение элементов каждого столбца.
Функция [Y, I] = sort(X) кроме массива упорядоченных элементов по столбцам возвращает массив индексов, позволяющих восстановить структуру исходного массива. Такое восстановление можно реализовать с помощью следующего цикла:
for j = 1:3
X(I(:, j), j) = Y(:, j);
end
Если анализируемый массив содержит комплексные элементы, то сортировка выполняется для массива abs(X).
Пример:
Рассмотрим массив M = magic(3).
M = | 8 | 1 | 6 | |
3 | 5 | 7 | ||
4 | 9 | 2 |
[Y, I] = sort(M)
Y = | 3 | 1 | 2 | I = | 2 | 1 | 3 | |
4 | 5 | 6 | 3 | 2 | 1 | |||
8 | 9 | 7 | 1 | 3 | 2 |
Сопутствующие функции: MIN, MAX, MEAN, MEDIAN, FIND.
Наверх
MAX — определение максимальных элементов массива
Синтаксис:
Y = max(X)
[Y, I] = max(X)
C = max(A, B)
Описание:
Функция Y= max(X) в случае одномерного массива возвращает наибольший элемент; в случае двумерного массива — это вектор-строка, содержащая максимальные элементы каждого столбца. Таким образом, max(max(X)) — это наибольший элемент массива.
Функция [Y, I] = max(X) кроме самих максимальных элементов возвращает вектор-строку индексов этих элементов в данном столбце.
Функция C = max(A, B) возвращает массив C тех же размеров, какие имеют массивы A и B, каждый элемент которого есть максимальный из соответствующих элементов этих массивов.
Если анализируемый массив содержит комплексные элементы, то максимальные элементы определяются из условия max(abs(X)). Если массив содержит один или несколько элементов типа NaN, то результатом операции будет NaN.
Пример:
Рассмотрим массив M = magic(3).
M = | 8 | 1 | 6 | |
3 | 5 | 7 | ||
4 | 9 | 2 |
y = max(M) | [y, I] = max(M) | max(max(M)) |
y = 8 9 7 | y = 8 9 7 I = 1 3 2 |
9 |
Сопутствующие функции: MIN, SORT.
Наверх
MIN — определение минимальных элементов массива
Синтаксис:
Y = min(X)
[Y, I] = min(X)
C = min(A, B)
Описание:
Функция Y = min(X) в случае одномерного массива возвращает наименьший элемент; в случае двумерного массива — это вектор-строка, содержащая минимальные элементы каждого столбца. Таким образом, min(min(X)) — это наименьший элемент массива.
Функция [Y, I] = min(X) кроме самих минимальных элементов возвращает вектор-строку индексов этих элементов в данном столбце.
Функция C = min(A, B) возвращает массив C тех же размеров, какие имеют массивы A и B, каждый элемент которого есть минимальный из соответствующих элементов этих массивов.
Если анализируемый массив содержит комплексные элементы, то минимальные элементы определяются из условия min(abs(X)). Если массив содержит один или несколько элементов типа NaN, то результатом операции min будет NaN.
Пример:
Рассмотрим массив M = magic(3).
M = | 8 | 1 | 6 | |
3 | 5 | 7 | ||
4 | 9 | 2 |
y = min(M) | [y, I] = min(M) | min(min(M)) |
y = 3 1 2 | y = 3 1 2 I = 2 1 3 |
1 |
Сопутствующие функции: MAX, SORT.
Наверх
MEDIAN — определение срединных значений (медиан) элементов массива
Синтаксис:
mdx = median(X)
Описание:
Функция mdx = median(X) в случае одномерного массива возвращает значение срединного элемента; в случае двумерного массива — это вектор-строка, содержащая значение срединных элементов каждого столбца. Таким образом, median(median(X)) — это срединный элемент (медиана) массива, что совпадает со значением median(X(:)).
Пример:
Рассмотрим массив M = magic(4).
M = | 16 | 2 | 3 | 13 | |
5 | 11 | 10 | 8 | ||
9 | 7 | 6 | 12 | ||
4 | 14 | 15 | 1 |
mdx = median(M) | median(median(M)) | |
mdx = 7 9 8 10 | ans = 8.5000 |
Сопутствующие функции: MEAN, STD, COV, CORRCOEF.
Наверх
MEAN — определение средних значений элементов массива
Синтаксис:
mx = mean(X)
Описание:
Функция mx = mean(X) в случае одномерного массива возвращает арифметическое среднее элементов массива; в случае двумерного массива — это вектор-строка, содержащая арифметическое среднее элементов каждого столбца. Таким образом, mean(mean(X)) — это арифметическое среднее (математическое ожидание) элементов массива, что совпадает со значением mean(X(:)).
Пример:
Рассмотрим массив M = magic(4).
M = | 16 | 2 | 3 | 13 | |
5 | 11 | 10 | 8 | ||
9 | 7 | 6 | 12 | ||
4 | 14 | 15 | 1 |
mx = mean(M) | mean(mean(M)) | |
mx = 8.5000 8.5000 8.5000 8.5000 | ans = 8.5000 |
Сопутствующие функции: MEDIAN, STD, COV, CORRCOEF.
Наверх
STD — определение стандартных отклонений элементов массива
Синтаксис:
sx = std(X)
Описание:
Функция sx = std(X) в случае одномерного массива возвращает стандартное отклонение элементов массива; в случае двумерного массива — это вектор-строка, содержащая стандартное отклонение элементов каждого столбца.
Пример:
Рассмотрим массив M = magic(4).
M = | 16 | 2 | 3 | 13 | |
5 | 11 | 10 | 8 | ||
9 | 7 | 6 | 12 | ||
4 | 14 | 15 | 1 |
sx = std(M)
sx = 5.4467 5.1962 5.1962 5.4467
Сопутствующие функции: MEDIAN, MEAN, COV, CORRCOEF.
Наверх
COV — определение ковариационной матрицы элементов массива
Синтаксис:
C = cov(X)
C = cov(X, y)
Описание:
Функция C = cov(X) в случае одномерного массива возвращает дисперсию элементов массива; в случае двумерного массива, когда каждый столбец рассматривается как переменная, а каждая строка — как наблюдение, cov(X) — это матрица ковариаций, diag(cov(X)) — вектор дисперсий, sqrt(diag(cov(X))) — вектор стандартных отклонений для каждого столбца.
Функция C = cov(X, y), где массивы X и Y имеют одинаковое количество строк, равносильна функции cov([X Y]).
Пример: Рассмотрим массив M = magic(4)/norm(magic(4)).
M = | 0.4706 | 0.0588 | 0.0882 | 0.3824 | |
0.1471 | 0.3235 | 0.2941 | 0.2353 | ||
0.2647 | 0.2059 | 0.1765 | 0.3529 | ||
0.1176 | 0.4118 | 0.4412 | 0.0294 |
C = cov(X) | diag(cov(X)) | sqrt(diag(cov(X))) | ||||||||||||||||||||||||
|
|
|
Алгоритм: Вычисление матрицы ковариаций реализуется следующим алгоритмом:
[n, p] = size(X);
X = X — ones(n, 1) * mean(X);
C = X’ * X/(n — 1);
Сопутствующие функции: CORRCOEF, MEAN, STD.
Наверх
CORRCOEF — определение коэффициентов корреляции элементов массива
Синтаксис:
S = corrcoef(X)
S = corrcoef(X, Y)
Описание:
Функция S = corrcoef(X) возвращает матрицу коэффициентов корреляции для двумерного массива, когда каждый столбец рассматривается как переменная, а каждая строка — как наблюдение.
Элементы матрицы S = corrcoef(X) связаны с элементами матрицы ковариаций C = cov(X) следующим соотношением:
.
Функция S = corrcoef(X, Y), где массивы X и Y имеют одинаковое количество строк, равносильна функции corrcoef([X Y]).
Пример:
Рассмотрим массив M = magic(4)/norm(magic(4)).
M = | 0.4706 | 0.0588 | 0.0882 | 0.3824 | |
0.1471 | 0.3235 | 0.2941 | 0.2353 | ||
0.2647 | 0.2059 | 0.1765 | 0.3529 | ||
0.1176 | 0.4118 | 0.4412 | 0.0294 |
S = corrcoef(M) | C = cov(X) | ||||||||||||||||||||||||||||||||
|
|
Сопутствующие функции: COV, MEAN, STD.
Наверх
DIFF — вычисление конечных разностей и приближенное дифференцирование
Синтаксис:
y = diff(x)
y = diff(x, n)
Описание:
Функция y = diff(x) вычисляет конечные разности. Если x — одномерный массив вида x = [x(1) x(2) … x(n)], то diff(x) — это вектор разностей соседних элементов diff(x) = [x(2) — x(1) x(3) — x(2) … x(n) — x(n-1)]. Количество элементов вектора x на единицу меньше количества элементов вектора diff(x). Если X — двумерный массив, то берутся разности столбцов diff(X) = X(2:m, — X(1:m-1, :).
Функция y = diff(x, n) вычисляет конечные разности порядка n, удовлетворяющие рекуррентному соотношению diff(x, n) = diff(x, n-1).
Аппроксимацией производной n порядка является отношение diff(y, n)./diff(x, n).
При наличии специализированного пакета Symbolic Math Toolbox [1] возможно реализовать точное дифференцирование в символьном виде, используя следующие функции пакета:
- diff(S) дифференцирует символьное выражение S по свободной переменной;
- diff(S, ‘v’) дифференцирует символьное выражение S по v;
- diff(S, n) и diff(S, ‘v’, n) дифференцирует n раз символьное выражение S;
- diff без аргументов дифференцирует предшествующее выражение.
Сопутствующие функции: GRADIENT, DEL2.
Ссылки:
1. Symbolic Mathematics Toolbox. User’s Guide. Natick: The MathWorks, Inc., 1994.
Наверх
GRADIENT — конечные разности и приближенное вычислениеградиента функции от двух переменных
Синтаксис:
[px, py] = gradient(F)
[px, py] = gradient(F, dx, dy)
Описание:
Функция [px, py] = gradient(F) вычисляет конечные разности функции F(x, y), заданной на двумерной сетке и представляющей собой массив чисел.
Функция [px, py] = gradient(F, dx, dy) возвращает численные значения производных функции F в виде массивов px = dF/dx и py = dF/dy, где dx и dy могут быть скалярами, равными шагам разбиения сетки по осям x и y, либо векторами координат узлов сетки при разбиении с переменным шагом.
Пример:
Рассмотрим расчет и построение поля направлений для функции
F =
с использованием функции gradient.
[x, y] = meshgrid(-2:.2:2, -2:.2:2);
z = x .* exp(-x.^2 — y.^2);
[px, py] = gradient(z, .2, .2);
contour(z), hold on, quiver(px, py), hold off
Сопутствующие функции: DIFF, DEL2, QUIVER, CONTOUR.
Наверх
DEL2 — пятиточечная аппроксимация Лапласиана
Синтаксис:
V = del2(U)
Описание:
Функция V = del2(U) возвращает массив того же размера, каждый элемент которого равен разности среднего значения соседних элементов и элемента рассматриваемого узла. Узлы сетки во внутренней области имеют четырех соседей, а на границе и в углах — только трех или двух соседей.
Если массив U рассматривать как функцию U(x, y), вычисленную в точках квадратной сетки, то 4del2(U) является конечно-разностной аппроксимацией дифферренциального оператора Лапласа, примененного к функции U.
.
Пример:
Функция u(x, y) = x2 + y2 имеет лапласиан, равный D2u = 4, в чем можно убедиться, взглянув на графики этих функций.
[x, y] = meshgrid(-4:4, -3:3);
U = x.* x + y.* y,
U =
25 | 18 | 13 | 10 | 9 | 10 | 13 | 18 | 25 | |
20 | 13 | 8 | 5 | 4 | 5 | 8 | 13 | 20 | |
17 | 10 | 5 | 2 | 1 | 2 | 5 | 10 | 17 | |
16 | 9 | 4 | 1 | 0 | 1 | 4 | 9 | 16 | |
17 | 10 | 5 | 2 | 1 | 2 | 5 | 10 | 17 | |
20 | 13 | 8 | 5 | 4 | 5 | 8 | 13 | 20 | |
25 | `8 | 13 | 10 | 9 | 10 | 13 | 18 | 25 |
V = 4 * del2(U),
V =
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | |
4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
surfl(U), surfl(V)
Сопутствующие функции: GRADIENT, DIFF.
Аппроксимация и интерполяция данных
Наверх
POLYFIT — аппроксимация данных полиномом
Синтаксис:
p = polyfit(x, y, n)
Описание:
Функция p = polyfit(x, y, n) находит коэффициенты полинома p(x) степени n, который аппроксимирует функцию y(x) в смысле метода наименьших квадратов. Выходом является строка p длины n +1, содержащая коэффициенты аппроксимирующего полинома.
Пример:
Рассмотрим аппроксимацию функции ошибки erf(x), которая является ограниченной сверху функцией, в то время как аппроксимирующие полиномы неограниченны, что приводит к ошибкам аппроксимации.
x = (0:0.1:2.5)’;
y = erf(x);
вычислим коэффициенты аппроксимирующего полинома степени 6:
p = polyfit(x, y, 6)
p = 0.0084 -0.0983 0.4217 -0.7435 0.1471 1.1064 0.0004
вычислим значения полинома в точках сетки:
f = polyval(p, x);
сформируем следующую таблицу данных:
table = [x y f y-f]
table =
|
|
Из таблицы видно, что на отрезке [0 2.5] точность аппроксимации находится в пределах 3-4 знаков; построим графики функции и аппроксимирующего полинома на отрезке [0 5].
x = (0:0.1:5)’;
y = erf(x);
f = polyval(p, x);
plot(x, y, ‘ob’, x, f, ‘-g’), » axis([0 5 0 2])
Как следует из анализа графика, аппроксимация вне отрезка [0 2.5] расходится.
Алгоритм:
Аппроксимация полиномом связана с вычислением матрицы Вандермонда V, элементами которой являются базисные функции
,
и последующим решением переопределенной системы линейных уравнений
Vp = y.
Пользователь может самостоятельно внести изменения в М-файл polyfit, чтобы применить другие базисные функции.
Сопутствующие функции: POLY, POLYVAL, VANDER.
Наверх
INTERPFT — аппроксимация периодической функции на основе быстрого преобразования Фурье
Синтаксис:
yp = interpft(y, n)
Описание:
Функция yp = interpft(y, n) возвращает одномерный массив чисел, который является периодической функцией, определенной в n точках и аппроксимирующей одномерный массив y. Если length(x) = m, а интервал дискретности dx, то интервал дискретности для y определяется по формуле dy = dx * m/n, причем n всегда превышает m.
Пример:
Рассмотрим аппроксимацию функции y = sin(x), которая задана 11 точками на интервале [0 10].
x = 0:10; y = sin(x);
xp = 0:0.25:10;
yp = interpft(y, 41);
xt = 0:0.01:10; yt = sin(xt);
plot(xt, yt, ‘r’), hold on, plot(x, y, ‘ob’, xp, yp)
На графике построена точная функция y = sin(x) с указанием точек съема данных и ее аппроксимация в 41 точке. Как видно из графика, аппроксимация вне интервала [0 1.5] имеет нарастающую погрешность.
Сопутствующие функции: ICUBIC, SPLINE, INTERP1.
Наверх
ICUBIC — кубическая интерполяция функции одной переменной
Синтаксис:
yi = icubic(y, xi)
yi = icubic(x, y, xi)
Описание:
Функция yi = icubic(y, xi) интерполирует значения функции y в точках xi внутри области определения функции, используя кубические полиномы. Если Y — двумерный массив, то интерполирующая кривая строится для каждого столбца. Если указано значение xi вне области определения функции, то результатом будет NaN.
Функция yi = icubic(x, y, xi) позволяет использовать более мелкую сетку xi при условии, что аргумент x изменяется монотонно и сетка равномерна.
Пример:
Зададим синусоиду всего 10 точками и проведем интерполяцию, используя мелкую сетку.
x = 0:10; y = sin(x);
xi = 0:.25:10;
yi = icubic(x, y, xi);
plot(x, y, ‘o’, xi, yi, ‘g’), grid.
Сопутствующие функции: POLYFIT, SPLINE.
Наверх
SPLINE, PPVAL, MKPP, UNMKPP — интерполяция функции одной переменной кубическим сплайном
Синтаксис:
yi = spline(x, y, xi) | v = ppval(pp, xx) | |
pp = spline(x, y) | [breaks, coefs, l, k] = unmkpp(pp) | |
pp = mkpp(breaks, coefs) |
Описание:
Функция yi = spline(x, y, xi) интерполирует значения функции y в точках xi внутри области определения функции, используя кубические сплайны [1].
Функция pp = spline(x, y) возвращает pp-форму сплайна, используемую в М-файлах ppval, mkpp, unmkpp.
Функция v = ppval(pp, xx) вычисляет значение кусочно-гладкого полинома pp для значений аргумента xx.
Функция [breaks, coefs, l, k] = unmkpp(pp) возвращает характеристики кусочно гладкого полинома pp:
breaks — вектор разбиения аргумента;
coefs — коэффициенты кубических сплайнов;
l = length(breaks) — 1;
k = length(coefs)/l.
Функция pp = mkpp(breaks, coefs) формирует кусочно-гладкий полином pp по его характеристикам.
Пример:
Зададим синусоиду всего 10 точками и проведем интерполяцию кубическими сплайнами, используя мелкую сетку.
x = 0:10; y = sin(x);
xi = 0:.25:10;
yi = spline(x, y, xi);
plot(x, y, ‘o’, xi, yi, ‘g’), grid
Определим pp-форму сплайна.
pp = spline(x, y);
[breaks, coeffs, l, k] = unmkpp(pp)
breaks = 0 1 2 3 4 5 6 7 8 9 10
coeffs =
-0.0419 | -0.2612 | 1.1446 | 0 | |
-0.0419 | -0.3868 | 0.4965 | 0.8415 | |
0.1469 | -0.5124 | -0.4027 | 0.9093 | |
0.1603 | -0.0716 | -0.9867 | 0.1411 | |
0.0372 | 0.4095 | -0.6488 | -0.7568 | |
-0.1234 | 0.5211 | 0.2818 | -0.9589 | |
-0.1684 | 0.1509 | 0.9538 | -0.2794 | |
-0.0640 | -0.3542 | 0.7506 | 0.6570 | |
0.1190 | -0.5463 | -0.1499 | 0.9894 | |
0.1190 | -0.1894 | -0.8856 | 0.4121 |
l = 10
k = 4
Вычислим pp-форму в узловых точках сетки.
v = ppval(pp,x)
v =
0 | 0.8415 | 0.9093 | 0.1411 | -0.7568 | -0.9589 | -0.2794 | 0.6570 | 0.9894 | 0.4121 | -0.5440 |
Алгоритм:
Интерполяция сплайнами использует вспомогательные функции ppval, mkpp, unmkpp, которые образуют небольшой пакет для работы с кусочно-гладкими полиномами.
Существенно большие возможности для работы со сплайнами предо-ставляет пользователю специализированный пакет Spline Toolbox [2].
Сопутствующие функции: ICUBIC, INTERP1, POLYFIT, Spline Toolbox.
Ссылки:
- Carl de Boor. A Practical Guide to Splines. Berlin, 1978.
- Spline Toolbox. User’s Guide. Natick: The MathWorks, Inc., 1992.
Наверх
INTERP1 — одномерная табличная интерполяция
Синтаксис:
yi = interp1(x, y, xi)
yi = interp1(x, y, xi, ‘<метод>‘)
Описание:
Функция yi = interp1(x, y, xi) строит интерполирующую кривую для одномерного массива y, заданного на сетке x; выходной массив yi может быть определен на более мелкой сетке xi. Если Y — двумерный массив, то интерполирующая кривая строится для каждого столбца. По умолчанию реализована линейная интерполяция.
Функция yi = interp1(x, y, xi, ‘<метод>‘) позволяет задать метод интерполяции:
‘linear’ | линейная | |
‘cubic’ | кубическая | |
‘spline’ | кубические сплайны |
Принято, что аргумент x изменяется монотонно; кроме того, для кубической интерполяции предполагается, что сетка по x равномерна.
Пример:
Зададим синусоиду всего 10 точками и проведем интерполяцию, используя мелкую сетку.
x = 0:10; y = sin(x);
xi = 0:.25:10;
yi = interp1(x, y, xi);
plot(x, y, ‘o’, xi, yi, ‘g’), hold on
yi = interp1(x, y, xi, ‘spline’ );
plot(x, y, ‘ob’, xi, yi, ‘m’), grid, hold off
Алгоритм:
Методы линейной и кубической интерполяции реализуются довольно просто; что же касается интерполяции сплайнами, то в этом случае используются вспомогательные функции ppval, mkpp, unmkpp, которые образуют небольшой пакет для работы с кусочно-гладкими полиномами.
Существенно большие возможности пользователям для решения проблем интерполяции и аппроксимации предоставляет специализированный пакет Spline Toolbox [1].
Сопутствующие функции: INTERPFT, INTERP2, GRIDDATA.
Ссылки:
1. Spline Toolbox. User’s Guide. Natick: The MathWorks, Inc., 1992.
Наверх
INTERP2 — двумерная табличная интерполяция
Синтаксис:
ZI = interp2(X, Y, XI, YI)
ZI = interp2(X, Y, XI, YI, ‘<метод>‘)
Описание:
Функция ZI = interp2(X, Y, XI, YI) интерполирует данные, определяющие некоторую поверхность на двумерной сетке {X, Y}; выходной массив ZI может быть определен на более мелкой сетке {XI, YI}. По умолчанию реализована линейная интерполяция.
Функция ZI = interp2(X, Y, XI, YI, ‘<метод>‘) позволяет задать метод интерполяции:
‘linear’ | линейная | |
‘cubic’ | кубическая |
Принято, что аргументы X и Y изменяются монотонно; кроме того, для кубической интерполяции предполагается, что сетка {X, Y} равномерна.
Пример:
Проведем интерполяцию функции peaks, используя мелкую сетку.
[X, Y] = meshgrid(-3:0.25:3);
Z = peaks(X, Y);
[XI, YI] = meshgrid(-3:0.125:3);
ZI = interp2(X, Y, Z, XI, YI);
mesh(X, Y, Z), hold on, mesh(XI, YI, ZI+15), hold off
Сопутствующие функции: INTERPFT, INTERP1, GRIDDATA.
Наверх
GRIDDATA — двумерная табличная интерполяция на неравномерной сетке
Синтаксис:
ZI = griddata(x, y, z, XI, YI)
[XI, YI, ZI] = griddata(x, y, z, XI, YI)
Описание:
Функция ZI = griddata(x, y, z, XI, YI) возвращает массив ZI, который определен на новой сетке {XI, YI} в результате интерполяции исходной функции z, заданной на неравномерной сетке {x, y}.
Функция [XI, YI, ZI] = griddata(x, y, z, XI, YI) кроме массива ZI возвращает массивы XI, YI, упорядоченные по аналогии с функцией meshgrid.
Пример:
Определим функцию на сетке, заданной 100 точками, выбранными случайно на отрезке [-2 2].
x = rand(100, 1) * 4 — 2;
y = rand(100, 1) * 4 — 2;
z = x.*exp(-x.^2 — y.^2);
Векторы x, y, z определяют 100 случайных точек на поверхности функции ZI, которую зададим на следующей равномерной сетке:
ti = -2:0.25:2;
[XI, YI] = meshgrid(ti, ti);
ZI = griddata(x, y, z, XI, YI);
Построим поверхность функции, полученной в результате интерполяции на неравномерной случайной сетке.
mesh(XI, YI, ZI), hold on, plot3(x, y, z, ‘or’)
Сопутствующие функции: INTERP1, INTERP2.
Численное интегрирование
Наверх
TRAPZ — интегрирование методом трапеций
Синтаксис:
I = trapz(x, y)
I = trapz(y)
Описание:
Функция I = trapz(x, y) вычисляет интеграл от функции y по переменной x, используя метод трапеций. Аргументы x и y могут быть одномерными массивами одинакового размера, либо массив Y может быть двумерным, но тогда должно выполняться условие size(Y, 1) = length(x). В последнем случае вычисляется интеграл для каждого столбца.
Функция I = trapz(y) вычисляет интеграл, предполагая, что шаг интегрирования постоянен и равен единице; в случае, когда шаг h отличен от единице, но постоянен, достаточно вычисленный интеграл умножить на h.
Примеры:
Вычислим интеграл
I = .
Его точное значение равно двум.
Выберем равномерную сетку
x = 0:pi/100:pi; y = sin(x);
тогда оба интеграла
I = trapz(x, y) и I = pi/100*trapz(y)
дают одинаковый результат:
I = 1.9998.
Образуем неравномерную сетку, используя генератор случайных чисел.
x = sort(rand(1,101)*pi); y = sin(x);
I = trapz(x, y)
I = 1.9987.
Результат еще менее точен, поскольку максимальный из шагов max(diff(x)) равен 0.1810
Сопутствующие функции: SUM, CUMSUM, QUAD, QUAD8.
Наверх
QUAD, QUAD8 — вычисление интегралов методом квадратур
Синтаксис:
[I, cnt] = quad(‘<имя функции>‘, a, b)
[I, cnt] = quad(‘<имя функции>‘, a, b, tol)
[I, cnt] = quad(‘<имя функции>‘, a, b, tol, trace)
[I, cnt] = quad8(‘<имя функции>‘, a, b)
[I, cnt] = quad8(‘<имя функции>‘, a, b, tol)
[I, cnt] = quad8(‘<имя функции>‘, a, b, tol, trace)
Описание:
Квадратура — это численный метод вычисления площади под графиком функции, то есть вычисление определенного интеграла вида
I = .
Функции quad и quad8 используют разные квадратурные формулы.
Функции [I, cnt] = quad(‘<имя функции>‘, a, b) и [I, cnt] = quad8(‘<имя функции>‘, a, b) вычисляют интеграл от заданной функции; последняя может быть как встроенной функцией, так и М-файлом. Переменная cnt содержит информацию о том, сколько раз в процессе интегрирования вычислялась подынтегральная функция.
Функции [I, cnt] = quad(‘<имя функции>‘, a, b, tol) и [I, cnt] = quad8(‘<имя функции>‘, a, b, tol) вычисляют интеграл с заданной относительной погрешностью tol. По умолчанию tol = 1e-3.
Функции [I, cnt] = quad(‘<имя функции>‘, a, b, tol, trace) и [I, cnt] = quad8(‘<имя функции>‘, a, b, tol, trace), когда аргумент trace не равен нулю, строят график, показывающий ход вычисления интеграла.
Примеры:
Вычислим интеграл
I = .
Его точное значение равно двум.
[I, cnt] = quad(‘sin’, 0, pi) | [I, cnt] = quad(‘sin’, 0, pi, 1e-4, 1) | |
I = 2.0000 | I = 2.0000 | |
cnt = 17 | cnt = 33 |
Как следует из анализа полученных данных, при увеличении точности вычисления на порядок почти вдвое увеличивается трудоемкость расчетов. График с результатами промежуточных расчетов показан на рисунке.
Алгоритм:
Функция quad использует квадратурные формулы Ньютона — Котеса 2-го порядка (правило Симпсона), а функция quad8 — формулы 8-го порядка [1-2]. При наличии в подынтегральной функции особенностей типа
I =
предпочтительнее использовать процедуру quad8.
Диагностические сообщения:
Функции quad и quad8 используют рекурсивный вызов. Для того чтобы предотвратить бесконечную рекурсию при вычислении сингулярных интегралов, глубина рекурсии ограничена уровнем 10. При достижении этого ограничения выдается сообщение
Recursion level limit reached in quad. Singularity likely.
В процедуре quad достигнута предельная глубина рекурсии. Функция, возможно, сингулярна.
Ограничения:
Функции quad и quad8 не позволяют интегрировать функции с особенностями типа
I = .
В этом случае рекомендуется выделить такие члены и проинтегрировать их аналитически, а к остатку применить процедуры quad и quad8.
Сопутствующие функции: SUM, CUMSUM, TRAPZ.
Ссылки:
- Forsythe G. E., Malcolm M. A., Moler C. B. Computer Methods for Mathematical Computations. Prentice-Hall, 1977.
- Справочник по специальным функциям: Пер. с англ./Под ред. М. Абрамовица и И. Стиган. М.: Наука, 1979.
Интегрирование обыкновенных дифференциальных уравнений (ОДУ)
Наверх
ODE23, ODE45 — решение задачи Коши для систем ОДУ
Синтаксис:
[t, X] = ode23(‘<имя функции>‘, t0, tf, x0)
[t, X] = ode23(‘<имя функции>‘, t0, tf, x0, tol, trace)
[t, X] = ode45(‘<имя функции>‘, t0, tf, x0)
[t, X] = ode45(‘<имя функции>‘, t0, tf, x0, tol, trace)
Описание:
Функции ode23 и ode45 предназначены для численного интегрирования систем ОДУ. Они применимы как для решения простых дифференциальных уравнений, так и для моделирования сложных динамических систем.
Любая система нелинейных ОДУ может быть представлена как система дифференциальных уравнений 1-го порядка в явной форме Коши:
,
где x — вектор состояния;
t — время;
f — нелинейная вектор-функция от переменных x, t.
Функции [t, X] = ode23(‘<имя функции>‘, t0, tf, x0, tol, trace) и [t, X] = = ode45(‘<имя функции>‘, t0, tf, x0, tol, trace) интегрируют системы ОДУ, используя формулы Рунге — Кутты соответственно 2-го и 3-го или 4-го и 5-го порядка.
Эти функции имеют следующие параметры:
Входные параметры:
‘<имя функции>‘ — строковая переменная, являющаяся именем М-файла, в котором вычисляются правые части системы ОДУ;
t0 — начальное значение времени; tfinal — конечное значение времени;
x0 — вектор начальных условий;
tol — задаваемая точность; по умолчанию для ode23 tol = 1.e-3, для ode45 tol = 1.e-6);
trace — флаг, регулирующий вывод промежуточных результатов; по умолчанию равен нулю, что подавляет вывод промежуточных результатов;
Выходные параметры:
t — текущее время;
X — двумерный массив, где каждый столбец соответствует одной переменной.
Примеры:
Рассмотрим дифференциальное уравнение 2-го порядка, известное как уравнение Ван дер Поля,
.
Это уравнение может быть представлено в виде системы ОДУ в явной форме Коши:
Первый шаг процедуры интегрирования — это создание М-файла для вычисления правых частей ОДУ; присвоим этому файлу имя vdpol.
function xdot = vdpol(t, x)
xdot = [x(2); x(2) .* (1 — x(1).^2) — x(1)];
Чтобы проинтегрировать систему ОДУ, определяемых функцией vdpol в интервале времени 0 <= t <= 20, вызовем функцию ode23:
t0 = 0; tf = 20;
x0 = [0 0.25]’; %Начальные условия
[t, X] = ode23(‘vdpol’, t0, tf, x0);
plot(t, X), grid, hold on
gtext(‘x1’), gtext(‘x2’)
Рассмотрим простейший из известных примеров странного аттрактора — аттрактор Ресслера [1]:
где параметры {a, b, c} имеют значения {0.2 0.2 5.7}, а начальное условие задается следующим образом: x0 = [-0.7 -0.7 1].
Для того чтобы проинтегрировать эту систему в интервале времени 0<= t<= 20, вызовем функцию ode45:
t0 = 0; tf = 20;
x0 = [-0.7 -0.7 1]’.%Начальные условия
[t, X] = ode45(‘ressler’, t0, tf, x0);
comet3(X(:, 1), X(:, 2), X(:, 3)).
Алгоритм:
Функции ode23 и ode45 реализуют методы Рунге — Кутты с автоматическим выбором шага, описанные в работе [2]. Такие алгоритмы используют тем большее количество шагов, чем медленнее изменяется функция. Поскольку функция ode45 использует формулы более высокого порядка, обычно требуется меньше шагов интегрирования и результат достигается быстрее. Для сглаживания полученных процессов можно использовать функцию interp1.
Диагностические сообщения:
Если функции ode23 и ode45 не могут выполнить интегрирование во всем заданном диапазоне времени выдается сообщение
Singularity likely.
Система сингулярна.
В состав версии 4.0 помимо функций ode23 и ode45 включена также функция ode23p, которая позволяет в процессе интегрирования строить в трехмерном пространстве орбиты движения для трех первых переменных состояния. Перед обращением к этой функции пользователь должен задать диапазоны изменения этих переменных, чтобы определить размер графика, используя следующие операторы:
axis([x1min x1max x2min x2max x3min x3max]);
hold .
Для получения тех же результатов вместо этой не столь очевидной процедуры целесообразно использовать такую последовательность:
[t, X] = ode23(‘<имя функции>‘, t0, tf, x0, tol, trace);
comet3(X(:, 1), X(:, 2), X(:, 3));.
В этом случае построение орбиты реализуется автоматически, но после выполнения процедуры интегрирования. Кроме того, в данном случае пользователь может выбирать любые переменные состояния.
Для эффективного моделирования сложных динамических систем с непрерывным и дискретным временем рекомендуется использовать специализированную систему SIMULINK [3], входящую в состав программных продуктов, выпускаемых фирмой The MathWorks, Inc.
Ссылки:
- Хакен Г. Синергетика: иерархии неустойчивостей в самоорганизующихся системах и устройствах. М.: Мир, 1985. 423 с.
- Forsythe G. E., Malcolm M. A., Moler C. B. Computer Methods for Mathematical Computations. Prentice-Hall, 1977.
- SIMULINK. User’s Guide. Natick: The MathWorks, Inc., 1990.
Вычисление минимумов и нулей функции
Наверх
FMIN, FORTIONS — минимизация функции одной переменной
Синтаксис:
xmin = fmin(‘<имя функции>‘, x1, x2)
xmin = fmin(‘<имя функции>‘, x1, x2, options)
[xmin, options] = fmin(‘<имя функции>‘, x1, x2, options, p1,…, p10)
options = foptions
Описание:
Функция xmin = fmin(‘<имя функции>‘, x1, x2) возвращает значение локального минимума функции в интервале x1<= x<= x2.
Функция xmin = fmin(‘<имя функции>‘, x1, x2, options) использует вектор управляющих параметров options, который включает 18 компонентов, описанных ниже. Он предназначен для настройки алгоритмов оптимизации, применяемых как в системе MATLAB, так и в пакете программ Optimization Toolbox [1]. Функция fmin использует только 3 из этих параметров: options(1), options(2), options(14).
Функция [xmin, options] = fmin(‘<имя функции>‘, x1, x2, options, p1,…, p10) позволяет передать до 10 параметров, а кроме того, возвращает вектор управляющих параметров options, которые использовались алгоритмом, и в частности, параметр options(10), фиксирующий количество выполненных итераций, и параметр options(8), содержащий минимальное значение функции.
Функция options = foptions возвращает вектор-строку исходных значений параметров, используемых функциями fmin и fmins системы MATLAB и функциями fminu, constr, attgoal, minimax, leastsq, fsolve пакета Optimization Toolbox. Значения по умолчанию присваиваются внутри функций оптимизации и могут отличаться от исходных значений.
Опция | Назначение опции | Исходное значение | Значение по умолчанию |
options(1) | Вывод промежуточных результатов: 0 — не выводятся; 1 — выводятся | 0 | 0 |
options(2) | Итерационная погрешность для аргумента | 1e-4 | 1e-4 |
options(3) | Итерационная погрешность для функции | 1e-4 | 1e-4 |
options(4) | Терминальный критерий соблюдения ограничений | 1e-6 | 1e-6 |
options(5) | Стратегия | 0 | 0 |
options(6) | Оптимизация | 0 | 0 |
options(7) | Алгоритм линейного поиска | 0 | 0 |
options(8) | Значение целевой функции | 0 | 0 |
options(9) | Для контроля градиента установить в 1 | 0 | 0 |
options(10) | Количество выполненых итераций | 0 | 0 |
options(11) | Количество вычисленных градиентов | 0 | 0 |
options(12) | Количество вычисленных ограничений | 0 | 0 |
options(13) | Количество ограничений в виде равенств | 0 | 0 |
options(14) | Максимальное количество итераций, n — количество переменных | 0 | fmin: 500 fmins: 200хn |
options(15) | Параметр, используемый прри наличии целевой функции | 0 | 0 |
options(16) | Минимальное прриращение переменных при вычислении градиента | 1e-8 | 1e-8 |
options(17) | Максимальное прриращение переменных при вычислении градиента | 0.1 | 0.1 |
options(18) | Размер шага минимизации h | 0 | h <=1 |
Пример:
Вычислим приближенное значение p путем минимизации функции y = cos(x) на отрезке [3 4] с итерационной погрешностью по x — 1e-12.
[xmin, opt] = fmin(‘cos’, 3, 4, [0, 1e-12]);
xmin = 3.141592654027715e+000
pi = 3.141592653589793e+000
norm(y-pi) = 4.3792e-010
Функция у = cos(x)
Обратите внимание, что итерационная погрешность (разница между двумя соседними итерациями) отличается от погрешности вычисления (разница между вычисленным и машинным значением p .
Номер опции opt | Исходное значение | Значение при выходе из функции fmin | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
Анализ таблицы подтверждает, что заданная итерационная погрешность opt(2) равна 1.0000e-012; минимальное значение функции opt(8) равно -1.0000e+000; число выполненных итераций opt(10) равно 9.0000e+000 при максимально допустимом числе итераций opt(14) = 5.0000e+002.
Алгоритм:
Функция fmin реализует методы “золотого сечения” и параболической интерполяции [2].
Сопутствующие функции: FMINS, FZERO, Optimization Toolbox.
Ссылки:
- Optimization Toolbox. User’s Guide. Natick: The MathWorks, Inc., 1991.
- Forsythe G. E., Malcolm M. A., Moler C. B. Computer Methods for Mathematical Computations. Prentice-Hall, 1976.
Наверх
FMINS — минимизация функции нескольких переменных
Синтаксис:
xmin = fmins(‘<имя функции>‘, x0)
xmin = fmins(‘<имя функции>‘, x0, options)
[xmin, options] = fmins(‘<имя функции>‘, x0, options, [ ], arg1,…, arg10)
Описание:
Функция xmin = fmins(‘<имя функции>‘, x0) возвращает вектор xmin, соответствующий значению локального минимума функции в окрестности точки x0.
Функция xmin = fmins(‘<имя функции>‘, x0, options) использует вектор управляющих параметров options, который включает 18 компонентов, соответствующих функции foptions. Функция fmins использует только 4 из этих параметров: options(1), options(2), options(3), options(14).
Функция [xmin, options] = fmins(‘<имя функции>‘, x0, options, [ ], arg1,…, arg10) позволяет передать до 10 параметров; четвертый входной аргумент необходим, чтобы обеспечить совместимость с функцией fminu из пакета Optimization Toolbox [1]. Кроме того, возвращается вектор управляющих параметров options, которые использовались алгоритмом, и в частности, параметр options(10), фиксирующий количество выполненных итераций, и параметр options(8), содержащий минимальное значение функции.
Пример:
Рассмотрим классический пример минимизации функции Розенброка от двух переменных.
.
Минимум этой функции достигается в точке (a, a2) и равен нулю. В качестве начальной точки обычно выбирается точка (-1.2 1).
Определим М-файл rosenbr(x, a), обеспечивающий вычисление этой функции для заданного параметра a.
function y = rosenbr(x, a)
if nargin < 2, a = 1; end
y = 100 * (x(2) — x(1)^2)^2 + (a — x(1))^2;
Рассмотрим случай a = 1.
[xmin, opt] = fmins(‘rosenbr’, [-1.2 1], [0, 1e-6]);
xmin = 9.999997969915502e-001 9.999995750683192e-001
Номер опции opt | Исходное значение | Значение при выходе из функции fmin | ||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
Анализ таблицы подтверждает, что заданная итерационная погрешность opt(2) равна 1.0000e-06; минимальное значение функции opt(8) равно 7.6989e-014; число выполненных итераций opt(10) равно 1.9900e+002 при максимально допустимом числе итераций opt(14) = 4.0000e+002.
Рассмотрим случай, когда минимум сдвинут в точку (sqrt(2), 2).
[xmin, opt] = fmins(‘rosenbr’, [-1.2 1], [0, 1e-6], [ ], sqrt(2));
xmin, opt(8), opt(10)
xmin = 1.414213634743838e+0002.000000234240279e+000
opt(8) = 9.2528e-014
opt(10) = 206
Алгоритм:
Функция fmins реализует метод Нелдера — Мида [2, 3], который является прямым методом, не требующим вычисления градиента или иной информации о производной, и связан с построением симплекса в n-мерном пространстве, который задается n+1-й вершиной. В двумерном пространстве симплекс — это треугольник, а в трехмерном — пирамида.
На каждом шагу алгоритма новая точка выбирается внутри или вблизи симплекса. Значение функции в этой точке сравнивается со значениями в вершинах симплекса, и, как правило, одна из вершин заменяется этой точкой, задавая тем самым новый симплекс. Эти итерации повторяются до тех пор, пока диаметр симплекса не станет меньше заданной величины итерационной погрешности по переменным x.
Сопутствующие функции: FMIN, FZERO, Optimization Toolbox.
Ссылки:
- Optimization Toolbox. User’s Guide. Natick: The MathWorks, Inc., 1991.
- Nelder J. A., Mead R. A Simplex Method for Function Minimization//Computer Journal. Vol. 7, P. 308-313.
- Dennis J. E., Woods D. J. New Computing Environments: Microcomputers in Large-Scale Computing, Ed. by A. Wouk. SIAM, 1987. P. 116-122.
Наверх
FZERO — нахождение нулей функции одной переменной
Синтаксис:
z = fzero(‘<имя функции>‘, x0)
z = fzero(‘<имя функции>‘, x0, tol)
z = fzero(‘<имя функции>‘, x0, tol, trace)
Описание:
Функция z = fzero(‘<имя функции>‘, x0) находит нуль функции в окрестности точки x0.
Функция z = fzero(‘<имя функции>‘, x0, tol) возвращает результат с относительной погрешностью tol, задаваемой пользователем. По умолчанию tol = eps.
Функция z = fzero(‘<имя функции>‘, x0, tol, trace) позволяет выдавать на экран терминала промежуточные результаты поиска нуля функции.
Пример:
Вычислим действительные нули полинома f(x) = x4 — 4 * x3 + 12.
Сначала сформируем М-файл polynom4 для вычисления этой функции:
function y = polynom4(x)
y = x.^4 — 4*x.^3 + 12;
затем найдем корень полинома, стартуя из точки x0 = -0.5:
z = fzero(‘ polynom4’, -0.5, eps, 1)
z = 1.746170944975038e+000;
теперь найдем корень полинома, стартуя из точки x0 = 3.0:
z = fzero(‘ polynom4’, 3, eps, 1)
z = 3.777351952771215e+000;
точные значения корней полинома могут быть вычислены с помощью функции
roots([1 -4 0 0 12])
ans =
3.777351952771212e+000 | |
1.746170944975038e+000 | |
-7.617614488731261e-001 +1.113117638472703e+000i | |
-7.617614488731261e-001 -1.113117638472703e+000i |
Нетрудно видеть, что оба подхода обеспечивают согласованные результаты.
На рис. а показана траектория движения из точки x0 = -0.5, а на рис. б — из точки x0 = 3.0.
Алгоритм:
Функция fzero использует методы деления отрезка пополам, секущей и обратной квадратической интерполяции [1, 2].
Сопутствующие функции: FMIN, ROOTS.
Ссылки:
- Brent R. Algorithms for Minimization Without Derivatives. Prentice-Hall, 1973.
- Forsythe G. E., Malcolm M. A., Moler C. B. Computer Methods for Mathematical Computations. Prentice-Hall, 1976.
Наверх
FPLOT — построение графиков функции одной переменной
Синтаксис:
fplot(‘<имя функции>‘, [<интервал>])
fplot(‘<имя функции>‘, [<интервал>], n)
fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>)
fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>, <дробление шага>)
[x, Y] = fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>, <дробление шага>)
Описание:
Функция fplot(‘<имя функции>‘, [<интервал>]) строит график функции в заданном интервале [xmin xmax].
Функция fplot(‘<имя функции>‘, [<интервал>], n) строит график функции, разбивая интервал минимум на n частей. По умолчанию n = 25.
Функция fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>) строит график так, чтобы изменение угла наклона на соседнем участке отличалось не более чем на величину <приращение угла>. По умолчанию приращение угла = 10°.
Функция fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>, <дробление шага>) выполняет построение графика так, чтобы изменение угла наклона на соседнем участке отличалось не более чем на величину <приращение угла>, но требовало при этом не более чем k дроблений шага. По умолчанию <дробление шага> = 20.
Функция [x, Y] = fplot(‘<имя функции>‘, [<интервал>], n, <приращение угла>, <дробление шага>) возвращает абсциссы и ординаты функции в виде одномерного массива x и, возможно, двумерного массива Y. График при этом не строится. Построение графика можно выполнить в дальнейшем с помощью функции plot(x, y).
Пример:
Построим график функции, используя функцию fplot.
Сначала сформируем М-файл myfun 4 для вычисления двух функций:
function y = myfun(x)
y(:, 1) = 200 * sin(x) ./ x;
y(:, 2) = x .^ 2;
теперь построим график в интервале [-20 20] с разбиением интервала минимум на 50 частей и так, чтобы <приращение угла> не превышало 2°.
Преобразование Фурье
Наверх
FFT, IFFT — одномерное дискретное прямое и обратное преобразования Фурье
Синтаксис:
Y = fft(X) | X = ifft(Y) | |
Y = fft(X, n) | X = ifft(Y, n) |
Описание:
Дискретные прямое и обратное преобразования Фурье для одномерного массива x длины N определяются следующим образом:
Функция Y = fft(X) вычисляет для массива данных X дискретное преобразование Фурье, используя FFT-алгоритм быстрого Фурье-преобразования. Если массив X двумерный, вычисляется дискретное преобразование каждого столбца.
Функция Y = fft(X, n) вычисляет n-точечное дискретное преобразование Фурье. Если length(X) < n, то недостающие строки массива X заполняются нулями; если length(X) > n, то лишние строки удаляются.
Функция X = ifft(Y) вычисляет обратное преобразование Фурье для массива Y.
Функция X = ifft(Y, n) вычисляет n-точечное обратное преобразование Фурье для массива Y.
Примеры:
Основное назначение преобразования Фурье — выделить частоты регулярных составляющих сигнала, зашумленного помехами. Рассмотрим данные, поступающие с частотой 1000 Гц. Сформируем сигнал, содержащий регулярные составляющие с частотами 50 Гц и 120 Гц и случайную аддитивную компоненту с нулевым средним.
t = 0:0.001:0.6;
x = sin(2 * pi * 50 * t) + sin(2 * pi * 120 * t);
y = x + 2 * randn(size(t));
plot(y(1:50)), grid
На рис. а показан этот сигнал. Глядя на него, трудно сказать, каковы частоты его регулярных составляющих. Реализуя одномерное преобразование Фурье этого сигнала на основе 512 точек и построив график спектральной плотности (рис. б), можно выделить две частоты, на которых амплитуда спектра максимальна. Это частоты 120 и 50 Гц.
Y = fft(y, 512);
Pyy = Y.*conj(Y)/512;
f = 1000 * (0:255)/512;
figure(2), plot(f, Pyy(1:256)), grid
Алгоритм:
Если длина последовательности входных данных является степенью числа 2, то применяется алгоритм быстрого преобразования Фурье с основанием 2, имеющий максимальную производительность. Этот алгоритм оптимизирован для работы с действительными данными; если данные комплексные, то реализуется комплексное преобразование Фурье. Эффективность первого на 40 % выше второго.
Если длина входной последовательности не является степенью числа 2, то применяется преобразование со смешанными основаниями, которые определяются как простые множители длины входной последовательности, которая при необходимости подвергается усечению.
Время расчета существенно зависит от значения длины последовательности. Если значение длины точно разлагается на простые множители, то вычисления для такой последовательности выполняются достаточно быстро; если же не все множители оказываются простыми, и даже их будет меньше, то время вычисления существенно возрастает.
Если сравнивать эффективность вычислений, то преобразование Фурье с основанием 2 действительной последовательности из 4096 точек занимает 2.1 с, а комплексной — 3.7 с. Обычное преобразование Фурье для последовательности из 4096 точек занимает 7 с, а для последовательности из 4098 точек — 58 с.
Сопутствующие функции: FFT2, IFFT2, FFTSHIFT, Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
FFT2, IFFT2 — двумерное дискретное прямое и обратное преобразования Фурье
Синтаксис:
Y = fft2(X) | X = ifft2(Y) | |
Y = fft2(X, m, n) | X = ifft2(Y, m, n) |
Описание:
Функция Y = fft2(X) вычисляет для массива данных X двумерное дискретное преобразование Фурье. Если массив X двумерный, вычисляется дискретное преобразование для каждого столбца.
Функция Y = fft(X, n) вычисляет n-точечное дискретное преобразование Фурье. Если length(X) < n, то недостающие строки массива X заполняются нулями; если length(X) > n, то лишние строки удаляются.
Функция X = ifft(Y) вычисляет обратное преобразование Фурье для массива Y.
Функция X = ifft(Y, n) вычисляет n-точечное обратное преобразование Фурье для массива Y.
Примеры:
Рассмотрим тот же пример, что и для функции fft, но сформируем 2 входных последовательности (рис. а):
t = 0:0.001:0.6;
x = sin(2*pi*50*t) + sin(2*pi*120*t);
y1 = x + 2*randn(size(t));
y2 = x + 2*randn(size(t));
y = [y1; y2];
plot(y(1, 1:50)), hold on, plot(y(2, 1:50)), grid, hold off
Применим двумерное преобразование Фурье для сигнала y на основе 512 точек и построим график спектральной плотности. Теперь можно выделить 2 частоты, на которых амплитуда спектра максимальна. Это частоты — 100/2Гц и 240/2Гц.
Y = fft2(y, 2, 512);
Pyy = Y.*conj(Y)/512;
f = 1000*(0:255)/512;
figure(2), plot(f, Pyy(1:256)), grid
Алгоритм:
Двумерное дискретное преобразование связано с одномерным дискретным преобразованием Фурье следующим образом:
fft2(X) = fft(fft(X).’).’
Сопутствующие функции: FFT, IFFT, FFTSHIFT, Signal Processing Toolbox.
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
FFTSHIFT — перегруппировка выходных массивов преобразований Фурье
Синтаксис:
Y = fftshift(X)
Описание:
Функция Y = fftshift(X) перегруппировывает выходные массивы функций fft и fft2, размещая нулевую частоту в центре спектра.
Если v — одномерный массив, то выполняется циклическая перестановка правой и левой его половины:
v | fftshift(v) |
1 2 3 4 5 | 4 5 1 2 3 |
Если X — двумерный массив, то меняются местами квадранты: I « IV и II « III:
X = [‘ I ‘ ‘ II ‘;…
‘ III ‘ ‘ IV ‘;]
fftshift(X)
Пример:
Рассмотрим тот же пример, который рассматривался и для функции fft, но введем постоянную составляющую с уровнем 0.3:
t = 0:0.001:0.6;
x = sin(2 * pi * 50 * t) + sin(2 * pi * 120 * t);
y = x + 2 * randn(size(t)) + 0.3;
plot(y(1:50)), grid
Применим одномерное преобразование Фурье для сигнала y и построим график спектральной плотности. Здесь можно выделить 3 частоты, на которых амплитуда спектра максимальна. Это частоты 0, 58.4 и 140.1 Гц (рис. а).
Y = fft(y);
Pyy = Y.*conj(Y)/512;
f = 1000 * (0:255)/512;
figure(1), plot(f, Pyy(1:256)), grid
ginput
58.4112 | 136.6337 | 140.1869 | 62.3762 | ||
58.4112 | 68.9109 | 140.1869 | 96.8317 |
Выполним операции
Y = fftshift(Y);
Pyy = Y.*conj(Y)/512;
figure(2), plot(Pyy), grid
Из анализа рис. б) следует, что нулевая частота сместилась в середину спектра.
Сопутствующие функции: FFT, FFT2, Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Свертка и фильтрация
Наверх
CONV, DECONV — свертка одномерных массивов
Синтаксис:
z = conv(x, y)
[q, r] = deconv(z, x)
Описание:
Если заданы одномерные массивы x и y длины соответственно m = length(x) и n = length(y), , то свертка z — это одномерный массив длины m + n -1, k-й элемент которого определяется по формуле
.
Функция z = conv(x, y) вычисляет свертку z двух одномерных массивов x и y.
Рассматривая эти массивы как выборки из двух сигналов, можно сформулировать теорему свертки в следующей форме:
Если X = fft([x zeros(1, length(y)-1]) и Y = fft([y zeros(1, length(x) — 1]) — согласованные по размерам преобразования Фурье сигналов x и y, то справедливо соотношение conv(x, y) = ifft(X.*Y).
Иначе говоря, свертка двух сигналов эквивалентна умножению преобразований Фурье этих сигналов.
Функция [q, r] = deconv(z, x) выполняет операцию, обратную операции свертки. Эта операция равносильна определению импульсной характеристики фильтра. Если справедливо соотношение z = conv(x, y), то q = y, r = 0.
Сопутствующие функции: Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
CONV2 — свертка двумерных массивов
Синтаксис:
Z = conv2(X, Y)
Z = conv2(X, Y, ‘<опция>‘)
Описание:
Функция Z = conv2(X, Y) вычисляет свертку Z двумерных массивов X и Y. Если массивы имеют размеры соответственно mx х nx и my х ny, то размер массива Z равен (mx + my — 1) х (nx + ny — 1).
Функция Z = conv2(X, Y, ‘<опция>‘) имеет опцию для управления размером массива Z, которая может принимать следующие значения:
‘full’ — полноразмерная свертка (по умолчанию);
‘same’ — центральная часть размера mx х nx;
‘valid’ — центральная часть размера (mx-my+1) х (nx-ny+1) при условии, что (mx х nx) > (my х ny).
Процедура conv2 выполняется наиболее эффективно, если выполнено условие (mx х nx) > (my х ny), то есть количество элементов массива X превосходит количество элементов массива Y.
Пример:
Рассмотрим два массива X и Y.
X | Y | |||||
8 | 1 | 6 | 1 | 1 | ||
3 | 5 | 7 | 1 | 1 | ||
4 | 9 | 2 |
И вычислим их свертку для различных значений опции.
Z = conv2(X, Y) | Zs = conv2(X, Y, ‘same’) | Zv = conv2(X, Y, ‘valid’) | ||||||||||||||||
|
Сравнивая столбцы последней таблицы, можно понять назначение опций ‘full’, ‘same’, ‘valid’.
Сопутствующие функции: CONV, DECONV, FILTER2, Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
FILTER — дискретная одномерная фильтрация
Синтаксис:
y = filter(b, a, x)
[y, Zf] = filter(b, a, x, Zi)
Описание:
Функция y = filter(b, a, x) фильтрует сигнал, заданный в виде одномерного массива x, используя дискретный фильтр, описываемый конечно-разностными уравнениями вида
y(n) = b(1) * x(n) + b(2) * x(n — 1) + … + b(nb + 1) * x(n — nb)
— a(2) * y(n — 1) — … — a(na + 1) * y(n — na),
при этом входной параметр b = [b(1) b(2) … b(nb + 1)], а параметр a = [a(2) … … a(na+1)].
Функция [y, Zf] = filter(b, a, x, Zi) позволяет учесть запаздывания входного Zi и выходного Zf сигналов.
Сопутствующие функции: FILTER2, Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
FILTER2 — дискретная двумерная фильтрация
Синтаксис:
Y = filter2(B, X)
Y = filter2(B, X, ‘<опция>‘)
Описание:
Функция Y = filter2(B, X) фильтрует сигнал, заданный в виде двумерного массива X, используя дискретный фильтр, описываемый матрицей B. Результат имеет те же размеры, которые имеет и массив X, и вычисляется с использованием двумерной свертки.
Функция Y = filter2(B, X, ‘<опция>‘) имеет опцию для управления размером массива Y, которая может принимать следующие значения:
‘same’ | size(Y) = size(X) (по умолчанию) |
‘valid’ | size(Y) < size(X) |
‘full’ | size(Y) > size(X) |
Пример:
Рассмотрим фильтр B и массив X.
X | B | |||||
8 | 1 | 6 | 1 | 1 | ||
3 | 5 | 7 | 1 | 1 | ||
4 | 9 | 2 |
И вычислим их свертку для различных значений опции.
Y = filter2(B, X) | Y = filter2(B, X, ‘valid’) | Zv = conv2(X, Y, ‘full’) | ||||||||||||||||
|
Сопутствующие функции: CONV2, FILTER, Signal Processing Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1993.
Наверх
UNWRAP — корректировка фазовых углов
Синтаксис:
Q = unwrap(P)
Q = unwrap(P, cutoff)
Описание:
Функция Q = unwrap(P) корректирует фазовые углы элементов одномерного массива P при переходе через значение p, дополняя их значениями ±2p для того, чтобы убрать разрывы функции; если P — двумерный массив, то соответствующая функция применяется к столбцам.
Функция Q = unwrap(P, cutoff) позволяет пользователю изменить значение cutoff критического угла; по умолчанию cutoff = p .
Пример:
Рассмотрим непрерывный неминимально-фазовый фильтр, описываемый передаточной функцией
.
Вычислим частотную характеристику этого фильтра в диапазоне w = 0.1:0.01:10, используя функцию freqresp пакета Control System Toolbox [1].
w = 0.1:0.01:10;
g = freqresp(num, den, sqrt(-1) * w);
Вычислим фазовый угол частотной характеристики без использования и с использованием функции unwrap.
ph1 = (180./pi) * (atan2(imag(g), real(g)));
ph2 = (180./pi) * unwrap(atan2(imag(g), real(g)));
w | ph1 | ph2 |
0.6000 | 126.7350 | 126.7350 |
0.7000 | 141.9270 | 141.9270 |
0.8000 | -158.7123 | 201.2877 |
0.9000 | -135.6888 | 224.3112 |
1.0000 | 135.0000 | -225.0000 |
1.1000 | -139.3435 | 220.6565 |
1.2000 | -145.0993 | 214.9007 |
1.3000 | -151.1794 | 208.8206 |
1.4000 | -157.1667 | 202.8333 |
1.5000 | -162.8839 | 197.1161 |
1.6000 | -168.2575 | 191.7425 |
1.7000 | -173.2642 | 186.7358 |
1.8000 | -177.9068 | 182.0932 |
1.9000 | 177.7986 | 177.7986 |
2.0000 | 173.8298 | 173.8298 |
Из таблицы следует, что при входе и выходе из диапазона частот 0.8-2.0 Гц фазовые углы ph1 при достижении критического угла p терпят разрывы, которые устраняются функцией unwrap.
Построим фазовые частотные характеристики ph1(w) и ph2(w)-360, которые подтверждают сделанные выводы.
semilogx(w, ph1), hold on, grid
semilogx(w, ph2-360, ‘b’)
Сопутствующие функции: ANGLE, ABS, Control System Toolbox [1].
Ссылки:
1. Signal Processing Toolbox User’s Guide. Natick: The MathWorks, Inc., 1990
220 |
Часть II. Моделирование цифровой обработки сигналов в MATLAB |
тервале аппроксимации — совокупности полос пропускания (ПП) и задерживания (ПЗ) КИХ-фильтра.
Веса — числа, всегда большие единицы, — рассчитываются следующим образом:
вес, равный единице, присваивается полосе с наибольшим максимально допустимым отклонением;
веса в остальных полосах рассчитываются как отношение наибольшего максимально допустимого отклонения к максимально допустимому отклонению в данной полосе.
Согласно теореме Чебышева [2], минимум максимальной (по модулю) взвешенной ошибки аппроксимации δmin max достигается в точках альтернанса — частотах, на которых максимальное (по модулю) взвешенное отклонение амплитудной функции (АЧХ равна ее модулю) от идеальной АЧХ минимально δmin max , одинаково и чередуется по знаку1.
Число точек альтернанса взаимосвязано с порядком КИХ-фильтра и не может быть меньшим, чем представленное в табл. 12.1.
Таблица 12.1. Количество точек альтернанса и порядок КИХ-фильтра
Тип КИХ-фильтра |
Число точек |
Порядок фильтра |
|||||||||
альтернанса m |
R |
||||||||||
Тип 1 (Type-1): |
|||||||||||
порядок R — четный; |
m = |
R |
+ 2 |
R = 2m − 4 |
|||||||
ИХ h(n) — симметричная |
2 |
||||||||||
Тип 2 (Type-2): |
|||||||||||
порядок R — нечетный, |
m = |
R −1 |
+ 2 |
R = 2m − 3 |
|||||||
ИХ h(n) — симметричная |
2 |
||||||||||
Тип 3 (Type-3): |
|||||||||||
порядок R — четный; |
m = |
R |
+1 |
R = 2m − 2 |
|||||||
R |
|||||||||||
= 0 |
2 |
||||||||||
ИХ h(n) — антисимметричная и h |
|||||||||||
2 |
|||||||||||
Тип 4 (Type-4): |
|||||||||||
порядок R — нечетный; |
m = |
R −1 |
+ 2 |
R = 2m − 3 |
|||||||
ИХ h(n) — антисимметричная |
2 |
||||||||||
Как уже говорилось (см. разд. 11.1.4), синтез КИХ-фильтра сводится к расчету его импульсной характеристики.
1 Альтернанс (от фр. alternative) — чередование противоположных.
Глава 12. Синтез КИХ-фильтров методом чебышевской аппроксимации |
221 |
Процедура синтеза КИХ-фильтров методом чебышевской аппроксимации является итерационной и включает в себя следующие шаги:
1.Задание требований к АЧХ.
2.Оценка порядка фильтра R.
Оценкой порядка R называют начальное значение порядка в итерационной процедуре синтеза фильтра, которое определяется автоматически по эмпирической формуле на основании требований к АЧХ.
3.Расчет импульсной характеристики фильтра h(n) .
Расчет ИХ h(n) производится с помощью численного метода, разработанного на основе обменного алгоритма Ремеза и известного в англоязычной литературе как алгоритм Паркса—Мак-Клиллена.
Импульсная характеристика может быть как симметричной, так и антисимметричной, поэтому необходимо следить за тем, на основе какого из четырех типов КИХ-фильтров может синтезироваться фильтр требуемой избирательности (см. табл. 11.1).
4.Проверка выполнения требований к АЧХ.
При синтезе в MATLAB программными средствами проверка выполнения требований к АЧХ заключается в сравнении максимальной (по модулю) взвешенной ошибки аппроксимации δmin max с допустимым взвешенным отклонением
δmax АЧХ от идеальной АЧХ, равным (см. разд. 11.1.2).
• для ФНЧ и ФВЧ:
δmax = max{δ1,δ2} ; |
(12.2) |
||
• |
для ПФ: |
||
δmax = max{δ21 |
, δ1, δ22} ; |
(12.3) |
|
• |
для РФ: |
||
δmax = max{δ11 |
, δ2 , δ12}. |
(12.4) |
Возможны две ситуации.
•Требования к АЧХ не выполняются: δmin max > δmax .
Вэтом случае следует увеличить порядок R и вернуться к пп. 3—4.
•Требования к АЧХ выполняются: δmin max ≤ δmax .
Вэтом случае следует уменьшить порядок R и вернуться к пп. 3—4.
В обоих случаях увеличение/уменьшение порядка R продолжается до тех пор, пока не будет найден оптимальный (минимальный) порядок Ropt , при котором выполняются требования к АЧХ.
5. Выбор структуры КИХ-фильтра (см. табл. 11.2).
222 |
Часть II. Моделирование цифровой обработки сигналов в MATLAB |
12.1.2. Синтез КИХ-фильтров
методом чебышевской аппроксимации в MATLAB
Синтез оптимальных КИХ-фильтров методом чебышевской аппроксимации выполняется с помощью функции:
[b,error,opt] = firpm(R,f0,m0,weight,ftype,{lgrid})
где R — порядок фильтра R (11.2); f0 — вектор-столбец нормированных частот
fˆ = |
f |
[ |
] |
||
fд |
2 |
в основной полосе |
0;1 , включающий левую границу основной полосы |
||
частот (0) , граничные частоты ПП и ПЗ в порядке их следования слева направо и правую границу основной полосы (1); m0 — вектор-столбец значений идеальной АЧХ на частотах вектора f0; длины векторов m0 и f0 совпадают; weight — векторстолбец весов в ПП и ПЗ в порядке следования слева направо; ftype — параметр, указывающий тип КИХ-фильтра и принимающий значения (см. табл. 11.1):
‘hilbert’ — для 3-го и 4-го типов и цифровых преобразователей Гильберта;
‘differentiator’ — для 3-го и 4-го типов и цифровых дифференциаторов;
по умолчанию (если параметр отсутствует) — для 1-го и 2-го типов;
‘ ‘ (пробел) — тождественно отсутствию параметра ftype.
lgrid — коэффициент плотности сетки частот (Density Factor); указывается элементом массива ячеек (см. разд. 3.1.4) в фигурных скобках и равен целому числу, большему 16-ти (по умолчанию — 16); с ростом lgrid возрастает точность вычисления коэффициентов b, и вместе с тем — объем вычислений.
b — вектор коэффициентов передаточной функции (11.1) длины N = R +1 .
opt — массив записей (см. разд. 3.1.4) со следующими полями:
opt.fgrid — сетка нормированных частот (вектор) на интервале аппроксимации (совокупности ПП и ПЗ) в шкале нормированных частот fˆ ; правая граница
основной полосы частот, равная единице, не выводится;
opt.H — вектор значений комплексной частотной характеристики на сетке час-
тот opt.fgrid;
opt.error — вектор отклонений АЧХ от идеальной на сетке частот opt.fgrid;
opt.des — вектор значений идеальной АЧХ на сетке частот opt.fgrid;
opt.wt — вектор весов на сетке частот opt.fgrid;
opt.iextr — вектор номеров элементов вектора opt.fgrid, соответствующих
частотам альтернанса;
opt.fextr — вектор нормированных частот альтернанса.
error — максимальная (по модулю) взвешенная ошибка аппроксимации δmin max
(см. разд. 12.1.1): error = max(abs(opt.error)).
length(f) =
Глава 12. Синтез КИХ-фильтров методом чебышевской аппроксимации |
223 |
Оценка порядка R КИХ-фильтра для функции firpm, а также вычисление параметров f0, m0, weight производится по требованиям к АЧХ с помощью функции:
[R,f0,m0,weight] = firpmord(f,m,ripple,Fs)
где f — вектор граничных частот ПП и ПЗ в порядке их следования слева направо
в шкале частот f (Гц) в основной полосе |
0; f |
2 |
; m — вектор значений идеальной |
|
д |
АЧХ в порядке их следования слева направо; соблюдается условие 2*length(m)-2; ripple — вектор максимально допустимых отклонений АЧХ в порядке их следования слева направо; Fs — частота дискретизации fд (Гц); R —
оценка порядка фильтра R с точностью до ±2.
Остальные параметры были определены ранее для функции firpm.
12.1.3. Описание требований к характеристике затухания в виде объекта fdesign
В MATLAB имеются средства синтеза КИХ- и БИХ-фильтров непосредственно в виде объекта dfilt (см. разд. 11.1.3). В этом случае требования задаются к характеристике затухания АЧХ (дБ) (11.6) и описываются в виде объекта fdesign:
Hs = fdesign.type([‘sp1,sp2,…’,]sp1,sp2,…,Fs)
где Hs — имя объекта fdesign; fdesign — тип объекта; type — функция, задающая конкретный тип избирательности ЦФ (табл. 12.2); ‘sp1,sp2,…’ — список обязательных параметров функции type.
Список обязательных параметров строго регламентирован и соответствует требованиям к АЧХ (дБ). В табл. 12.3—12.6 приводятся списки обязательных параметров для различных функций type; в круглых скобках указаны те же параметры, которые используются при выводе свойств объекта fdesign.
sp1,sp2,… — значения обязательных параметров в списке ‘sp1,sp2,…’. Принятый по умолчанию список параметров ‘sp1,sp2,…’ может отсутствовать, однако его удобно оставлять для идентификации значений параметров.
Fs — частота дискретизации fд (Гц).
Свойства объекта fdesign выводятся по его имени Hs и включают в себя список обязательных параметров функции type с их значениями.
Таблица 12.2. Функции type для частотно-избирательных ЦФ |
||
Функция type |
Тип избирательности ЦФ |
|
lowpass |
Lowpass Filter — ФНЧ |
|
highpass |
Highpass Filter — ФВЧ |
|
bandpass |
Bandpass Filter — ПФ |
|
bandstop |
Bandstop Filter — РФ |
|
224 Часть II. Моделирование цифровой обработки сигналов в MATLAB
Таблица 12.3. Список параметров объекта fdesign.lowpass
Параметры функции |
Требования к АЧХ (дБ) ФНЧ |
|||
lowpass |
||||
Fp (Fpass) |
fχ |
— граничная частота ПП |
||
Fst (Fstop) |
fk |
— граничная частота ПЗ |
||
Ap (Apass) |
amax |
(дБ) — максимально допустимое затухание в ПП |
||
Ast (Astop) |
amin |
(дБ) — минимально допустимое затухание в ПЗ |
||
Таблица 12.4. Список параметров объекта fdesign.highpass
Параметры функции |
Требования к АЧХ (дБ) ФВЧ |
|||
highpass |
||||
Fst (Fstop) |
fk |
— граничная частота ПЗ |
||
Fp (Fpass) |
fχ |
— граничная частота ПП |
||
Ast (Astop) |
amin |
(дБ) — минимально допустимое затухание в ПЗ |
||
Ap (Apass) |
amax |
(дБ) — максимально допустимое затухание в ПП |
||
Таблица 12.5. Список параметров объекта fdesign.bandpass
Параметры функции |
Требования к АЧХ (дБ) ПФ |
|||
bandpass |
||||
Fst1 (Fstop1) |
f−k |
— граничная частота ПЗ1 |
||
Fp1 (Fpass1) |
f−χ |
— левая граничная частота ПП |
||
Fp2 (Fpass2) |
fχ |
— правая граничная частота ПП |
||
Fst2 (Fstop2) |
fk |
— граничная частота ПЗ2 |
||
Ast1 (Astop1) |
a1min |
(дБ) — минимально допустимое затухание в ПЗ1 |
||
Ap (Apass) |
amax |
(дБ) — максимально допустимое затухание в ПП |
||
Ast2 (Astop2) |
a2min |
(дБ) — минимально допустимое затухание в ПЗ2 |
||
Глава 12. Синтез КИХ-фильтров методом чебышевской аппроксимации |
225 |
Таблица 12.6. Список параметров объекта fdesign.bandstop
Параметры функции |
Требования к АЧХ (дБ) РФ |
|||
bandstop |
||||
Fp1 (Fpass1) |
f−χ |
— граничная частота ПП1 |
||
Fst1 (Fstop1) |
f−k |
— левая граничная частота ПЗ |
||
Fst2 (Fstop2) |
fk |
— правая граничная частота ПЗ |
||
Fp2 (Fpass2) |
fχ |
— граничная частота ПП2 |
||
Ap1 (Apass1) |
a1max |
(дБ) — максимально допустимое затухание в ПП1 |
||
Ast (Astop) |
amin |
(дБ) — минимально допустимое затухание в ПЗ |
||
Ap2 (Apass2) |
a2max (дБ) — максимально допустимое затухание в ПП2 |
|||
12.1.4. Синтез КИХ-фильтров в виде объектов dfilt на основе объектов fdesign
При задании требований к АЧХ (дБ) в виде объекта fdesign для синтеза КИХфильтров в виде объекта dfilt используются функции, представленные в табл. 12.7. Отметим, что порядки КИХ-фильтров, синтезированных с помощью функций kaiserwin и equiripple, могут отличаться от соответствующих порядков КИХ-фильтров, синтезированных с помощью функций fir1 и firpm, что объясняется различием алгоритмов синтеза.
Таблица 12.7. Функции синтеза КИХ-фильтра в виде объекта dfilt |
|
Функция |
Метод синтеза |
kaiserwin |
Окон с использованием окна Кайзера |
equiripple |
Наилучшей равномерной (чебышевской) аппроксимации |
Обобщенный формат функции синтеза КИХ-фильтра в виде объекта dfilt на основе объекта fdesign представлен двумя разновидностями:
Hf = function_fir(Hs)
Hf = design(Hs,’function_fir‘)
где function_fir — имя конкретной функции из табл. 12.7; Hs — имя объекта
fdesign; Hf — имя объекта dfilt.
226 |
Часть II. Моделирование цифровой обработки сигналов в MATLAB |
По умолчанию выбирается прямая структура КИХ-фильтра (Direct-Form FIR). Для выбора прямой приведенной структуры (см. табл. 11.2) можно воспользоваться расширенным форматом функции синтеза КИХ-фильтра:
Hf = design(Hs,’function_fir‘,’FilterStructure’,‘structure’)
где ‘structure’ — функция, задающая конкретную структуру объекта Hf (см. табл. 11.2).
Вычисление частотной (H) и импульсной (h) характеристик КИХ-фильтра, синтезированного в виде объекта dfilt, выполняется с помощью функций соответственно:
H = freqz(Hf,N)
h = impz(Hf)
где N — число точек (значений) частотной характеристики; в отсутствии параметра по умолчанию N = 512.
При выводе графиков АЧХ и ФЧХ в N точках в основной полосе значения частот в герцах задаются в виде вектора (где Fs — частота дискретизации):
f = 0:((Fs/2)/(N-1)):Fs/2;
12.2. Содержание лабораторной работы
Содержание работы связано с синтезом КИХ-фильтров методом наилучшей равномерной (чебышевской) аппроксимации, описанием их структур и анализом характеристик с использованием программных средств MATLAB.
12.3. Задание на лабораторную работу
Лабораторная работа выполняется на основе script-файлов с именами lr_12_low,
lr_12_high, lr_12_pass и lr_12_stop и function-файлов plot_fir и MAG_fir, которые
хранятся на прилагаемом компакт-диске в папке LAB_DSPLAB_12.
Перед выполнением работы необходимо сохранить путь к папке LAB_12 по команде контекстного меню Add to Path | Selected Folders.
Исходные данные для пунктов задания приводятся в табл. 12.8—12.11 для номера бригады Nбр , где Nбр =1, 2, … , 30 , и для КИХ-фильтров ФНЧ, ФВЧ, ПФ и РФ
включают в себя:
требования к АЧХ;
требования к характеристике затухания АЧХ (дБ) (11.6) для ее описания в виде объекта fdesign. Значения допустимых затуханий рассчитаны по формулам (11.7)—(11.8).
На прилагаемом компакт-диске в папке TablesTables_12 хранятся табл. 12.8— 12.11 исходных данных, примеры их заполнения для Nбр =1 и табл. 12.12 для п. 2 задания.
Глава 12. Синтез КИХ-фильтров методом чебышевской аппроксимации |
227 |
||||||||||||
Таблица 12.8. Требования к АЧХ и АЧХ (дБ) ФНЧ |
|||||||||||||
Условные |
Список требований |
Задаваемые значения |
Идентификатор |
||||||||||
обозначения |
|||||||||||||
fд |
Частота дискретизации |
fд = 5000 +100Nбр |
Fs = |
||||||||||
fχ |
Граничная частота ПП |
fχ |
fд |
20Nбр |
ft = |
||||||||
= |
10 |
+ |
|||||||||||
fk |
Граничная частота ПЗ |
fk |
fд |
250 + 25Nбр |
fk = |
||||||||
= |
+ |
||||||||||||
10 |
|||||||||||||
δ |
Максимально допустимое |
δ |
= 0, 05 |
d1 = 0.05 |
|||||||||
1 |
1 |
||||||||||||
отклонение в ПП |
|||||||||||||
δ |
2 |
Максимально допустимое |
δ |
2 |
= 0, 01 |
d2 = 0.01 |
|||||||
отклонение в ПЗ |
|||||||||||||
amax |
Максимально допустимое |
amax = 0, 4455 |
Ap = 0.4455 |
||||||||||
затухание в ПП (дБ) |
|||||||||||||
a |
Минимально допустимое |
a |
= 40 |
Ast = 40 |
|||||||||
min |
min |
||||||||||||
затухание в ПЗ (дБ) |
|||||||||||||
Таблица 12.9. Требования к АЧХ и АЧХ (дБ) ФВЧ
Условные |
Список требований |
Задаваемые значения |
Идентификатор |
|||||||||
обозначения |
||||||||||||
fд |
Частота дискретизации |
fд = 5000 +100Nбр |
Fs = |
|||||||||
fk |
Граничная частота ПЗ |
fχ |
fд |
20Nбр |
fk = |
|||||||
= |
10 |
+ |
||||||||||
fχ |
Граничная частота ПП |
fk |
fд |
250 + 25Nбр |
ft = |
|||||||
= |
+ |
|||||||||||
10 |
||||||||||||
δ |
2 |
Максимально допустимое |
δ |
2 |
= 0, 01 |
d2 = 0.01 |
||||||
отклонение в ПЗ |
||||||||||||
δ |
Максимально допустимое |
δ |
= 0, 05 |
d1 = 0.05 |
||||||||
1 |
1 |
|||||||||||
отклонение в ПП |
||||||||||||
a |
Минимально допустимое |
a |
= 40 |
Ast = 40 |
||||||||
min |
min |
|||||||||||
затухание в ПЗ (дБ) |
||||||||||||
amax |
Максимально допустимое |
amax = 0, 4455 |
Ap = 0.4455 |
|||||||||
затухание в ПП (дБ) |
||||||||||||
228 |
Часть II. Моделирование цифровой обработки сигналов в MATLAB |
||||||||||||||||
Таблица 12.10. Требования к АЧХ и АЧХ (дБ) ПФ |
|||||||||||||||||
Условные |
Список требований |
Задаваемые значения |
Идентификатор |
||||||||||||||
обозначения |
|||||||||||||||||
fд |
Частота дискретизации |
fд = 5000 +100Nбр |
Fs = |
||||||||||||||
f−k |
Граничная частота ПЗ1 |
f−k |
fд |
20Nбр |
fk1 = |
||||||||||||
= |
+ |
||||||||||||||||
20 |
|||||||||||||||||
f−χ |
Граничная частота ПП1 |
f−χ = |
fд |
250 + 25Nбр |
ft1 = |
||||||||||||
+ |
|||||||||||||||||
20 |
|||||||||||||||||
fχ |
Граничная частота ПП2 |
fд |
ft2 = |
||||||||||||||
fχ |
= |
+ 25Nбр |
|||||||||||||||
4 |
|||||||||||||||||
fk |
Граничная частота ПЗ2 |
fд |
fk2 = |
||||||||||||||
fk |
= |
+ 250 + 30Nбр |
|||||||||||||||
4 |
|||||||||||||||||
δ21 |
Максимально допустимое |
δ21 = 0, 01 |
d21 = 0.01 |
||||||||||||||
отклонение в ПЗ1 |
|||||||||||||||||
δ1 |
Максимально допустимое |
δ1 = 0, 05 |
d1 = 0.05 |
||||||||||||||
отклонение в ПП |
|||||||||||||||||
δ22 |
Максимально допустимое |
δ22 = 0, 01 |
d22 = 0.01 |
||||||||||||||
отклонение в ПЗ2 |
|||||||||||||||||
a1min |
Минимально допустимое |
a1min = 40 |
Ast1 = 40 |
||||||||||||||
затухание в ПЗ1 (дБ) |
|||||||||||||||||
amax |
Максимально допустимое |
amax = 0, 4455 |
Ap = 0.4455 |
||||||||||||||
затухание в ПП (дБ) |
|||||||||||||||||
a2min |
Минимально допустимое |
a2min = 40 |
Ast2 = 40 |
||||||||||||||
затухание в ПЗ2 (дБ) |
|||||||||||||||||
Таблица 12.11. Требования к АЧХ и АЧХ (дБ) РФ |
|||||||||||||||||
Условные |
Список требований |
Задаваемые значения |
Идентификатор |
||||||||||||||
обозначения |
|||||||||||||||||
fд |
Частота дискретизации |
fд = 5000 +100Nбр |
Fs = |
||||||||||||||
f−χ |
Граничная частота ПП1 |
f−χ |
fд |
20Nбр |
ft1 = |
||||||||||||
= |
20 |
+ |
|||||||||||||||
f−k |
Граничная частота ПЗ1 |
f−k |
fд |
250 + 25Nбр |
fk1 = |
||||||||||||
= |
+ |
||||||||||||||||
20 |
|||||||||||||||||
fk |
Граничная частота ПЗ2 |
fд |
fk2 = |
||||||||||||||
fk |
= |
+ 25Nбр |
|||||||||||||||
4 |
|||||||||||||||||
Глава 12. Синтез КИХ-фильтров методом чебышевской аппроксимации |
229 |
|||||||||
Таблица 12.11 (окончание) |
||||||||||
Условные |
Список требований |
Задаваемые значения |
Идентификатор |
|||||||
обозначения |
||||||||||
fχ |
Граничная частота ПП2 |
fд |
ft2 = |
|||||||
fχ = |
+ 250 + 30N |
бр |
||||||||
4 |
||||||||||
δ11 |
Максимально допустимое |
δ11 = 0, 05 |
d11 = 0.05 |
|||||||
отклонение в ПП1 |
||||||||||
δ2 |
Максимально допустимое |
δ2 = 0, 01 |
d2 = 0.01 |
|||||||
отклонение в ПЗ |
||||||||||
δ12 |
Максимально допустимое |
δ12 = 0, 05 |
d12 = 0.05 |
|||||||
отклонение в ПП2 |
||||||||||
a1max |
Максимально допустимое |
a1max = 0, 4455 |
Ap1 = 0.4455 |
|||||||
затухание в ПП1 (дБ) |
||||||||||
a |
Минимально допустимое |
a |
= 40 |
Ast = 40 |
||||||
min |
min |
|||||||||
затухание в ПЗ (дБ) |
||||||||||
a |
2max |
Максимально допустимое |
a |
2max |
= 0, 4455 |
Ap2 = 0.4455 |
||||
затухание в ПП2 (дБ) |
||||||||||
Задание на лабораторную работу заключается в синтезе КИХ-фильтров методом наилучшей равномерной (чебышевской) аппроксимации и анализе их характеристик и для каждого типа избирательности (ФНЧ, ФВЧ, ПФ или РФ) включает
всебя выполнение следующих пунктов:
1.Ввод требований к АЧХ.
2.Вычисление оценки порядка КИХ-фильтра и значения весов в ПП и ПЗ. Выведенные значения весов (weight) внести в табл. 12.12.
Пояснить:
•какая функция используется для вычисления оценки порядка КИХ-фильтра и весов;
•с какой целью рассчитывается оценка порядка КИХ-фильтра;
•как рассчитываются веса в ПП и ПЗ.
Таблица 12.12. Результаты синтеза оптимальных КИХ-фильтров
Тип избиратель- |
Метод чебышевской аппроксимации |
||
ности фильтра |
порядок фильтра R |
тип КИХ-фильтра |
вектор весов weight |
ФНЧ |
|||
ФВЧ |
|||
ПФ |
|||
РФ |
|||
МНК и его погрешность
25
Вторник
Ноя 2008
В эксперименте были намеряны значения , которым соответствуют . После получения апроксимирующего полинома (в нашем случае прямой ), нужно узнать погрешности коэффициентов и самой аппроксимации.
Остаточная дисперсия (она же дисперсия адекватности) имеет вид
,
где — количество коэффициентов полинома. Считается, что модель выбрана хорошая, если остаточная дисперсия сравнима по своему значению с дисперсией воспроизводимости, равной
.
В общем случае для , .
Далее для линейной зависимости
;
.
Соответствующий матлабовский скрипт:
function PP = LSM(x, y, k)
% — Усреднение по методу наименьших квадратов —-
%
% Входные параметры:
% x, y — векторы абсциссы и ординаты, где y = f(x);
% k — количество параметров МНК, фактически равно степени полинома,
% которым приближается зависимость, плюс 1 (для линейной апроксимации
% k = 2).
%
% Выход функции:
% P — массив коефициентов МНК. Для линейной зависимости
% y = a * x + b = P(1) * x + P(2). Остальные параметры несут смысл лишь
% при линейной зависимости (k = 2).
% S_a, S_b — дисперсии a и b.
% S_X и S_Y — дисперсии X и Y (обратная и прямая регресионная задача).
n = length(x);
if (n — length(y) ~= 0)
disp(‘Векторы должны иметь одинаковую размерность!’);
return;
end
if (n == k)
disp(‘Размерность апроксимирующего полинома должна быть меньше’);
disp(‘количества длины входного вектора данных!’);
return;
end
P = polyfit(x, y, k — 1);
Y = polyval(P, x);
S_y2 = 0;
temp2 = 0;
temp1 = 0;
for i=1:1:n
S_y2 = S_y2 + (Y(i) — y(i)).^2;
temp1 = temp1 + x(i);
temp2 = temp2 + x(i).^2;
end
S_y2 = S_y2 / (n — k);
if (k == 2)
temp3 = n * temp2 — temp1^2;
S_a = sqrt(n * S_y2 / temp3);
S_b = sqrt(temp2 / temp3 * S_y2);
S_Y = sqrt(S_y2);
S_X = S_Y * sqrt(1/n + 1 + n * (n — 1) * std(y)^2 / temp3 / P(1)^2) / P(1);
else
S_a = -1;
S_b = -1;
S_Y = -1;
S_X = -1;
end
disp(‘Коэффициенты аппроксимирующего полинома:’);
disp(P);
if (k == 2)
disp(‘Линейная аппроксимация Y = ax + b:’);
disp(‘Дисперсия a S_a = ‘);
disp(S_a);
disp(‘Дисперсия b S_b = ‘);
disp(S_b);
disp(‘Обратная регрессионная задача S_X = ‘);
disp(S_X);
disp(‘Прямая регрессионная задача S_Y = ‘);
disp(S_Y);
end
PP = [P S_a S_b S_X S_Y];
return;