#graph #partitioning #matrix #mesh #order

sys metis-sys

Raw FFI to METIS, the serial graph partitioner and fill-reducing matrix orderer

6 releases

0.3.1 Mar 10, 2024
0.3.0 Mar 6, 2024
0.2.1 Jul 24, 2023
0.2.0 Jun 12, 2023
0.1.1 Jul 2, 2021

#1679 in Math

Download history 1538/week @ 2024-06-03 1232/week @ 2024-06-10 1068/week @ 2024-06-17 1082/week @ 2024-06-24 1273/week @ 2024-07-01 1215/week @ 2024-07-08 1304/week @ 2024-07-15 1059/week @ 2024-07-22 940/week @ 2024-07-29 870/week @ 2024-08-05 883/week @ 2024-08-12 791/week @ 2024-08-19 908/week @ 2024-08-26 1051/week @ 2024-09-02 945/week @ 2024-09-09 1214/week @ 2024-09-16

4,228 downloads per month
Used in 4 crates (via metis)

MIT/Apache

5MB
39K SLoC

C 31K SLoC // 0.2% comments GLSL 7.5K SLoC Rust 443 SLoC // 0.0% comments Perl 36 SLoC // 0.1% comments Shell 28 SLoC // 0.1% comments Batch 8 SLoC

metis-rs

metis-rs is a Rust library providing idiomatic bindings to libmetis, a library for graph and mesh partitioning. It is made to be used with Rust version 1.67.0 or above.

Getting Started

Library released on crates.io. To use it, add the following to your Cargo.toml:

[dependencies]
metis-rs = "0.2"

The list of available versions and a change log are available in the CHANGELOG.md file.

Features

Use of Vendored Feature

The vendored feature enables metis-rs to build METIS from source and link to it statically. If not enabled, metis-rs looks for an existing installation and links to it dynamically.

Use of System-wide Feature

The use-system feature enables metis-rs to use the system-wide installation of METIS. If not enabled, metis-rs will refer to its own version of METIS.

Please note, vendored and use-system features are mutually exclusive.

Guidance for non-standard METIS installations

If you enabled the use-system feature and METIS is installed in a non-standard location, you must set the following environment variables:

export METISDIR=path/to/your/metis/installation
export CPATH="$METISDIR/include"
export RUSTFLAGS="-L$METISDIR/lib"

$METISDIR must point to a directory containing both lib/ and include/ directories with METIS's shared libraries and headers, respectively.

Building the documentation

To build the documentation, especially if METIS is installed in a non-standard location, set the RUSTDOCFLAGS environment variable:

export RUSTDOCFLAGS="-L$METISDIR/lib"

Then the following command will generate and open the documentation:

cargo doc --no-deps --open

License

metis-rs is distributed under the terms of both the MIT license and the Apache License (Version 2.0). Refer to LICENSE-APACHE and LICENSE-MIT for more details.

No runtime deps