Skip to content

This is an experiment implementing a WebAssembly pairwise sequence alignment module in Rust 🦀.

License

Notifications You must be signed in to change notification settings

hdescobarh/pairwasm_alignment

Repository files navigation

pairwasm_alignment

Rust WebAssembly npm Experimental License

WebAssembly performance, portability, and interoperability could bring the power of the Cloud to Bioinformatics and Computational Biology, facilitating collaboration among researchers and enhancing reproducibility.

This experiment is a WebAssembly pairwise sequence alignment module written in Rust 🦀. It implements the classic Needleman-Wunsch and Smith-Waterman.

Crate documentation and Demonstration

The WASM module use is straightforward since it only exposes a single function; read the next section for details. Also, you can check the Rust crate documentation here.

I also deployed an online demonstration that runs locally and on your browser. Be aware that Smith-Waterman and Needleman-Wunsch are dynamic programming algorithms and have quadratic time performance. Do not use the demo for long sequences.


Check the demo
pairwasm_alignment

Releases and how to use them

The module is offered in two flavors:

The wasm module itself is natively an ES module 1. It needs a Bundler. Only Webpack offers total compatibility and other bundlers will require additional configurations.

It can natively be included on a web page, and doesn't require any further postprocessing 1.

For example,

import init, { do_protein_alignment } from "./wasm_module/pairwasm_alignment.js";

export async function run(
  string_1: string,
  string_2: string,
  open_cost: number,
  extend_cost: number,
  substitution_matrix: number,
  algorithm: number) {
  await init();
  return do_protein_alignment(
    string_1,
    string_2,
    open_cost,
    extend_cost,
    substitution_matrix,
    algorithm
  );
}

Then the run function can be imported normally in any script.

Known issues

  • Using local alignment can give suboptimal alignments.


Bibliography

Footnotes

  1. Deploying Rust and WebAssembly. ↩ ↩2

About

This is an experiment implementing a WebAssembly pairwise sequence alignment module in Rust 🦀.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages