Форум программистов, компьютерный форум, киберфорум
Matlab
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/19: Рейтинг темы: голосов - 19, средняя оценка - 4.53
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37

Спектральный анализ функции

05.07.2014, 15:54. Показов 4305. Ответов 18
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите провести спектральный анализ следующей функции
x(t)=1.0+2.5cos(t)-1.5sin(t)+0.7cos(2t)-0.2sin(3t)

И мог бы кто нибудь разжевать что такое спектральный анализ периодического сигнала. Я что-то вообще не в зуб ногой.. =/
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.07.2014, 15:54
Ответы с готовыми решениями:

Спектральный анализ напряжения
Всем привет, сижу мучаюсь который день как собственно сделать спектральный анализ выходного сигнала (напряжения на электродвигателе) но не...

Спектральный анализ и статистика
Добрый день, Уже достаточно долго пытаюсь разобраться с fft и оцениванием результатов. В итоге, пришла к выводу, что, возможно,...

Спектральный анализ сигнала
Добрый день! Нужна помощь, есть сигнал записанный на осциллографе в формате exsel таблицы, 2 столбца (Амплитуда, Время). Подскажите как...

18
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
05.07.2014, 17:19
bossuy, спектральный анализ (периодической функции) - есть разложение в ряд Фурье. Ищите в этом ключе. В матлабе Вам с этим заданием поможет справиться функция fourier либо же fft. Если возникнут конкретные вопросы - пишите.
1
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
05.07.2014, 17:31  [ТС]
R2D2, Спасибо. Может есть какая-нибудь более-менее понятная литература?
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
05.07.2014, 18:55
Классический учебник:
Баскаков С. И. Радиотехнические цепи и сигналы

Если для глубокого "погружения":
Сизиков В.С. Устойчивые методы обработки результатов измерений

Есть примеры на MATLAB:
Сергиенко_Цифровая обработка сигналов. MATLAB
3
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
05.07.2014, 19:17  [ТС]
R2D2, Nick07, Не могли бы Вы еще взглянуть на этот небольшой код..

Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
%Шаг 1. Генерируем шкалу времени от 0 до 1 секунды с шагом в 1/16384 секунды (получится всего 16385 шагов). Массив t из 16385 элементов содержит значения времени.
t = 0:1/16384:1;
 
%Шаг 2. Генерим массивы амплитудами сигналов. В результате получим массивы U1..U5, в каждом из которых 16385 значения сигнала.
U1      = 1             ;
U2      = 2.5  *cos(  t);
U3      = -1.5 *sin(  t);
U4      = 0.7  *cos(2*t);
U5      = -0.2 *sin(3*t);
 
%Шаг 3. Суммируем все сигналы между собой. В результате получим массив x из 16385 значений.
x = U1+U2+U3+U4+U5;
 
%Шаг 4. Для того, чтобы сигнал отображался "красиво", вводим оконную функцию Хемминга. В результате получим массив оконного распределения w из 16385 значений. Операция ".'" нужна для транспонирования оконного массива (он был столбцом, нужно получить строку).
w = hamming(16385).';
 
%Шаг 5. Чтобы было "совсем реально", добавим немного шума. Здесь "size(t)" соответствует "1, 16385", т. е. вызов randn(size(t)) это то же самое, что вызов randn(1, 16385).
 x = x + 0.001*randn(size(t));
 
%Шаг 6. Применим оконную функцию к сигналу x, в результате получим массив z из 16385 значений. Здесь операция ".*" означает "перемножить каждый элемент массива w с соответствующим элементом массива x"
z = w.*x;
 
%Шаг 7. Делаем дискретное преобразование фурье (ДПФ) от сигнала z по 16384 точкам. В результате получим массив комплексных чисел Y (всего 16384 комплексных числа)
Y = fft(z,16384);
 
%Шаг 8. Вычисляем спектральную плотность по мощности, короче говоря - спектр (чего мы и добивались). В результате получим массив Pyy из 16384 значений. Здесь коэффициенты 5000 и 10000 подобраны таким образом, чтобы сместить значение десятичного логагифма в диапазон значений целого беззнакового 16-битного числа 0..65535.
Pyy = 5000 * log10(Y.*conj(Y) * 10000);
 
