gh-85283: _statistics uses the limited C API by vstinner · Pull Request #108500 · python/cpython (original) (raw)

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 andprivacy statement. We’ll occasionally send you account related emails.

Already on GitHub?Sign in to your account

Conversation3 Commits1 Checks0 Files changed

Conversation

This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.Learn more about bidirectional Unicode characters

[ Show hidden characters]({{ revealButtonHref }})

vstinner

@vstinner

Argument Clinic supports positional-only arguments for the limited C API.

@vstinner

With this change, _statistics._normal_dist_inv_cdf() uses less efficient code to parse its arguments:

@vstinner

Micro-benchmark on Linux with CPU isolation, Python built with -O3 (without LTO, without PGO):

$ python -m pyperf compare_to ref.json limited.json 
Mean +- std dev: [ref] 88.6 ns +- 1.5 ns -> [limited] 160 ns +- 1 ns: 1.81x slower

Code:

import _statistics
import pyperf

p = 0.5
mu = 0.0
sigma = 1.0

runner = pyperf.Runner()
runner.bench_func('inv_cdf', _statistics._normal_dist_inv_cdf, p, mu, sigma)

@vstinner

I'm not sure if the _statistics is a good candidate for this work on converting stdlib extensions to the limited C API. The Lib/statistics.py module has a pure Python implementation, and the C code is there for optimization. So I would expect best performance for that. Moreover, the function is quite fast, around 100 ns, so the cost of argument parsing is significant.

2 participants

@vstinner @bedevere-bot