Logarithme binaire

Tracé de lb n, la fonction logarithme de base 2.

En mathématiques, le logarithme binaire (log2 n) est le logarithme de base 2. C’est la fonction réciproque de la fonction puissance de deux : x ↦ 2x. Le logarithme binaire de x est la puissance à laquelle le nombre 2 doit être élevé pour obtenir la valeur x, soit : .

Ainsi, le logarithme binaire de 1 est 0, le logarithme binaire de 2 est 1, le logarithme binaire de 4 est 2, le logarithme binaire de 8 est 3.

On le notait[Quand ?] ld () (pour logarithmus dualis), mais la norme ISO 80000-2[1] indique que log2(x) devrait être symbolisé par lb (x). En fait, en analyse de la complexité des algorithmes, dans un contexte dans lequel il n'y a pas de confusion possible, il est parfois simplement noté log (x)[2].

En musique, le logarithme binaire intervient dans la formule permettant de déterminer la valeur en cents d’un intervalle. Cette valeur est égale en cents à 1200 fois le logarithme binaire du rapport de fréquence de l'intervalle. Le rapport de fréquence d'un intervalle est le quotient de la fréquence la plus haute sur la fréquence la plus basse de cet intervalle. Un cent vaut exactement un centième de demi-ton.

Informatique

[modifier | modifier le code]

En informatique, l'orientation binaire du matériel fait souvent du logarithme binaire le plus facile à calculer et le plus précis, les autres en étant dérivés.

En effet, soit (e ; m) la représentation virgule flottante binaire d'un nombre réel non nul x, où e est un entier porteur de l'ordre de grandeur, et m un significande tel que 1 ≤ |m| < 2. Alors, si m > 0 :

et le calcul de lb(x) se ramène ainsi au domaine [1 ; 2[

Par exemple, 10 = 23 × 1,25, lb(10)= 3 + lb(1,25).

où lb(1,25) est la partie fractionnaire du logarithme cherché.

Chaque bit de lb(1,25) peut se calculer directement bit à bit à l'aide des relations :

Quand on cherche un nouveau bit de x (0 < x < 2) :

  • on élève x au carré
    • si x vaut au moins 2, on note 1, on divise x par 2 et on poursuit ;
    • sinon, on note 0 et on poursuit[3].

Ainsi

Or 11,01010012 = 3,3203125, et on a déjà 23,3203125 = 9,9888...

La valeur lb(10) = 3,32... entraîne que le codage binaire d'un entier décimal occupera au moins 3,32 bits par chiffre décimal, soit 4 bits pour un chiffre, 7 bits pour 2 chiffres et 10 bits pour 3 chiffres (ou tranche de 3 chiffres).

Références

[modifier | modifier le code]
  1. ISO 80000-2:2009. Organisation internationale de normalisation. Consulté le 18 janvier 2012.
  2. Voir par exemple Complexité des algorithmes. Sylvain Perifel. 2014, sous licence Creative Commons, p.xvi.
  3. Dean K.J., 1969, A fresh approach to binary logarithm computing, Electronic Engineering.