node package manager
Loosely couple your services. Use Orgs to version and reuse your code. Create a free org »

combinatoricsjs

Combinatorics.js

Introduction

Combinatorics.js is a standalone math library for Javascript and Node.js. It features a solution to work with Permutations, Posets, Trees, and other enumerative collections.

Combinatorics.js is also a module to math.js.

Please see this blog article to get a general feel for this project.

Table of Contents

  1. Install/Build
  2. Roadmap
  3. Contributing
  4. License

Install/Build

To clone this project:

git clone git@github.com:devanp92/combinatorics.js.git
cd combinatorics.js

To install the necessary dependencies:

npm install

To test we use Mocha:

npm test // mocha test --recursive

To build we use Gulp:

gulp

Roadmap

A rough roadmap for Combinatorics.js

Permutation: π : {1...m} -> {1...m}:

  • Behaviors
    • Inverse
    • Multiply
    • Calculate number of cycles
    • Complement
    • Reverse
    • Randomize Permutation
  • States
    • Number of cycles
    • Parity (odd/even)
    • Number of fixed points (is it a Derangement?)
    • Is Identity
  • Ancillary
    • Create/Return iterator
    • Print to cycle notation

Util Functions

  • Is Integer
  • Combinations
  • Enumerative Methods
    • Bell Numbers
    • Stirling numbers of the first kind
    • Partitions
      • (Weak) Compositions
      • Set Partitions
        • Stirling numbers of the second kind
      • Integer Paritions

Contributing

Feel free to contribute to combinatorics.js! You can contribute in different ways: spread the word, report bugs, come up with ideas and suggestions, and contribute to the code.

There are a few preferences regarding code contributions:

Combinatorics.js follows the node.js code style
Send pull requests to the develop branch, not the master branch.
Pleae do not commit any files other than in lib/ and test/.
If adding functionality, please include source (lib/) and test (test/) files.

Thanks!

Adapted from math.js

License

Copyright (C) 2015 Devan Patel devanppatel92@gmail.com

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.