PyO3
pyo3
BlogDocsChangelog

hack: try removing error normalization

#4859
Comparing
davidhewitt:no-err-normalization
(
71e0281
) with
main
(
da618c7
)
CodSpeed Performance Gauge
-88%
Improvements
14
Regressions
2
Untouched
82
Ignored
21

Benchmarks

Failed

extract_str_extract_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Regression
CodSpeed Performance Gauge
-82%
1.8 µs10.4 µs
err_new_without_gil
pyo3-benches/benches/bench_err.rs::benches::criterion_benchmark
Regression
CodSpeed Performance Gauge
-88%
1.2 µs10.4 µs

Improved

not_a_list_via_extract_enum
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+38%
17.6 µs12.8 µs
enum_from_pyobject
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+30%
23.6 µs18.2 µs
ordered_richcmp
pyo3-benches/benches/bench_comparisons.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
2.4 µs2.1 µs
tuple_get_item
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
3.8 ms3.3 ms
list_get_item
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
3.9 ms3.3 ms
tuple_nth
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
3.9 µs3.4 µs
tuple_get_borrowed_item
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
3.6 ms3.1 ms
tuple_nth_back
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+16%
4 µs3.4 µs
list_nth
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+15%
4.3 µs3.7 µs
list_nth_back
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+15%
4.3 µs3.8 µs
ordered_dunder_methods
pyo3-benches/benches/bench_comparisons.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+13%
2.6 µs2.3 µs
tuple_get_borrowed_item_unchecked
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+13%
3.1 ms2.7 ms
tuple_get_item_unchecked
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+12%
3.3 ms2.9 ms
list_get_item_unchecked
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+12%
3.3 ms3 ms

Passed

iter_tuple
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+6%
5.5 ms5.2 ms
iter_list
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+5%
6.3 ms6 ms
extract_int_extract_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+5%
11.5 µs10.9 µs
collect_generic_iterator
pyo3-benches/benches/bench_any.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+4%
95.8 ms91.8 ms
extract_bigint_extract_fail
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+4%
11.6 µs11.1 µs
decimal_via_extract
pyo3-benches/benches/bench_decimal.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+4%
14.9 µs14.4 µs
extract_float_extract_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+4%
11.6 µs11.2 µs
getattr_intern
pyo3-benches/benches/bench_intern.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+4%
3.3 µs3.2 µs
test_with_typed_args_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+3%
17.2 µs16.7 µs
err_new_restore_and_fetch
pyo3-benches/benches/bench_err.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
7.7 µs7.4 µs
extract_hashbrown_map
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
17.1 ms16.6 ms
iter_set
pyo3-benches/benches/bench_set.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
10.3 ms10 ms
extract_btreeset
pyo3-benches/benches/bench_set.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
15.3 ms14.9 ms
extract_hashmap
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
19.8 ms19.2 ms
iter_dict
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
11 ms10.7 ms
dict_get_item
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+3%
16.3 ms15.9 ms
test_simple_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+3%
18.3 µs17.8 µs
test_simple_kwargs_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
18.6 µs18.2 µs
vec_into_pyobject
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
2.5 µs2.4 µs
test_simple_args_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
18.9 µs18.5 µs
extract_bigint_small
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
2.6 µs2.6 µs
test_simple_args_kwargs_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
19.1 µs18.7 µs
extract_hashbrown_set
pyo3-benches/benches/bench_set.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
15.8 ms15.5 ms
test_none_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
12.8 µs12.5 µs
extract_hashset
pyo3-benches/benches/bench_set.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
20.3 ms20 ms
bytes_new_medium
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
1.6 µs1.5 µs
test_args_kwargs_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
14.4 µs14.1 µs
byte_slice_into_pyobject_medium
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
1.6 µs1.6 µs
extract_btreemap
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
37 ms36.4 ms
test_many_keyword_arguments_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+2%
18.9 µs18.6 µs
call_one_arg
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+2%
232.1 µs228.5 µs
test_setter
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
+1%
16.9 µs16.6 µs
test_positional_only_rs
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+1%
13.7 µs13.6 µs
test_class_method
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
+1%
17.9 µs17.7 µs
identify_object_type
pyo3-benches/benches/bench_any.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
15.7 µs15.6 µs
test_proto_call
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
+1%
13.4 µs13.3 µs
extract_bigint_big_positive
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
3.7 µs3.6 µs
extract_bigint_huge_positive
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
11.6 µs11.6 µs
extract_bigint_big_negative
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
3.9 µs3.9 µs
dict_new
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
25.7 ms25.5 ms
extract_bigint_huge_negative
pyo3-benches/benches/bench_bigint.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
13.2 µs13.1 µs
tuple_new_list
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
2.1 ms2.1 ms
first_time_init
pyo3-benches/benches/bench_pyclass.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
+1%
39.7 µs39.4 µs
test_method_call
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
+1%
14.9 µs14.8 µs
test_static_method
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
+1%
15.7 µs15.6 µs
test_simple_args_kwargs_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
+1%
20.7 µs20.6 µs
test_args_kwargs_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
19 µs18.9 µs
list_new
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
6.7 ms6.7 ms
call_method_one_arg
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
628.1 µs626.1 µs
test_positional_only_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
13.6 µs13.6 µs
test_with_typed_args_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
13.7 µs13.7 µs
test_method_call_py
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
0%
14 µs14 µs
test_empty_class_init_py
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
0%
14 µs14 µs
test_many_keyword_arguments_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
16.9 µs16.9 µs
test_empty_class_init
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
0%
23.4 µs23.4 µs
test_simple_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
17.4 µs17.3 µs
test_simple_args_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
17.8 µs17.8 µs
call_1
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
253.5 µs253.1 µs
vec_bytes_from_py_bytearray_large
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
177.9 µs177.7 µs
tuple_into_pyobject
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
2.8 µs2.8 µs
call_method_1
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
657.5 µs657.1 µs
call
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
609.6 µs609.3 µs
call_0
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
191.6 µs191.6 µs
vec_bytes_from_py_bytearray_medium
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
2 µs2 µs
vec_bytes_from_py_bytes_medium
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
2 µs2 µs
call_method_0
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
608.3 µs608.1 µs
tuple_new
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
6.7 ms6.7 ms
tuple_to_list
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
1.6 ms1.6 ms
set_new
pyo3-benches/benches/bench_set.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
15.2 ms15.2 ms
clean_attach
pyo3-benches/benches/bench_attach.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
3.5 µs3.5 µs
drop_many_objects
pyo3-benches/benches/bench_py.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
3.8 µs3.8 µs
drop_many_objects_without_gil
pyo3-benches/benches/bench_py.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
44.9 µs44.9 µs
byte_slice_into_pyobject_large
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
176.7 µs176.7 µs
bytes_new_large
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
176.7 µs176.7 µs
vec_bytes_from_py_bytes_large
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
177.7 µs177.7 µs
test_simple_kwargs_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
20.4 µs20.4 µs
call_method
pyo3-benches/benches/bench_call.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
0%
1.3 ms1.3 ms
test_proto_call_py
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
0%
14.4 µs14.4 µs
test_none_py
pytests/tests/test_pyfunctions.py
CodSpeed Performance Gauge
0%
13.4 µs13.4 µs
test_class_attribute
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
0%
14.1 µs14.1 µs
dirty_attach
pyo3-benches/benches/bench_attach.rs::benches::criterion_benchmark
CodSpeed Performance Gauge
-1%
5 µs5 µs
test_getter
pytests/tests/test_pyclasses.py
CodSpeed Performance Gauge
-5%
16.4 µs17.3 µs

