Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

bench: update random value generation #6430

Merged
merged 2 commits into from
Mar 30, 2025

Conversation

hrshya
Copy link
Contributor

@hrshya hrshya commented Mar 28, 2025

Resolves none .

Description

What is the purpose of this pull request?

This pull request:

  • Refactors random number generation in JS benchmarks for the math/base/special/negafibonacci, math/base/special/negalucas, math/base/special/nonfibonacci and math/base/special/nonfibonaccif packages.
  • Replaces randu() with discreteUniform() from @stdlib/random/array/discrete-uniform for cleaner and more consistent code.
  • Moves the random number generation outside the benchmarking loops.
  • Updates the test messages to follow code conventions.

Related Issues

Does this pull request have any related issues?

This pull request:

  • resolves no related issues.

Questions

Any questions for reviewers of this pull request?

No.

Other

Any other information relevant to this pull request? This may include screenshots, references, and/or implementation notes.

No.

Checklist

Please ensure the following tasks are completed before submitting this pull request.


@stdlib-js/reviewers

@stdlib-bot stdlib-bot added Math Issue or pull request specific to math functionality. Needs Review A pull request which needs code review. labels Mar 28, 2025
@stdlib-bot
Copy link
Contributor

stdlib-bot commented Mar 28, 2025

Coverage Report

Package Statements Branches Functions Lines
math/base/special/negafibonacci $\color{green}221/221$
$\color{green}+100.00\%$
$\color{green}11/11$
$\color{green}+100.00\%$
$\color{green}2/2$
$\color{green}+100.00\%$
$\color{green}221/221$
$\color{green}+100.00\%$
math/base/special/negalucas $\color{green}151/151$
$\color{green}+100.00\%$
$\color{green}9/9$
$\color{green}+100.00\%$
$\color{green}1/1$
$\color{green}+100.00\%$
$\color{green}151/151$
$\color{green}+100.00\%$
math/base/special/nonfibonacci $\color{green}215/215$
$\color{green}+100.00\%$
$\color{green}12/12$
$\color{green}+100.00\%$
$\color{green}2/2$
$\color{green}+100.00\%$
$\color{green}215/215$
$\color{green}+100.00\%$
math/base/special/nonfibonaccif $\color{green}210/210$
$\color{green}+100.00\%$
$\color{green}12/12$
$\color{green}+100.00\%$
$\color{green}2/2$
$\color{green}+100.00\%$
$\color{green}210/210$
$\color{green}+100.00\%$

The above coverage report was generated for the changes in this PR.

@hrshya
Copy link
Contributor Author

hrshya commented Mar 28, 2025

With this PR almost all the packages of math/base/special/* have been refactored.

@@ -46,10 +46,11 @@ bench( pkg, function benchmark( b ) {
var y;
var i;

x = -discreteUniform( 100, 0, 78 );
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This doesn't work. discreteUniform( 100, 0, 78 ); returns an array and we cannot just stick a - in front to get negative values. Instead, please directly draw from the desired distribution, i.e. do discreteUniform( 100, -78, 0 ); here.

Similar changes will have to be made in various other places of this PR.

Copy link
Member

@Planeshifter Planeshifter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Various files will have to be updated to not have a minus sign applied to an array value.

Thanks for your PR and any necessary edits!

@Planeshifter Planeshifter added Needs Changes Pull request which needs changes before being merged. and removed Needs Review A pull request which needs code review. labels Mar 29, 2025
@kgryte kgryte added the Benchmarks Pull requests adding or improving benchmarks for measuring performance. label Mar 29, 2025
@hrshya hrshya requested a review from Planeshifter March 30, 2025 04:35
@stdlib-bot stdlib-bot added the Needs Review A pull request which needs code review. label Mar 30, 2025
Copy link
Member

@Planeshifter Planeshifter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you, @hrshya!

@Planeshifter Planeshifter added the Ready To Merge A pull request which is ready to be merged. label Mar 30, 2025
@stdlib-bot
Copy link
Contributor

PR Commit Message

bench: update random value generation

PR-URL: https://github.com/stdlib-js/stdlib/pull/6430

Co-authored-by: hrshya <[email protected]>
Reviewed-by: Philipp Burckhardt <[email protected]>

Please review the above commit message and make any necessary adjustments.

@stdlib-bot stdlib-bot removed Needs Review A pull request which needs code review. Needs Changes Pull request which needs changes before being merged. labels Mar 30, 2025
@Planeshifter Planeshifter merged commit e9f9513 into stdlib-js:develop Mar 30, 2025
48 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Benchmarks Pull requests adding or improving benchmarks for measuring performance. Math Issue or pull request specific to math functionality. Ready To Merge A pull request which is ready to be merged.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants