Apache Commons RNG (Pseudo-random number generators)

Clone this repo:
  1. 91224cc Update legacy GitHub links in CONTRIBUTING.md by Gary Gregory · 16 hours ago master
  2. 000b658 Bump GH CI actions/checkout from 6.0.2 to 6.0.3 by Gary Gregory · 5 days ago
  3. 35ca184 Bump github/codeql-action from 4.36.0 to 4.36.2 by Gary Gregory · 7 days ago
  4. 098b9ad Bump github/codeql-action from 4.35.5 to 4.36.0 by Gary Gregory · 2 weeks ago
  5. 431ccf4 Bump github/codeql-action from 4.35.4 to 4.35.5 by Gary Gregory · 3 weeks ago

Apache Commons RNG

Java CI Coverage Status Quality Gate Status Maven Central CodeQL OpenSSF Scorecard

The Apache Commons RNG project provides pure-Java implementation of pseudo-random generators.

Documentation

More information can be found on the Apache Commons RNG homepage. The Javadoc for each of the modules can be browsed:

Questions related to the usage of Apache Commons RNG should be posted to the user mailing list.

Getting the latest release

You can download source and binaries from our download page.

Alternatively, you can pull it from the central Maven repositories:

<dependency>
  <groupId>org.apache.commons</groupId>
  <artifactId>commons-rng-simple</artifactId>
  <version>1.7</version>
</dependency>
<dependency>
  <groupId>org.apache.commons</groupId>
  <artifactId>commons-rng-sampling</artifactId>
  <version>1.7</version>
</dependency>

Building

Building requires a Java JDK and Apache Maven. The required Java version is found in the pom.xml as the maven.compiler.source property.

From a command shell, run mvn without arguments to invoke the default Maven goal to run all tests and checks.

Contributing

We accept Pull Requests via GitHub. The developer mailing list is the main channel of communication for contributors. There are some guidelines which will make applying PRs easier for us:

  • No tabs! Please use spaces for indentation.
  • Respect the existing code style for each file.
  • Create minimal diffs - disable on save actions like reformat source code or organize imports. If you feel the source code should be reformatted create a separate PR for this change.
  • Provide JUnit tests for your changes and make sure your changes don't break any existing tests by running mvn.
  • Before you push a PR, run mvn (without arguments). This runs the default goal which contains all build checks.
  • To see the code coverage report, regardless of coverage failures, run mvn clean site -Dcommons.jacoco.haltOnFailure=false -Pjacoco

If you plan to contribute on a regular basis, please consider filing a contributor license agreement. You can learn more about contributing via GitHub in our contribution guidelines.

License

This code is licensed under the Apache License v2.

See the NOTICE file for required notices and attributions.

Donating

You like Apache Commons RNG? Then donate back to the ASF to support development.

Additional Resources

Apache Commons Components

Please see the list of components