Ignored

sequence_from_list
pyo3-benches/benches/bench_list.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
272.5 ns272.5 ns
sequence_from_tuple
pyo3-benches/benches/bench_tuple.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
301.7 ns301.7 ns
extract_float_cast_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+20%
178.3 ns149.2 ns
extract_float_cast_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
-6%
456.9 ns486.1 ns
extract_float_extract_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+10%
331.9 ns303.1 ns
extract_int_cast_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+11%
306.9 ns277.8 ns
extract_int_cast_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+30%
519.4 ns398.6 ns
extract_int_extract_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+36%
456.1 ns335.6 ns
extract_str_cast_fail
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
273.6 ns273.6 ns
mapping_from_dict
pyo3-benches/benches/bench_dict.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+11%
301.7 ns272.5 ns
extract_str_extract_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+11%
608.3 ns549.7 ns
list_via_cast
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
149.2 ns149.2 ns
not_a_list_via_cast
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
-12%
214.4 ns243.6 ns
extract_str_cast_success
pyo3-benches/benches/bench_extract.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+18%
583.1 ns494.7 ns
vec_bytes_from_py_bytearray_small
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
776.1 ns775.6 ns
not_a_list_via_extract
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+14%
243.6 ns214.4 ns
list_via_extract
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
183.9 ns183.9 ns
getattr_direct
pyo3-benches/benches/bench_intern.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
+1%
6.5 µs6.4 µs
vec_bytes_from_py_bytes_small
pyo3-benches/benches/bench_frompyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
802.5 ns801.9 ns
bytes_new_small
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
305.8 ns305.8 ns
byte_slice_into_pyobject_small
pyo3-benches/benches/bench_intopyobject.rs::benches::criterion_benchmark
Ignored
CodSpeed Performance Gauge
0%
335 ns335 ns

Commits

Click on a commit to change the comparison range
Base
main
da618c7
-88.66%
hack: try removing error normalization
31b7f09
1 year ago
by davidhewitt
+0.61%
Merge branch 'main' into no-err-normalization
71e0281
3 months ago
by davidhewitt
© 2025 CodSpeed Technology
Home Terms Privacy Docs