Counting and generating permutations using timed languages (long version)

Abstract : The signature of a permutation $\sigma$ is a word whose letter of index i is d when $sigma$ has a descent (i.e. $\sigma(i)>\sigma(i+1)$) and is a when $\sigma$ has an ascent (i.e. $\sigma(i)<\sigma(i+1)$). Combinatorics of permutations with a prescribed signature is quite well explored. Given a language over the alphabet {a,d}, we associate to it the class of permutations with signature in the language. Here we state and address the two problems of counting and randomly generating for every classes of permutations associated to a regular language. First we give an algorithm that computes a closed form formula for the exponential generating function of such a class. Then we give an algorithm that given a regular language L and an integer n generates randomly the n-length permutations of the class associated to L in a uniform manner, i.e. all the permutations of length n with signature in L are equally probable to be returned. Both contributions are based on a geometric interpretation of a subclass of regular timed languages.
Document type :
Preprints, Working Papers, ...
Contributor : Nicolas Basset <>
Submitted on : Wednesday, October 2, 2013 - 10:59:36 AM
Last modification on : Tuesday, October 11, 2016 - 1:55:57 PM


Files produced by the author(s)


  • HAL Id : hal-00820373, version 2


Nicolas Basset. Counting and generating permutations using timed languages (long version). 2013. <hal-00820373v2>




Record views


Document downloads