Blanc, RĂ©gis WilliamKneuss, EtienneKuncak, ViktorSuter, Philippe2013-04-252013-04-252013-04-252013https://infoscience.epfl.ch/handle/20.500.14299/91798We present the Leon verification system for a subset of the Scala programming language. Along with several functional features of Scala, Leon supports imperative constructs such as mutations and loops, using a translation into recursive functional form. Both properties and programs in Leon are expressed in terms of user-defined functions. We discuss several techniques that led to an efficient semi-decision procedure for first-order constraints with recursive functions, which is the core solving engine of Leon. We describe a generational unrolling strategy for recursive templates that yields smaller satisfiable formulas and ensures completeness for counter-examples. We evaluate the benefits of these techniques on a set of examples.On Verification by Translation to Recursive Functionstext::report