No Description

dependabot[bot] fd1680dcfd Bump pylint from 2.14.1 to 2.14.2 1 year ago
.github d247e77be0 Bump actions/setup-python from 3 to 4 1 year ago
examples 9b88f192f0 Bump notebook from 6.4.7 to 6.4.10 in /examples 2 years ago
freesurfer_surface 14c3f680fc pylint: enable various optional checks/extensions 1 year ago
tests 2bc6d35e82 drop compatibility with python3.6 2 years ago
.gitignore 4b90cba86e dev env: added mypy, removed autopep8 3 years ago
.pylintrc 14c3f680fc pylint: enable various optional checks/extensions 1 year ago
CHANGELOG.md 2bc6d35e82 drop compatibility with python3.6 2 years ago
COPYING ac6fcf78bd added GPLv3+ 3 years ago
MANIFEST.in 021b5e62a7 convert readme from markdown to rest (fixes project overview on pypi) 4 years ago
Pipfile adf0e63139 dev / test env: upgrade black 1 year ago
Pipfile.lock fd1680dcfd Bump pylint from 2.14.1 to 2.14.2 1 year ago
README.rst 378ea44397 drop compatibility with python3.5; raise descriptive exception when missing annotation or geometry info; assume default value for `creator`; fixed type hints 2 years ago
mypy.ini 4b90cba86e dev env: added mypy, removed autopep8 3 years ago
setup.py 6f89b5e201 test against python3.10 2 years ago

README.rst

freesurfer-surface
==================

.. image:: https://img.shields.io/badge/code%20style-black-000000.svg
:target: https://github.com/psf/black
.. image:: https://travis-ci.org/fphammerle/freesurfer-surface.svg?branch=master
:target: https://travis-ci.org/fphammerle/freesurfer-surface
.. image:: https://coveralls.io/repos/github/fphammerle/freesurfer-surface/badge.svg?branch=master
:target: https://coveralls.io/github/fphammerle/freesurfer-surface?branch=master
.. image:: https://img.shields.io/pypi/v/freesurfer-surface.svg
:target: https://pypi.org/project/freesurfer-surface/#history
.. image:: https://img.shields.io/pypi/pyversions/freesurfer-surface.svg
:target: https://pypi.org/project/freesurfer-surface/
.. image:: https://zenodo.org/badge/185943856.svg
:target: https://zenodo.org/badge/latestdoi/185943856

Python Library to Read and Write Surface Files in Freesurfer’s
TriangularSurface Format

Freesurfer https://surfer.nmr.mgh.harvard.edu/

Install
-------

.. code:: sh

pip3 install --user freesurfer-surface

Usage
-----

Read Surface File
~~~~~~~~~~~~~~~~~

.. code:: python

from freesurfer_surface import Surface

surface = Surface.read_triangular('bert/surf/lh.pial')

for vertex in surface.vertices[:3]:
print(vertex)

vertex_0 = surface.vertices[0]
print('coordinates of vertex #0:', (vertex_0.right, vertex_0.anterior, vertex_0.superior))

for triangle_index, triangle in enumerate(surface.triangles[:4]):
print(f'\ntriangle #{triangle_index}:')
print('vertex indices:', triangle.vertex_indices)
print('vertex coordinates:')
for vertex in surface.select_vertices(triangle.vertex_indices):
print((vertex.right, vertex.anterior, vertex.superior))

Edit Surface File
~~~~~~~~~~~~~~~~~

.. code:: python

from freesurfer_surface import Surface, Vertex, Triangle
surface = Surface.read_triangular('bert/surf/lh.pial'))
vertex_a = surface.add_vertex(Vertex(0.0, 0.0, 0.0))
vertex_b = surface.add_vertex(Vertex(1.0, 1.0, 1.0))
vertex_c = surface.add_vertex(Vertex(2.0, 2.0, 2.0))
surface.triangles.append(Triangle((vertex_a, vertex_b, vertex_c)))
surface.write_triangular('somewhere/else/lh.pial')

List Labels in Annotation File
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

.. code:: python

from freesurfer_surface import Annotation

annotation = Annotation.read('tests/subjects/fabian/label/lh.aparc.annot')
for label in annotation.labels.values():
print(label.index, label.hex_color_code, label.name)

or

.. code:: sh

$ freesurfer-annotation-labels tests/subjects/fabian/label/lh.aparc.annot
index color name
0 #190519 unknown
1 #196428 bankssts
2 #7d64a0 caudalanteriorcingulate
3 #641900 caudalmiddlefrontal
...
33 #4614aa temporalpole
34 #9696c8 transversetemporal
35 #ffc020 insula

Find Border of Labelled Region
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

.. code:: python

from freesurfer_surface import Surface
surface = Surface.read_triangular('bert/surf/lh.pial'))
surface.load_annotation_file('bert/label/lh.aparc.annot')
region, = filter(lambda l: l.name == 'precentral',
annotation.labels.values())
print(surface.find_label_border_polygonal_chains(region))

Tests
-----

.. code:: sh

pip3 install --user pipenv
git clone https://github.com/fphammerle/freesurfer-surface.git
cd freesurfer-surface
pipenv run pylint freesurfer_surface
pipenv run pytest --cov=freesurfer_surface