Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Interval.direction() doesn't distinguish accidentals of same note #105

Open
eagor opened this issue Apr 14, 2016 · 4 comments
Open

Interval.direction() doesn't distinguish accidentals of same note #105

eagor opened this issue Apr 14, 2016 · 4 comments

Comments

@eagor
Copy link

eagor commented Apr 14, 2016

var a = teoria.note('a'),
    ab = teoria.note('ab'),
    aS = teoria.note('a#');
ab.interval(a).direction(); // "up"
// but
a.interval(ab).direction(); // "up"
aS.interval(a).direction(); // "up"
aS.interval(ab).direction(); // "up"

interval from A# to Ab returns direction "up", even though Ab is 2 semitones down from A#.

@saebekassebil
Copy link
Owner

Hey Eagor.

I can see why that might be confusing behaviour. But actually it is working as "expected": The Interval#direction() method doesn't measure whether the interval goes up or down on the keyboard - but rather which direction the interval as "facing".

I'm not sure that there is such an interval as "diminished unison", but I kind of had to make it up to make the theory "complete". And to me a diminished is smaller than a perfect - and to make a perfect unison smaller a diminished unison must be a half-step lower. At least that's the reasoning.

I'm very open to listen to other suggestions on this behaviour if you have any input :)

@eagor
Copy link
Author

eagor commented Apr 15, 2016

Yeah, it's a bit misleading, as initially I would think that if you play two notes one after another, you would hear whether the melody goes up or down, hence the direction of the interval.

Or, maybe there is some other theoretical meaning of interval direction? Or what might be the use case expecting current behavior?

ps. anyways, great lib. The idea with .coord is genius!!!

@eagor
Copy link
Author

eagor commented Apr 20, 2016

maybe, this should go to a different thread, but I've just found this:

teoria.scale("cx", 'wholetone').simple()
> ["cx", "dx", "ex", "fundefined", "gundefined", "aundefined"]

@saebekassebil
Copy link
Owner

Well spotted! This should produce some kind of an error. Please open a new issue on this though.

Den 20. apr. 2016 kl. 13.24 skrev eagor [email protected]:

maybe, this should go to a different thread, but I've just found this:

teoria.scale("cx", 'wholetone').simple()

["cx", "dx", "ex", "fundefined", "gundefined", "aundefined"]

You are receiving this because you commented.
Reply to this email directly or view it on GitHub

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants