|
| 1 | +#!/usr/bin/env python |
| 2 | + |
| 3 | +from argparse import ArgumentParser |
| 4 | +import random |
| 5 | +import sys |
| 6 | +import networkx as nx |
| 7 | + |
| 8 | + |
| 9 | +def random_tree(max_branch, max_height): |
| 10 | + G = nx.DiGraph() |
| 11 | + random_subtree(G, None, max_branch, max_height) |
| 12 | + return G |
| 13 | + |
| 14 | + |
| 15 | +def random_subtree(G, root, max_branch, max_height): |
| 16 | + if max_height: |
| 17 | + if root: |
| 18 | + nr_branches = random.randrange(0, max_branch + 1) |
| 19 | + for i in range(1, nr_branches + 1): |
| 20 | + node = root + '.' + str(i) |
| 21 | + G.add_edge(root, node) |
| 22 | + random_subtree(G, node, max_branch, max_height - 1) |
| 23 | + else: |
| 24 | + node = '1' |
| 25 | + random_subtree(G, node, max_branch, max_height - 1) |
| 26 | + |
| 27 | + |
| 28 | +def main(): |
| 29 | + arg_parser = ArgumentParser(description='generate random tree') |
| 30 | + arg_parser.add_argument('--output', required=True, |
| 31 | + help='output file name') |
| 32 | + arg_parser.add_argument('--branching', dest='max_branch', type=int, |
| 33 | + default=3, help='maximum node branching') |
| 34 | + arg_parser.add_argument('--height', dest='max_height', type=int, |
| 35 | + default=4, help='maximum tree height') |
| 36 | + arg_parser.add_argument('--seed', type=int, default=None, |
| 37 | + help='seed for random number generator') |
| 38 | + arg_parser.add_argument('--delim', dest='delimiter', default=' ', |
| 39 | + help='delimiter for edge list') |
| 40 | + arg_parser.add_argument('--no-data', action='store_true', |
| 41 | + dest='no_data', help='show edge data') |
| 42 | + arg_parser.add_argument('--edge-list', action='store_true', |
| 43 | + dest='edge_list', |
| 44 | + help='generate edge list output') |
| 45 | + options = arg_parser.parse_args() |
| 46 | + random.seed(options.seed) |
| 47 | + tree = random_tree(options.max_branch, options.max_height) |
| 48 | + if options.edge_list: |
| 49 | + nx.write_edgelist(tree, options.output, |
| 50 | + delimiter=options.delimiter, |
| 51 | + data=not options.no_data) |
| 52 | + else: |
| 53 | + nx.write_graphml(tree, options.output) |
| 54 | + return 0 |
| 55 | + |
| 56 | +if __name__ == '__main__': |
| 57 | + status = main() |
| 58 | + sys.exit(status) |
0 commit comments