* implementation and factorisation * factorize test * doc * fix bug and improve test * address suggestions