Print methods for permutation objects
print.Rd
Print methods for permutation objects with matrix-like printing for words and bracket notation for cycle objects.
Arguments
- x
Object of class
permutation
withword
objects dispatched toprint.word()
andcycle
objects dispatched toprint.cycle()
- h
Boolean, with default
TRUE
meaning to coerce words to cycle form before printing. See details- ...
Further arguments (currently ignored)
- y,comma
In
as.character.cyclist()
, argumenty
is a list of cycles (a cyclist); andcomma
is Boolean, specifying whether to include a comma in the output- give_string
In function
Value
Returns its argument invisibly, after printing it (except for
print.cycle(x,give_string=TRUE)
, in which case a character
vector is returned).
Details
Printing of word objects is controlled by
options("print_word_as_cycle")
. The default behaviour is to
coerce a word to cycle form and print that, with a notice that the
object itself was coerced from word.
If options("print_word_as_cycle")
is FALSE
, then objects
of class word are printed as a matrix with rows being the permutations
and fixed points indicated with a dot.
Function as.character_cyclist()
is an internal function used by
print.cycle()
, and is not really designed for the end-user. It
takes a cyclist and returns a character string.
Function print_word()
and print_cycle()
are provided for
power users. These functions print their argument directly as word or
cycle form; they coerce to the appropriate form. Use
print_word()
if you have a permutation in word form and want to
inspect it as a word form but (for some reason) do not want to set
options("print_word_as_cycle")
. See size.Rd
for a
use-case.
Coercing a cycle to a character vector can be done with
as.character()
, which returns a character vector that is
suitable for as.cycle()
, so if a
is a cycle
all(as.cycle(as.character(a)) == a)
will return TRUE
.
If you want to use the options of the print method, use
print.cycle(...,give_string=TRUE)
, which respects the print
options discussed below. Neither of these give useful output if their
argument is in word form.
The print method includes experimental functionality to display
permutations of sets other than the default of integers
\(1,2,\ldots, n\). Both cycle and word print methods
are sensitive to option perm_set
: the default value of
NULL
means to use integers. The symbols may be the elements of
any character vector; use idiom such as
options("perm_set" = letters)
to override the default. But beware! If the permutation includes
numbers greater than the length of perm_set
, then NA
will be printed. It is possible to use vectors with elements of more
than one character (e.g. state.abb
).
In the printing of cycle objects, commas are controlled with option
"comma"
. The default NULL
means including commas in the
representation if the size of the permutation exceeds 9. This works
well for integers but is less suitable when using letters or state
abbreviations. Force the use of commas by setting the option to
TRUE
or FALSE
, e.g.
options("comma" = TRUE)
The print method does not change the internal representation of word or cycle objects, it only affects how they are printed.
The print method is sensitive to experimental option
print_in_length_order
(via function
as.character_cyclist()
). If TRUE
, permutations cycle
form will be printed but with the cycles in increasing length order.
Set it with
options("print_in_length_order" = TRUE)
There is a package vignette (type vignette("print")
at the
command line) which gives more details and long-form documentation.
Examples
# generate a permutation in *word* form:
x <- rperm(4,9)
# default behaviour is to print in cycle form irregardless:
x
#> [1] (1853)(276)(49) (124835976) (135296)(478) (168594)(23)
#> [coerced from word form]
# change default using options():
options(print_word_as_cycle=FALSE)
# objects in word form now printed using matrix notation:
x
#> 1 2 3 4 5 6 7 8 9
#> [1] 8 7 1 9 3 2 6 5 4
#> [2] 2 4 5 8 9 1 6 3 7
#> [3] 3 9 5 7 2 1 8 4 6
#> [4] 6 3 2 1 9 8 . 5 4
# printing of cycle form objects not altered:
as.cycle(x)
#> [1] (1853)(276)(49) (124835976) (135296)(478) (168594)(23)
# restore default:
options(print_word_as_cycle=TRUE)
as.character_cyclist(list(1:4,10:11,20:33)) # x a cyclist;
#> [1] "(1,2,3,4)(10,11)(20,21,22,23,24,25,26,27,28,29,30,31,32,33)"
as.character_cyclist(list(c(1,5,4),c(2,2))) # does not check for consistency
#> [1] "(1,5,4)(2,2)"
as.character_cyclist(list(c(1,5,4),c(2,9)),comma=FALSE)
#> [1] "(154)(29)"
options("perm_set" = letters)
rperm(r=9)
#> [1] (agehc)(bfi) (ac)(bhfgie) (af)(cdh)(egi) (ahgd)(beifc) (acihdb)(eg)
#> [6] (aeigbdfhc) (ahigdf)(bc) (aehb)(cgf) (adbihec)(fg) (agi)(bfhde)
#> [coerced from word form]
options("perm_set" = NULL) # restore default