%Шаг 9. Нарисуем график нашего спектра
%Подготовим ось X - ось частот от 0 до 8191 Гц
f =  (0:8191);
% и нарисуем график. Рисуем не весь массив, а только половину (вторая половина Pyy является зеркальным отображением первой).
plot(f,Pyy(1:8192))
title ('Удельная мощность спектра')
xlabel('Частота (Hz)')
grid
График тот что получается при выполнении этого кода и есть спектральным анализом данной функции? или нет?
Извините, если спрашиваю полную чушь =/
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
05.07.2014, 22:13
Посмотрите пример спектрального анализа:
http://www.mathworks.com/help/matlab/ref/fft.html
Там функция состоит из двух синусоид с разными частотами и на графике соответственно ДВА пика на этих частотах.
1
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
06.07.2014, 14:07  [ТС]
Всем спасибо за ответы. Очень помогли.

Тему закрываю.

Может кому-то пригодится

Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Fs = 1; % Частота дискретизации
T = 1/Fs; % период дискретизации
L = 1000; % длина сигнала
t = (0:L-1)*T; % вектор времени 
x = 1+2.5*cos(t)-1.5*sin(t)+0.7*cos(2*t)-0.2*sin(3*t);
y = x + 0.6*randn(size(t)); % Добавление шума в функцию
subplot(1,2,1)
plot(Fs*t(1:50),y(1:50))
title('Сигнал поврежденный случайным шумом')
xlabel('Время (в миллисекундах)')
 
NFFT = 2^nextpow2(L); % следующая степень числа 2 от длины y
Y = fft(y,NFFT)/L; % fft - одномерное прямое дискретное 
                   % преобразование в ряд Фурье                   
f = Fs/2*linspace(0,1,NFFT/2+1); % linspace - генерация 
                                 % арифметической прогрессии
% Участок одностороннего амплитудного спектра.
subplot(1,2,2)
plot(f,2*abs(Y(1:NFFT/2+1))) 
title('Односторонняя амплитуда спектра y(t)')
xlabel('Частота (Гц)')
ylabel('|Y(f)|')
Скрин:
1
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
06.07.2014, 21:11
bossuy, я тут еще немного намекнуть хочу:
Цитата Сообщение от bossuy Посмотреть сообщение
Fs = 1; % Частота дискретизации
Цитата Сообщение от bossuy Посмотреть сообщение
x = 1+2.5*cos(t)-1.5*sin(t)+0.7*cos(2*t)-0.2*sin(3*t);
На теоремку Котельникова намекаю, если что
0
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
06.07.2014, 22:01  [ТС]
R2D2, а что там не так? насколько я понимаю что по теореме Котельникова
Fs≥(2*3t), Fs=1, 2*3t=2*3*1/2pi≈0.955, следовательно условие выполняется...

единственное что мне показалось. так это можно уменьшить период
Цитата Сообщение от bossuy Посмотреть сообщение
T = 1/(3*Fs); % период дискретизации
0
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
06.07.2014, 23:41
У Вас максимальная частота синуса = 3 рад/с. Соответственно - частота дискретизации 6 рад/с (теоретический минимум, при котором, в общем то, можно и вообще ноль получить после дискретизации )
1
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
07.07.2014, 13:55  [ТС]
R2D2, спасибо, исправил.
Подскажите пожалуйста как подписать по горизонтальной оси вместо частоты в герцах, номера соответствующих гармоник 1,2,...
0
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
07.07.2014, 15:10
bossuy, накинь в пейнте как это должно быть, что б долго не распрашивать.
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
07.07.2014, 17:34
Ось Х нормировать в номера гармоник

Проще всего использовать text и на графике указать номер гармоники.
0
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
07.07.2014, 18:30  [ТС]
Nick07,
Цитата Сообщение от Nick07 Посмотреть сообщение
Проще всего использовать text и на графике указать номер гармоники.
text, тут скорей всего не подойдет, так как значения частот все равно остается на оси...

