File: splice-doc.m2

package info (click to toggle)
macaulay2 1.24.11%2Bds-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 171,648 kB
  • sloc: cpp: 107,850; ansic: 16,307; javascript: 4,188; makefile: 3,947; lisp: 682; yacc: 604; sh: 476; xml: 177; perl: 114; lex: 65; python: 33
file content (50 lines) | stat: -rw-r--r-- 1,306 bytes parent folder | download | duplicates (5)
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
-- Status: rewritten July 2018
-- Author: Lily Silverstein

doc ///
 Key
  splice
  (splice, BasicList)
 Headline
  remove subsequences from a sequence or list
 Usage
  splice X
 Inputs
  X:BasicList
 Outputs
  Y:BasicList
   the new list resulting from replacing each element of {\tt X} that is a sequence
   with its elements
 Description
  Text
   Unlike the function @TO deepSplice@, which recursively flattens subsequences at all levels,
   {\tt splice} removes the outermost nested level of subsequences only.
  Example
   X = {(), (0, (1, 2, (3, 4))), (5, (6, 7)), 8, 9};
   splice X
   deepSplice X
  Text
   {\tt splice} does not alter elements that are lists, arrays, or anything other than
   sequences.
  Example  
   Z = {(), {0, {1, 2, (3, 4)}}, [5, [6, 7]], 8, 9};
   splice Z
  Text
   {\tt splice} works on sequences, too, and all other objects of @TO class@ BasicList.
   The output matches the class of the input.
  Example
   splice ((), (0, (1, 2, (3, 4))), (5, (6, 7)), 8, 9)
   splice [(), (0, (1, 2, (3, 4))), (5, (6, 7)), 8, 9]   
  Text
   Even if {\tt X} is a @TO MutableList@, {\tt splice} returns a new list rather than
   altering the definition of {\tt X}.
  Example
   M = new MutableList from X
   splice M
   M
 SeeAlso
  deepSplice
  flatten
  "lists and sequences"
///