New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

combinatoricsjs

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

combinatoricsjs

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.

latest
Source
npmnpm
Version
0.0.2
Version published
Maintainers
1
Created
Source

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

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.

Keywords

math

FAQs

Package last updated on 01 Sep 2015

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts