Support

If you have a problem or need to report a bug please email : support@dsprobotics.com

There are 3 sections to this support area:

DOWNLOADS: access to product manuals, support files and drivers

HELP & INFORMATION: tutorials and example files for learning or finding pre-made modules for your projects

USER FORUMS: meet with other users and exchange ideas, you can also get help and assistance here

NEW REGISTRATIONS - please contact us if you wish to register on the forum

Users are reminded of the forum rules they sign up to which prohibits any activity that violates any laws including posting material covered by copyright

FFT question

DSP related issues, mathematics, processing and techniques

FFT question

Postby Lex248 » Mon Sep 18, 2017 7:30 am

Hi, all.
On the picture example of work of FFT. Whether it is possible to get access to every period of a signal separately? May be convolution?
Attachments
FFT_Test.jpg
FFT_Test.jpg (61.06 KiB) Viewed 36623 times
Sorry, I bad speak english.
---
My plug-ins http://nalexsoft.blogspot.com/
Lex248
 
Posts: 33
Joined: Mon Aug 29, 2016 7:44 pm
Location: Russia

Re: FFT question

Postby martinvicanek » Mon Sep 18, 2017 9:35 pm

Lex, we need more information.
What do you mean by "access to every period of a signal separately"?
Do you want to take the Fourier Transform of one period?
Why would you want to do that?
What is the context?
User avatar
martinvicanek
 
Posts: 1328
Joined: Sat Jun 22, 2013 8:28 pm

Re: FFT question

Postby Lex248 » Wed Sep 20, 2017 9:30 am

For example, I want to make so through FFT, but standard methods don't allow to make so.
Attachments
FFT_Test_2.jpg
FFT_Test_2.jpg (48.1 KiB) Viewed 36568 times
Sorry, I bad speak english.
---
My plug-ins http://nalexsoft.blogspot.com/
Lex248
 
Posts: 33
Joined: Mon Aug 29, 2016 7:44 pm
Location: Russia

Re: FFT question

Postby martinvicanek » Thu Sep 21, 2017 7:04 pm

If the signal is as simple as in your picture, then you just need to check for zero crossings to determine the period.
It is still not obvious to me why you would need a Fourier transform to zero out one signal period. :?:
User avatar
martinvicanek
 
Posts: 1328
Joined: Sat Jun 22, 2013 8:28 pm

Re: FFT question

Postby Lex248 » Thu Sep 21, 2017 7:56 pm

The signal will be not simple. I need it for improving of my plug-in "P-Filter - Positional Filter". Standard methods of processing of FFT create artifacts, wrong determination of a position. High frequencies of a signal give many uncontrollable periods. I need control over every period of each frequency of FFT image, if it is possible. It something like several thousands of band pass filters in real time.
Sorry, I bad speak english.
---
My plug-ins http://nalexsoft.blogspot.com/
Lex248
 
Posts: 33
Joined: Mon Aug 29, 2016 7:44 pm
Location: Russia

Re: FFT question

Postby martinvicanek » Thu Sep 21, 2017 10:39 pm

If I understand your concern correctly, the standard way to deal with it is windowing and overlap-add.
several thousands of band pass filters in real time

That is possible. It's what happens in my FFT vocoder plugin. if your filter is not very steep you may get away with simply multiplying the spectrum by your filter response curve and IFFT - that's it.
User avatar
martinvicanek
 
Posts: 1328
Joined: Sat Jun 22, 2013 8:28 pm

Re: FFT question

Postby Lex248 » Fri Sep 22, 2017 3:01 pm

Thank you for help, Martin. I am familiar with your FFT vocoder, but to me is unclear as it works and as I can apply it in the purposes. Maybe there is a block diagram? Still you use mono4, and it is undesirable for me.
Sorry, I bad speak english.
---
My plug-ins http://nalexsoft.blogspot.com/
Lex248
 
Posts: 33
Joined: Mon Aug 29, 2016 7:44 pm
Location: Russia

Re: FFT question

Postby martinvicanek » Fri Sep 22, 2017 11:40 pm

People tend to think of an FFT representation in terms of a graphic equalizer, where you can simply multiply each bin by its corresponding slider value, then simply inverse FFT the result and that's it:
NaiveFFTFiltering.png
NaiveFFTFiltering.png (12.04 KiB) Viewed 36462 times
That might work if your filter curve is very moderate.

However, the correct way of doing it is based on linear convolution.:
CorrectFFTFiltering.png
CorrectFFTFiltering.png (12.69 KiB) Viewed 36462 times
You first IFFT your filter curve to obtain an impulse response (IR). Theen you apply a circular shift so the bulk of the IR is at the center of your frame, and apply a window function to avaid border artifacts. Then you convolve your signal with the windowed IR.
User avatar
martinvicanek
 
Posts: 1328
Joined: Sat Jun 22, 2013 8:28 pm

Re: FFT question

Postby Lex248 » Sat Sep 23, 2017 7:01 am

The problem is that I have no constant filter curve. It depends on a signal and changes according to it.
Sorry, I bad speak english.
---
My plug-ins http://nalexsoft.blogspot.com/
Lex248
 
Posts: 33
Joined: Mon Aug 29, 2016 7:44 pm
Location: Russia

Re: FFT question

Postby martinvicanek » Sat Sep 23, 2017 11:42 am

No problem, just keep updating your IR as you go. Use overlapp and add to avoid sudden changes.
User avatar
martinvicanek
 
Posts: 1328
Joined: Sat Jun 22, 2013 8:28 pm


Return to DSP

Who is online

Users browsing this forum: No registered users and 23 guests