Цитата Сообщение от Nick07 Посмотреть сообщение
Ось Х нормировать в номера гармоник
Не подскажите как реализовать именно этот момент? Что бы график строился как и сейчас по частоте, а подписывало значения гармоник..
0
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
07.07.2014, 18:52
bossuy, юзай свойства XTickLabel и XTick. Пробуй, разбирайся, если что - пиши.
1
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
10.07.2014, 13:39  [ТС]
R2D2, не подскажешь, как из всего графика выводить на экран только гармоники?
Я не могу нигде найти как рассчитывается гармоника, что бы потом "выхватывать" нужные значения =/
0
Эксперт по электронике
 Аватар для R2D2
939 / 839 / 121
Регистрация: 23.11.2012
Сообщений: 2,488
10.07.2014, 14:07
bossuy, сделай БПФ (с помощью fft), далее найди гармоники (findpeaks) и нарисуй их каким нибудь stem'ом. Было дело, мы со здешним гуру похожую тему раскручивали
0
533 / 438 / 47
Регистрация: 17.07.2013
Сообщений: 2,236
10.07.2014, 19:08
Гармоника - частота колебаний, кратная основной частоте.
Основная частота = F*1
Первая гармоника = F*2
Вторая гармоника = F*3 и т.д..
Сумма синусов и косинусов гармоник с разными множителями составляют исследуемый сигнал.
Разделите анализируемый диапазон частот на основную частоту и получите точку на оси Х равную 1, где на оси частот расположена основная частота, Х=2 соответственно, где частота удвоенная и т.д..
0
9 / 9 / 0
Регистрация: 04.07.2014
Сообщений: 37
13.07.2014, 23:34  [ТС]
R2D2, теперь у меня возникла следующая проблема:
Картинка получается красивой и почти соответствует действительности, но все же немного не то, а именно должно быть omega2:omega1=2, а у меня получается =1,7499 и практически везде так... только omega5:omega1=5,00001

файл diffsys.m
Matlab M
1
2
3
4
5
6
7
8
function dxdt = diffsys(t, x)
b=0;
y=0.5;
P=0;
w=2.0;
dxdt(1,1) = x(2); 
dxdt(2,1) = P*cos(w*t)-b*x(2)-x(1)-y*x(1).^3; 
end
ну сам код:
Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
clear, clc
 
tk = [0 15]; 
x0 = [0.01 0];
[T X] = ode45('diffsys',tk,x0);
X=X';
for i=1:size(T,1)
    x(i)=X(2,i);
end
L=size(x,2);
NFFT = 2^nextpow2(L); 
Y1 = fft(x,NFFT)/L;                  
f = linspace(0,1,NFFT/2+1);
Y(1)=abs(Y1(1));
for i=2:NFFT/2+1
Y(i)=2*abs(Y1(i));
end
[pks locks]=findpeaks(Y);
stem (f(locks(1:10)), pks(1:10))
set(gca,'XTick',f(locks))
set(gca,'XTickLabel',f(locks)*2*pi)
xlabel('Угловая скорость')
ylabel('|Y(f)|')


Преподаватель сказал следующее: "Советую проварьировать длину промежутка , на котором производится разложение функции,по науке его длина должна быть кратна периоду первой гармоники,а также число выбираемых на нем точек."

Я что-то уже вторые сутки сижу и не могу понять, как и что мне нужно варьировать =/
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.07.2014, 23:34
Помогаю со студенческими работами здесь

Спектральный анализ осциллограмм
Доброго времени суток! Нужно сделать спектральный анализ средствами mathcad или matlab. Только сигналы заданы в виде картинок jpeg. Как...

Спектральный анализ в матлабе
то что нужно сдлелать смотрите пожалуйста ниже=) вариант 5

Гармонический и спектральный анализ в Matlab
Доброго времени суток! Сразу прошу прощения за создание аналогичной темы, но в похожих темах ответа так и не нашел. Я полный профан в плане...

Спектральный анализ данных в Matlab
Добрый день! Зарегистрировался на вашем форуме, т.к. надеюсь, что вы мне поможете. Сначала небольшое отступление - я аспирант,...

Спектральный анализ несинусоидального сигнала в Matlab
Доброго времени суток! Прошу Вашей помощи так как в матлабе я новичок, только учусь, поэтому если, что то спрашиваю не то прощу прошения...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru