package containers-data
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
On This Page
  
  
  A set of advanced datatypes for containers
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      containers-3.13.1.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=eb9b26eb2c3cf04fc5157d256eb49c43552ccb5c59c568772d70315db9669784
    
    
  sha512=7f4cf5112c8047fd789c04129745dbe9783aa94390e8983f86408053b0af637e2a9cfce1559ce466b1b6ff7c01fd52d8685f5db1d1c0dda2c0aa138f90606a50
    
    
  doc/containers-data/CCKTree/index.html
Module CCKTreeSource
Lazy Tree Structure This structure can be used to represent trees and directed graphs (as infinite trees) in a lazy fashion. It is a structural type.
Basics
Fold on values in no specified order. May not terminate if the tree is infinite.
Graph Traversals
Build a set structure given a total ordering.
Depth-first traversal of the tree.
force t evaluates t completely and returns a regular tree structure.
Look for an element that maps to Some _.
Pretty-printing
Example (tree of calls for naive Fibonacci function):
  let mk_fib n =
    let rec fib' l r i =
      if i=n then r else fib' r (l+r) (i+1)
    in fib' 1 1 1;;
  let rec fib n = match n with
    | 0 | 1 -> CCKTree.singleton (`Cst n)
    | _ -> CCKTree.node2 (`Plus (mk_fib n)) (fib (n-1)) (fib (n-2));;
  let pp_node fmt = function
    | `Cst n -> Format.fprintf fmt "%d" n
    | `Plus n -> Format.fprintf fmt "%d" n;;
  Format.printf "%a@." (CCKTree.pp pp_node) (fib 8);;A pretty-printer using S-expressions and boxes to render the tree. Empty nodes are not rendered; sharing is ignored.
Pretty printing in the DOT (graphviz) format
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  On This Page