Kernel.SubstSourceSubstitutions using DeBruijn indices.
A substitution is a function mapping a variable (location, identifier and DB index) under a given number of lambda abstractions to a term. A substitution raises Not_found meaning that the variable is not subsituted.
apply_subst subst n t applies subst to t under n lambda abstractions.
k < n are considered "locally bound" and are never substituted.k >= n may be substituted if k-n is mapped in sigma.unshift i t shifts every De Bruijn indices in t by -i. Raises UnshiftExn when t contains De Bruijn variables of indices k <i.
psubst_l l k t substitutes the first n De Bruijn variables (with n = length l) in t with the corresponding term in l. Unshifts n times the free variables with greater indices.
subst t u substitutes the first free De Bruijn variable with u in t. Unshifts the other free variables.
subst_n n y t substitutes the n-th free De Bruijn variable in t with a fresh variable named y becoming the first free variable in t. All others free variables are shifted by one preventing index collision.