Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.59/29: Рейтинг темы: голосов - 29, средняя оценка - 4.59
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9

Обработка звука: оконное преобразование Фурье и вывод разными цветами

08.04.2016, 17:11. Показов 5871. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ребят,помогите пожалуйста!!! Программирование только началось, а задания как-то нужно делать.Кучу книг перечитала. В общем дали задание в котором нужно загрузить звук,сделать его оконное преобразование Фурье и чтобы итоговые графики выводились разными цветами. Всё это нужно в Visual C# 2010 сделать
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.04.2016, 17:11
Ответы с готовыми решениями:

Частота звука в Wav файле (найти через Быстрое Преобразование Фурье)
Собственно, нужно найти частоту звука в Wav файле. Везде говорят о БПФ, но я нигде не нашел понятных новичку примеров. Нашел код для...

Оконное преобразование Фурье
Как я понял, с помощью ОПФ мы получаем еще и разрешение по времени.Но я так и не нашел,и соответственно не понял,как это выглядит-т.е. если...

Оконное преобразование Фурье
Здравствуйте, хотелось бы узнать, как работает и как можно реализовать оконное преобразование Фурье (читал статьи, но осталось...

14
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
08.04.2016, 21:06
Посмотрите NAudio NET, полно примеров, может что подойдет
http://naudio.codeplex.com/
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9
08.04.2016, 21:10  [ТС]
Большое спасибо!
0
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
08.04.2016, 21:24
Еще есть Accord.NET Framework
http://accord-framework.net/samples.html
Там тоже есть пример Spectrum analyzer (Fourier)

Добавлено через 10 минут
Еще интересная ссылка - Draw Spectrogram STFT in C#, what function can I use?
http://stackoverflow.com/quest... -can-i-use
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9
08.04.2016, 23:13  [ТС]
Продвижение есть) звук загрузить и воспроизвести получилось. Теперь буду с преобразованием колдовать! Спасибо таким людям,как Вы!
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10424 / 5154 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
09.04.2016, 00:31
Цитата Сообщение от FlashOlya Посмотреть сообщение
оконное преобразование Фурье и чтобы итоговые графики выводились разными цветами
SonogramBuilder
C#
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
    public class SonogramBuilder
    {
        public List<float[]> Sonogram  { get; private set; }
        public int WindowSize { get; set; }
        public float MaxValue { get; set; }
 
        public SonogramBuilder()
        {
            WindowSize = 256;
        }
 
        public void Build(string fileName)
        {
            Sonogram = new List<float[]>();
            MaxValue = 0f;
            using (var stream = new AudioFileReader(fileName))
            foreach (var fft in GetWindowFFT(GetSamples(stream), WindowSize))
            {
                //
                Sonogram.Add(fft);
                //
                var m = fft.Max();
                if (m > MaxValue)
                    MaxValue = m;
            }
        }
 
        IEnumerable<float[]> GetWindowFFT(IEnumerable<float> samples, int windowSize)
        {
            var fft = new FFT();
            var buffer = new List<float>(windowSize + 1);
            foreach(var v in samples)
            {
                buffer.Add(v);
                if(buffer.Count == windowSize)
                {
                    yield return fft.PerformFreqFFT(buffer.ToArray()).Take(windowSize / 3).Select(f => (float)f.Norma).ToArray();
                    buffer.Clear();
                }
            }
        }
 
        IEnumerable<float> GetSamples(AudioFileReader stream)
        {
            var buffer = new float[20000];
 
            while (stream.Position < stream.Length)
            {
                var count = stream.Read(buffer, 0, buffer.Length);
                for (int i = 0; i < count; i += 2)
                    yield return buffer[i];
            }
        }
    }

FFT
C#
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
    class FFT
    {
        public UInt64 ReverseBits(UInt64 r, UInt64 n)                          // преобразовывает r = ReverseBits(x - 1) в ReverseBits(x)
        {
            do { n = n >> 1; r = r ^ n; }
            while ((r & n) == 0);
            return r;
        }
 
        /// <summary>
        /// БПФ : прореживание по частоте
        /// </summary>
        /// <param name="Data">Массив исходных значений</param>
        /// <returns>Массив результатов</returns>
        Complex[] FreqFFT(Complex[] Data)
        {
            if (Data.Length > 2)
            {
                Complex[] left = new Complex[Data.Length / 2];
                Complex[] right = new Complex[Data.Length / 2];
                Complex[] X = new Complex[Data.Length];
 
                for (Int32 i = 0; i < Data.Length / 2; i++)             //операция бабочка
                {
                    Complex W = new Complex(Math.Cos((double)(2 * Math.PI * (double)i) / (double)Data.Length),
                                           -Math.Sin((double)(2 * Math.PI * (double)i) / (double)Data.Length));
 
                    X[i] = Data[i] + Data[i + Data.Length / 2];
                    X[i + Data.Length / 2] = (Data[i] - Data[i + Data.Length / 2]) * W;
                }
 
                for (Int32 i = 0; i < Data.Length / 2; i++)
                {
                    left[i] = X[i];
                    right[i] = X[i + Data.Length / 2];
                }
 
                Complex[] Xleft = FreqFFT(left);
                Complex[] Xright = FreqFFT(right);
 
                for (Int32 i = 0; i < Data.Length / 2; i++)
                {
                    X[i] = Xleft[i];
                    X[i + Data.Length / 2] = Xright[i];
                }
                return X;
            }
            else
            {
                Complex[] X = new Complex[2];
                X[0] = Data[0] + Data[1];
                X[1] = Data[0] - Data[1];
 
                return X;
            }
        }
 
        /// <summary>
        /// БПФ : прореживание по частоте
        /// </summary>
        /// <param name="Data">Массив исходных значений</param>
        /// <returns>Массив результатов</returns>
        public Complex[] PerformFreqFFT(float[] Data)
        {
            Complex[] ComplexData = new Complex[Data.Length];
 
            for (Int32 i = Data.Length - 1; i >= 0; --i)
            {
                ComplexData[i] = new Complex(Data[i]);
            }
 
            ComplexData = FreqFFT(ComplexData);
 
            UInt64 r = 0;
 
            for (UInt64 i = 1; i < (UInt64)Data.Length; i++)          //бит-реверсивная перестановка
            {
                r = ReverseBits(r, (UInt64)Data.Length);
                if (r > i)
                {
                    Complex temp = ComplexData[i];
                    ComplexData[i] = ComplexData[r];
                    ComplexData[r] = temp;
                }
            }
 
            var FreqFFTResults = new Complex[Data.Length];
 
            for (Int32 i = 0; i < Data.Length; i++)
            {
                FreqFFTResults[i] = ComplexData[i];
            }
 
            return FreqFFTResults;
        }
    }




