__main__.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import argparse
  2. import csv
  3. import sys
  4. from freesurfer_surface import Annotation, Surface
  5. def annotation_labels():
  6. """
  7. List Labels Stored in Freesurfer's Annotation File
  8. (i.e., label/lh.aparc.annot)
  9. """
  10. argparser = argparse.ArgumentParser(description=annotation_labels.__doc__.strip())
  11. argparser.add_argument("--delimiter", default="\t", help="default: %(default)r")
  12. argparser.add_argument("annotation_file_path")
  13. args = argparser.parse_args()
  14. annotation = Annotation.read(args.annotation_file_path)
  15. csv_writer = csv.writer(sys.stdout, delimiter=args.delimiter)
  16. csv_writer.writerow(("index", "color", "name"))
  17. labels = sorted(annotation.labels.values(), key=lambda l: l.index)
  18. csv_writer.writerows(
  19. (
  20. l.index,
  21. l.hex_color_code,
  22. l.name,
  23. )
  24. for l in labels
  25. )
  26. def unite_surfaces():
  27. """
  28. Unite Multiple Surfaces in Freesurfer's TriangularSurface Format
  29. Into a Single TriangularSurface File (i.e., lh.pial, lh.white)
  30. """
  31. argparser = argparse.ArgumentParser(description=unite_surfaces.__doc__.strip())
  32. argparser.add_argument(
  33. "--output", metavar="OUTPUT_PATH", dest="output_path", required=True
  34. )
  35. argparser.add_argument("input_paths", metavar="INPUT_PATH", nargs="+")
  36. args = argparser.parse_args()
  37. union = Surface.unite(Surface.read_triangular(p) for p in args.input_paths)
  38. union.write_triangular(args.output_path)