Skip to main content

A collection of algorithms for iso-sufrace extraction on GPU. Supports pytorch.

Project description

isoext: Isosurface Extraction on GPU

PyPI version

Overview

Welcome to isoext — a Python library designed for efficient isosurface extraction, leveraging the power of GPU computing and comes with pytorch support. Our library attempts to implement a collection of classic isosurface extraction algorithms. Currently, only the following algorithms are supported, but more will come in the future:

isoext also comes with a Marching Cubes table generator, which you can use to integrate Marching Cubes into your own project or extend isoext with more algorithms. All the lookup tables we used are generated by the generator.

Installation

To install isoext, make sure CUDA Toolkit is installed and run:

pip install isoext

Quick Start

Here's a simple example to get you started:

import isoext
from isoext.sdf import *

aabb = [-1, -1, -1, 1, 1, 1]
res = 128
grid = isoext.make_grid(aabb, res)

torus_a = TorusSDF(R=0.75, r=0.15)
torus_b = RotationOp(sdf=torus_a, axis=[1, 0, 0], angle=90)
torus_c = RotationOp(sdf=torus_a, axis=[0, 1, 0], angle=90)

sphere_a = SphereSDF(radius=0.75)

sdf = IntersectionOp([
    sphere_a, 
    NegationOp(UnionOp([
        torus_a, torus_b, torus_c
    ]))
])
sdf_v = sdf(grid) # must be a cuda pytorchtensor

isolevel = 0

v, f = isoext.marching_cubes(sdf_v, aabb=aabb, level=isolevel, method="nagae")

isoext.write_obj('test.obj', v, f)

Marching Cubes

Arguments

isoext.marching_cubes accepts the following arguments:

  • grid: A CUDA PyTorch tensor representing the scalar field. It should be a 3D tensor.
  • aabb: (Optional) A list or tuple of 6 floats representing the axis-aligned bounding box [xmin, ymin, zmin, xmax, ymax, zmax]. Only one of aabb or cells should be given.
  • cells: (Optional) A CUDA PyTorch tensor representing the cell positions. It a 4D tensor and the first three dimensions must be the same as grid. Only one of aabb or cells should be given.
  • level: (Optional) The isovalue at which to extract the isosurface. Default is 0.0.
  • tight: (Optional) Whether to use tight grid layout. Default is True. When tight is False, the resolution of grid must be (2n, 2, 2). This is useful when cells are not organized in a regular grid.
  • method: (Optional) The marching cubes algorithm to use. Currently, lorensen and nagae are supported. Default is nagae.

Return Value

The function returns a tuple (vertices, faces):

  • vertices: A CUDA PyTorch tensor of shape (V, 3) representing the vertex positions.
  • faces: A CUDA PyTorch tensor of shape (F, 3) representing the triangular faces.
  • If no faces are found, both vertices and faces will be None.

Marching Cubes Table Generator

You can find the generator in luts/gen_mc_lut.py. Available methods are in luts/mc_methods. For example, to generate the table for lorensen, run:

cd luts
python gen_mc_lut.py mc_methods/lorensen.json output

This will generate the luts and as well as the meshes of all the cases inside the output/lorensen folder.

For the cube annotation, refer to the script documentation in luts/gen_mc_lut.py. The cases are indexed in binary format, where the ith bit indicates the ith vertex is below the isosurface if it is 1 and vice versa.

Task List

  • Fix docstring.
  • Add more Marching Cubes variants.
  • Add Dual Contouring.
  • Add Dual Marching Cubes.

License

isoext is released under the MIT License. Feel free to use it in your projects.

Acknowledgments

Project details


Download files

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

Source Distribution

isoext-0.4.2.tar.gz (24.2 kB view details)

Uploaded Source

File details

Details for the file isoext-0.4.2.tar.gz.

File metadata

  • Download URL: isoext-0.4.2.tar.gz
  • Upload date:
  • Size: 24.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.9.21

File hashes

Hashes for isoext-0.4.2.tar.gz
Algorithm Hash digest
SHA256 6badde3aa1905d1ceb804f7518931985709f44b3e1076ba9e59ef7e60043fa47
MD5 4b7940898ffe1388e96ae15e0db50119
BLAKE2b-256 e3d04e86fe2086401256e0c0bd35d61d8ddbc8cf3a308ce227e054068b8aa8aa

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