Skip to main content

Indie game storeFree gamesFun gamesHorror games
Game developmentAssetsComics
SalesBundles
Jobs
TagsGame Engines

Yeah the thing is that, I can't handle a note so far... For now, I mostly look for the highest peak of my spectrum and give its frequency.
It is really hard to get which note is played only with a sound spectrum. Even more when I have to take in account every music instruments that can be played on this tool... If it was that easy, indeed I would have done it.
I am no expert in music algorithm, and even when I tried to isolate a specific placement of peaks in order to register a note, I got results less precise than when I use the "highest peak" method sadly...

If I get new Ideas on how to precisely isolate a note from a spectrum I'll try to implement it, but so far, this is the most precise I can be... Sorry

Hmm, are you using C#?  I could try looking around for an API.  I've done some work with Unity in the past so I might be able to help in some capacity.


Assuming that's impossible, though, the problem I'm running into is that it's hard to find unique frequencies for each notes.  Each frequency is often shared between some number of notes when I play them, so it's pretty tedious trial and error, made worse by how difficult it is to identify frequencies when it keeps flipping between the highest peak.  What if, instead of displaying only the current highest peak, it displayed multiple (like the top 5)?  That seems like it'd be pretty doable with what you've already got so far, and would make it a lot easier to identify the different frequencies in each note.  If possible, it'd also be cool to order the frequencies by their frequency number, instead of by highest peak, so that they don't flip-flop whenever one peak gets slightly higher than the other, since it can be really hard to read on the current display when two frequencies are at similar peaks.

(1 edit)

Yes I'm using C# :)

And yes it is what I intend to do for my new way of isolating notes. 

But the order of peaks is not going to work as some notes fluctuate multiple times between different peaks. I have my ideas in mind, I just have to rework all my code...

And considering the fact that I have been working every day on this tool for free for the last three weeks, I'm going to lay down a bit...

(1 edit)

Fair enough, thanks for the work you're putting in on this.  Would it be possible for me to look at the source code?  I understand if you don't want me to be able to change anything, but I'd be curious to take a look and see what you're doing so far, to see if I can figure out how to make it work with notes.


EDIT: talked to my friend who's more educated in frequencies than I am, and the ones being shown don't match up with what they "ought" to be.  Theoretically using the peak should work fine, but the peak isn't matching what is expected (i.e. A4=440Hz), even using sample tones.


I did some testing and I think the problem may be as simple as some bad math - I tested pure tones and the spectrum looked reasonable, but the Hz number itself was off.  Here are all the Hz I tested - what was played on the left, and what was heard by AAI on the right:

100 = 48.16
150 = 61.17
200 = 71.23
250 - 80.27
300 = 86.37
350 = 91.52
400 = 97.03
450 = 100.78
500 = 104.30
550 = 107.46
600 = 111.09
650 = 113.67
700 = 116.13
750 = 118.36
800 = 121.05


I notice two things - first that the "heard" number is always lower, and that it keeps getting further and further off.  50Hz played difference at low frequencies makes a 13Hz heard difference, but at the top end it's only a 3Hz heard difference.  So I'm thinking there must be some math error with how you're converting frequencies to a Hz number?  If the number is right then it should be easy to convert to a note just using the A4=440 table.