Skip to main content

Python frontend for Gmsh

Project description

PyGmsh
======

|Build Status| |Code Health| |codecov| |Documentation Status| |PyPi
Version| |GitHub stars|

`Gmsh <http://geuz.org/gmsh/>`__ is a powerful mesh generation tool with
a scripting language that is notoriously hard to write.

The goal of PyGmsh is to combine the power of Gmsh with the versatility
of Python and to provide useful abstractions from the Gmsh scripting
language so you can create complex geometries more easily.

.. figure:: https://nschloe.github.io/pygmsh/screw.png
:alt:

To create the above mesh, simply do

.. code:: python test

import pygmsh as pg
import numpy as np

geom = pg.Geometry()

# Draw a cross.
poly = geom.add_polygon([
[0.0, 0.5, 0.0],
[-0.1, 0.1, 0.0],
[-0.5, 0.0, 0.0],
[-0.1, -0.1, 0.0],
[0.0, -0.5, 0.0],
[0.1, -0.1, 0.0],
[0.5, 0.0, 0.0],
[0.1, 0.1, 0.0]
],
lcar=0.05
)

axis = [0, 0, 1]

geom.extrude(
poly,
translation_axis=axis,
rotation_axis=axis,
point_on_axis=[0, 0, 0],
angle=2.0 / 6.0 * np.pi
)

points, cells, point_data, cell_data, field_data = pg.generate_mesh(geom)

to retrieve all points and cells of the mesh for the specified geometry.
To store the mesh, you can use
`meshio <https://pypi.python.org/pypi/meshio>`__; for example

.. code:: python

import meshio
meshio.write('test.vtu', points, cells, cell_data=cell_data)

The output file can be visualized with various tools, e.g.,
`ParaView <http://www.paraview.org/>`__.

You will find the above mesh in the directory ``test/examples/`` along
with other small examples.

Installation
~~~~~~~~~~~~

PyGmsh is `available from the Python Package
Index <https://pypi.python.org/pypi/pygmsh/>`__, so simply type

::

pip install -U pygmsh

to install or upgrade.

Usage
~~~~~

Just

::

import pygmsh as pg

and make use of all the goodies the module provides. The
`documentation <http://pygmsh.readthedocs.org/>`__ and the examples
under
```test/examples/`` <https://github.com/nschloe/pygmsh/tree/master/test/examples>`__
might inspire you.

Testing
~~~~~~~

To run the PyGmsh unit tests, check out this repository and type

::

pytest

Distribution
~~~~~~~~~~~~

To create a new release

1. bump the ``__version__`` number,

2. publish to PyPi and GitHub:

::

$ make publish

License
~~~~~~~

PyGmsh is published under the `MIT
license <https://en.wikipedia.org/wiki/MIT_License>`__.

.. |Build Status| image:: https://travis-ci.org/nschloe/pygmsh.svg
:target: https://travis-ci.org/nschloe/pygmsh
.. |Code Health| image:: https://landscape.io/github/nschloe/pygmsh/master/landscape.png
:target: https://landscape.io/github/nschloe/pygmsh/master
.. |codecov| image:: https://codecov.io/gh/nschloe/pygmsh/branch/master/graph/badge.svg
:target: https://codecov.io/gh/nschloe/pygmsh
.. |Documentation Status| image:: https://readthedocs.org/projects/pygmsh/badge/?version=latest
:target: http://pygmsh.readthedocs.org/en/latest/?badge=latest
.. |PyPi Version| image:: https://img.shields.io/pypi/v/pygmsh.svg
:target: https://pypi.python.org/pypi/pygmsh
.. |GitHub stars| image:: https://img.shields.io/github/stars/nschloe/pygmsh.svg?style=social&label=Star&maxAge=2592000
:target: https://github.com/nschloe/pygmsh


Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pygmsh-3.0.15-py2.py3-none-any.whl (20.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pygmsh-3.0.15-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pygmsh-3.0.15-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f5984952afbddb4cc6b55d072e192dbb6a95afb09b439315aae1dd4f54a7353d
MD5 74177a826b0e613bb6e4571de4467bbc
BLAKE2b-256 92af062f704b2adb3d8e09330842f3a52ce70e2dfb3eff789a6d69a9b978ec8c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page