!7 sS text = [[ One node "A". One node "B". B to the right of A. ]]; static new TreeSet nodes; static new LinkedHashSet relations; static new LinkedHashSet maybes; static new TreeMap coordinates; p { for (S s : sentences(text)) { new Matches m; if "One node *" nodes.add($1); else if "* to the right of *" relations.add(new Relation("to the right of", $1, $2)); } print("Got nodes: " + sfu(nodes)); print("Got relations: " + sfu(relations)); makeCoordinates(); print("Got coordinates: " + sfu(coordinates)); } svoid makeCoordinates { processRules(); for (S node : nodes) coordinates.put(node, pt(random(100), random(100))); } svoid processRules { for (Relation r : cloneList(relations)) if (r.is("to the right of")) { maybes.add(Relation("on same height as", r.a(), r.b())); Pt pa = coordinates.get(r.a()), pb = coordinates.get(r.b()); pa.x = min(pa.x, pb.x+10); } }