File: sort-doc.m2

package info (click to toggle)
macaulay2 1.25.05%2Bds-2
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 172,152 kB
  • sloc: cpp: 107,824; ansic: 16,193; javascript: 4,189; makefile: 3,899; lisp: 702; yacc: 604; sh: 476; xml: 177; perl: 114; lex: 65; python: 33
file content (145 lines) | stat: -rw-r--r-- 4,959 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
--- status: TODO
--- author(s): 
--- notes: 

document { 
     Key => sort,
     Headline => "sort a list or columns of a matrix",
     SeeAlso => {rsort, sortColumns, symbol<=, symbol?},
     Subnodes => {
	 TO (sort, List),
	 TO (sort, Matrix),
	 TO sortColumns,
         },
     }
document { 
     Key => (sort,Matrix),
     Headline => "sort the columns of a matrix",
     Usage => "sort m",
     Inputs => {
	  "m" => "between free modules"
	  },
     Outputs => {
	  Matrix => {"with the same shape as ", TT "m", " whose columns
	  are sorted in increasing order"}
	  },
     PARA{},
     "The default order is to sort the columns in ascending degree first,
     and within each degree, first compare ring elements in the highest non-zero component, 
     breaking ties by going to the next lower component.  
     Zero is considered earlier in the order than other elements",
     EXAMPLE {
	  "R = ZZ/32003[a..d,MonomialOrder=>Lex];",
	  "m = matrix{{a*d, b^2, b^100, b^50*d^50, c^2*d}}",
	  "sort m"
	  },
     PARA{},
     "The two optional arguments can modify this default order.
     The value of ", TO DegreeOrder, " is considered first (Ascending,
	  Descending, or null), and after that the monomial (or ring) order
     is used to break ties, either ascending or descending, depending on the
     value of ", TO MonomialOrder, ".",
     PARA{},
     "To sort the columns of ", TT "m", " in descending monomial order:",
     EXAMPLE {
	  "options sort",
	  "sort(m, DegreeOrder=>null, MonomialOrder=>Descending)"
	  },
     SeeAlso => {sortColumns},
     Subnodes => {
	 TO [sort, MonomialOrder],
	 TO [sort, DegreeOrder],
	 TO Ascending,
	 TO Descending
         },
     }
document { 
     Key => {(sort,List), (sort, List, Function)},
     Headline => "sort a list",
     Usage => "sort v",
     Inputs => { "v" },
     Outputs => {
	  List => {" of the same length as ", TT "v", " sorted in ascending order"}
	  },
     PARA {
	  "The sort function uses ", TO symbol<=, " to compare elements of the
	  list, which in turn calls upon the comparison operator ", TO symbol?, ", so, to determine how the elements are sorted,
	  refer to its documentation.  Methods for new user defined types of objects
	  can be installed for it, too, to obtain the desired sorting behavior."
	  },
     EXAMPLE {
	  "sort {c,e,a,f,b,f}",
	  "sort {4,2,6,3,8,2}"
	  },
     PARA {
	  "Comparison of strings is implemented so that symbols come
	  before alphanumeric characters, upper and lower case characters are
	  sorted together, and strings of digits are sorted by size of the implied number."
	  },
     EXAMPLE ///sort {"a11","a1","a2","A11","A1","A2","B2"}///,
     PARA {
	  "Visible lists (lists, sequences, and arrays) are compared lexicographically."
	  },
     EXAMPLE ///sort {(1,1),(2,1),(3,1),(1,2),(3,2)}///,
     PARA{
	  "If the elements of the list are polynomials, then the monomial order
	  is used to sort the elements according to their lead terms."
	  },
     EXAMPLE {
	  "R = ZZ[a..d,MonomialOrder=>Lex];",
	  "sort{a*d, b^100, c^3*d}"
	  },
     PARA{
	  "The optional arguments are not used in this version of sort."
	  },
     Caveat => {
	  "If a list contains elements of different types, the sorting still
	  occurs, but might not be particularly intuitive."
	  },
     SeeAlso => { rsort, symbol<=, symbol? }
     }
document { 
     Key => [sort, MonomialOrder],
     Headline => "specify Ascending or Descending monomial order",
     Usage => "sort(...,MonomialOrder=>x)",
     Inputs => {
	  "x" => Symbol => { "either ", TO "Ascending", " or ", TO "Descending"}
	  },
     Consequences => {
	  {"After the degree order has been considered, sort the columns of
	  the matrix in Ascending or Descending monomial order"}
	  },     
     Caveat => {"This option only works for sorting columns of a matrix, not
	  the elements of a list"},
     SeeAlso => {}
     }
document { 
     Key => [sort, DegreeOrder],
     Headline => "specify Ascending, Descending, or null",
     Usage => "sort(...,DegreeOrder=>x)",
     Inputs => {
	  "x" => Symbol => { "either ", TO "Ascending", ", ", TO "Descending", ", or ", TO null}
	  },
     Consequences => {
	  {"If ", TT "x", " is not null, first order the columns of the matrix
	  in ascending or descending degree (depending on ", TT "x", ").  If ",
	  TT "x", " is null, then only use the monomial order in the sort"}
	  },     
     Caveat => {"This option only works for sorting columns of a matrix, not
	  the elements of a list"},
     SeeAlso => {}
     }

document {
    Key => Ascending,
    Headline => "specify ascending order",
    TT "Ascending", " -- a symbol used as a value for optional
    arguments ", TO "DegreeOrder", " and ", TO "MonomialOrder", "."
}

document {
    Key => Descending,
    Headline => "specify descending order",
    TT "Descending", " -- a symbol used as a value for optional
    arguments ", TO "DegreeOrder", " and ", TO "MonomialOrder", "."
}