genfunc
rgf_simp
simplify an expression involving a rational generating function sequence
Calling Sequence
Parameters
Description
Examples
rgf_simp(expr, Fz, z, F, n, options)
expr
-
expression to simplify
Fz
rational generating function
z
name, generating function variable
F
name of function encoded by Fz
n
name, index variable of F
options
optional arguments
This function simplifies occurrences of sequence F in expr. If F is defined by an order k recurrence then all occurrences of F whose index differs from n by an integer amount are simplified to expressions involving Fn,...,Fn−k+1.
The function name argument F can have a parameter of the form an+b, where a is a positive integer and b is an integer. This pattern represents the index of the nth term in the sequence. Simplification will be done relative to the nth occurrence of this pattern. If the pattern is invalid or does not match any sequence occurrence in the expression, the unmodified expression is returned. The defaults are a=1 and b=0.
The simplified expression is expanded and the coefficients of Fan+b,...,Fan−k+1+b are collected.
A procedure may be passed as an optional argument and is applied to each coefficient of the collected result.
An expression may be passed as an optional argument. Occurrences of F are matched against the pattern to determine a value for n. If this value for n differs from the optional argument by an integer amount, the term is simplified relative to the expression.
The command with(genfunc,rgf_simp) allows the use of the abbreviated form of this command.
withgenfunc:
Fz≔z1−z−z2:
ex≔n2Fn+1+n2+1Fn+n2−2nFn−1+n+32Fn−2
rgf_simpex,Fz,z,F,n
3n2+6n+10Fn+n2−8n−9Fn−1
rgf_simpex,Fz,z,F,n,n−1
3n2+6n+10Fn−2+4n2−2n+1Fn−1
rgf_simpex,Fz,z,F,n,n+1
n2−8n−9Fn+1+2n2+14n+19Fn
rgf_simpex,Fz,z,F,n,n+1,factor
n+1n−9Fn+1+2n2+14n+19Fn
Fz≔1−z+z21−4z−z2:
rgf_simpF3n−2+F3n−11,Fz,z,F3n−2,n
−3F3n−2+17F3n−5
rgf_simp,Fz,z,F3n−2,n,n+1
−71F3n−2+17F3n+1
rgf_simpF3km−11,Fz,z,F3n−2,n,km
17F3km−5−4F3km−2
See Also
collect
Download Help Document