Все вместе Sonogram.zip
3
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
09.04.2016, 07:47
FlashOlya, Еще ссылка
Extreme Realtime Music Visualizer
http://www.codeproject.com/Art... Visualizer
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9
09.04.2016, 13:56  [ТС]
Спасибо Вам огромнейшее! Сама бы через уйму времени бы додумалась до этого,и то не факт. А как сонограмму(спектрограмму) сделать в виде "простой волны" ( синусоиды например.То есть обычный 2D график зависимости амплитуды от времени). И сонограмма нужна и обычный график.
0
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
09.04.2016, 16:58
Загрузил проект графика без использования библиотек sincos
Если нужно чтобы график менялся во времени, то придется добавить таймер и добавлять новые - удалять старые точки по таймеру.
Вот примерчик
C#
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
using System;
using System.Timers;
//http://msdn.microsoft.com/en-us/library/system.timers.timer.interval(v=vs.110).aspx
public class Example
{
    private static Timer aTimer;
 
    public static void Main()
    {
        // Create a timer with a   second interval.
        aTimer = new System.Timers.Timer(1000);
        // Hook up the Elapsed event for the timer. 
        aTimer.Elapsed += OnTimedEvent;
        aTimer.Enabled = true;
 
        Console.WriteLine("Press the Enter key to exit the program... ");
        Console.ReadLine();
        Console.WriteLine("Terminating the application...");
    }
 
    private static void OnTimedEvent(Object source, ElapsedEventArgs e)
    {
        Console.WriteLine("The Elapsed event was raised at {0}", e.SignalTime);
    }
}
Есть много библиотек, народу нравится ZedGraph
http://zedgraph.sourceforge.net/linesamples.html

Как установить ZedGraph
Вложения
Тип файла: rar sincos.rar (82.2 Кб, 30 просмотров)
1
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
09.04.2016, 17:27
Я подумал, что Вам может пригодиться решение с несколькими графиками на одной форме
Вложения
Тип файла: rar fourchart.rar (89.0 Кб, 53 просмотров)
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9
09.04.2016, 18:55  [ТС]
Ваша работа дорого стоит! Вы меня спасли! Спасибо Вам большое!!!! Надеюсь и Вам всегда люди готовы будут помочь в трудностях!
0
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
09.04.2016, 21:33
FlashOlya, мне самому интересно, что у Вас получится).
Кстати, интересные картинки есть в ВИКИ, посмотрите
https://en.wikipedia.org/wiki/... _transform
0
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 9
09.04.2016, 23:25  [ТС]
Оконное преобразование Фурье какое-то очень сложное..Неужели его никак нельзя проще сделать? Я в Excel делала,чтобы понятно было что это такое и как это работает,а тут как-то сложновато
0
1498 / 1213 / 821
Регистрация: 29.02.2016
Сообщений: 3,630
10.04.2016, 10:21
http://www.dsplib.ru/content/win/win.html#r3
0
0 / 0 / 0
Регистрация: 09.02.2020
Сообщений: 17
31.03.2020, 10:18
Storm23, Здравствуйте, осталась ли у Вас данная программа?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.03.2020, 10:18
Помогаю со студенческими работами здесь

Оконное преобразование Фурье!
Здравствуйте! Помогите пожалуйста:help: Кто нибудь знает специальный пакет для ОПФ в матлабе? или надо водить формулу ОПФ в ручную?...

Оконное преобразование Фурье
Оконное преобразование Фурье — это разновидность преобразования Фурье. ...

Оконное преобразование Фурье + FFT
проблема: вообще не знаю mathlab. нужно построить сигнал(cos3t^2) умножить его: 1. На одно большое окно(Хэмминга) 2. На несколько...

Вывод разными цветами
Как в java можно вывести ответ разными цветами?? Задача:Вывести разными цветами на экране заглавные согласные русского алфавита и...

Вывод координат разными цветами
Добрый день! Помогите пожалуйста с программой. Есть строка вида: &quot;12,34 34,56, 76,2&quot; Где первое число(до запятой) это номер...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru