David Kastrup wrote Monday, December 14, 2015 11:32 AM

> Urs Liska <u...@openlilylib.org> writes:
> 
>> Am 13.12.2015 um 14:09 schrieb Graham Breed:
>>> On 13/12/15 12:48, N. Andrew Walsh wrote:
>>>> Take a look at conversions.ly (sorry; mround is the equivalend
>>>> function in
>>>> the spreadsheet I use to do the same thing). Those functions will
>>>> convert
>>>> the input (given as a fraction comprising two integers) into Lily's
>>>> semitone values. That should allow you to convert between
>>>> just-intonation
>>>> ratios an the nearest note name. Urs has some comments in there
>>>> explaining
>>>> a bit how it works.
>>>
>>> Converting from ratios to cents is easy.  Converting between ratios
>>> and cents requires a function from cents to ratios.  That's a lot more
>>> difficult because information is lost.  You got us excited by
>>> suggesting that had been solved.
>>
>> Well, this is because conversion from cent to ratio isn't part of the
>> objective currently.
> 
> Guile has
> 
> (rationalize (inexact->exact (atan 0 -1)) #e1e-6)
> 
> so you can try converting irrational numbers to ratios.  However,
> figuring out the precision to use may be tricky and there is no "prefer
> simple ratios" option.  All you have to work with is the eps argument.

One way to approach this would be via continued fractions.
These provide a means to determine the "best" rational approximations
to a real number.

The continued fractions give a list of rational approximations in
which each member is a closer approximation to the real value than
the previous members, and each is also closer than any approximation
with a smaller or equal denominator.

For example, pi = [3;7,15,1,292,1,1,...] as a continued fraction,
which gives the successive "best" rational approximations to pi of 
3/1, 22/7, 333/106, 355/113, ...

Not sure how you'd determine which of the ratios was "correct" when
used for conversion from cent to ratio, though.  Maybe try a few
and see what comes out.

Trevor
_______________________________________________
lilypond-user mailing list
lilypond-user@gnu.org
https://lists.gnu.org/mailman/listinfo/lilypond-user

Reply via email to