forked from fastruby/fast-ruby
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtruffleruby-3.3.5.fastruby
922 lines (800 loc) · 42 KB
/
truffleruby-3.3.5.fastruby
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
$ ruby -v code/general/array-argument-vs-splat-arguments.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Function with single Array argument
266.475M i/100ms
Function with splat arguments
2.012k i/100ms
Calculating -------------------------------------
Function with single Array argument
3.163B (± 2.1%) i/s - 15.989B in 5.056526s
Function with splat arguments
21.067k (± 8.4%) i/s - 104.624k in 5.010276s
Comparison:
Function with single Array argument: 3163440638.6 i/s
Function with splat arguments: 21067.2 i/s - 150159.33x (± 0.00) slower
$ ruby -v code/general/assignment.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Parallel Assignment 315.892M i/100ms
Sequential Assignment
317.589M i/100ms
Calculating -------------------------------------
Parallel Assignment 3.168B (± 2.0%) i/s - 16.111B in 5.088069s
Sequential Assignment
3.113B (± 4.0%) i/s - 15.562B in 5.007770s
Comparison:
Parallel Assignment: 3167592019.9 i/s
Sequential Assignment: 3113470451.6 i/s - same-ish: difference falls within error
$ ruby -v code/general/attr-accessor-vs-getter-and-setter.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
getter_and_setter 302.380M i/100ms
attr_accessor 308.978M i/100ms
Calculating -------------------------------------
getter_and_setter 3.109B (± 3.4%) i/s - 15.724B in 5.063843s
attr_accessor 3.085B (± 3.0%) i/s - 15.449B in 5.012316s
Comparison:
getter_and_setter: 3109053736.7 i/s
attr_accessor: 3085194065.5 i/s - same-ish: difference falls within error
$ ruby -v code/general/begin-rescue-vs-respond-to.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
begin...rescue 9.049k i/100ms
respond_to? 308.872M i/100ms
Calculating -------------------------------------
begin...rescue 104.255k (± 7.6%) i/s - 524.842k in 5.073684s
respond_to? 3.173B (± 2.4%) i/s - 16.061B in 5.064796s
Comparison:
respond_to?: 3173190487.1 i/s
begin...rescue: 104254.7 i/s - 30436.92x (± 0.00) slower
$ ruby -v code/general/block-apply-method.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
normal 317.580M i/100ms
&method 18.095M i/100ms
Calculating -------------------------------------
normal 3.100B (± 4.0%) i/s - 15.561B in 5.029185s
&method 182.045M (± 1.8%) i/s - 922.846M in 5.070982s
Comparison:
normal: 3099583771.0 i/s
&method: 182045215.1 i/s - 17.03x (± 0.00) slower
$ ruby -v code/general/define_method-vs-module-eval.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
module_eval with string
165.000 i/100ms
define_method 148.000 i/100ms
Calculating -------------------------------------
module_eval with string
4.134k (±52.2%) i/s - 7.920k in 5.072194s
define_method 11.346k (±44.6%) i/s - 10.064k in 5.037638s
Comparison:
define_method: 11346.4 i/s
module_eval with string: 4134.2 i/s - same-ish: difference falls within error
$ ruby -v code/general/format-vs-round-and-to-s.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Float#round 265.511k i/100ms
Kernel#format 188.226k i/100ms
String#% 186.078k i/100ms
Calculating -------------------------------------
Float#round 2.805M (± 2.9%) i/s - 14.072M in 5.022179s
Kernel#format 1.884M (± 3.1%) i/s - 9.411M in 5.000457s
String#% 1.882M (± 4.0%) i/s - 9.490M in 5.051172s
Comparison:
Float#round: 2804546.9 i/s
Kernel#format: 1883915.3 i/s - 1.49x (± 0.00) slower
String#%: 1882125.5 i/s - 1.49x (± 0.00) slower
$ ruby -v code/general/hash-vs-openstruct-on-access.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash 318.179M i/100ms
OpenStruct 314.948M i/100ms
Calculating -------------------------------------
Hash 3.171B (± 2.8%) i/s - 15.909B in 5.020845s
OpenStruct 3.187B (± 1.7%) i/s - 16.062B in 5.042057s
Comparison:
OpenStruct: 3186612943.1 i/s
Hash: 3171423619.2 i/s - same-ish: difference falls within error
$ ruby -v code/general/hash-vs-openstruct.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash 308.230M i/100ms
OpenStruct 2.547k i/100ms
Calculating -------------------------------------
Hash 2.991B (±11.5%) i/s - 14.795B in 5.038333s
OpenStruct 46.202k (±22.6%) i/s - 216.495k in 5.034010s
Comparison:
Hash: 2990956280.7 i/s
OpenStruct: 46201.6 i/s - 64737.04x (± 0.00) slower
$ ruby -v code/general/inheritance-check.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
less than or equal 946.261k i/100ms
ancestors.include? 226.494k i/100ms
Calculating -------------------------------------
less than or equal 10.360M (± 4.1%) i/s - 52.044M in 5.031979s
ancestors.include? 2.342M (± 7.3%) i/s - 11.778M in 5.066485s
Comparison:
less than or equal: 10360454.0 i/s
ancestors.include?: 2341738.9 i/s - 4.42x (± 0.00) slower
$ ruby -v code/general/loop-vs-while-true.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
While Loop 1.000 i/100ms
Kernel loop 1.000 i/100ms
Calculating -------------------------------------
While Loop 31.575 (± 6.3%) i/s - 158.000 in 5.028931s
Kernel loop 31.616 (± 3.2%) i/s - 158.000 in 5.008213s
Comparison:
Kernel loop: 31.6 i/s
While Loop: 31.6 i/s - same-ish: difference falls within error
$ ruby -v code/general/raise-vs-e2mmap.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
$ ruby -v code/array/array-first-vs-index.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#[0] 309.765M i/100ms
Array#first 312.466M i/100ms
Calculating -------------------------------------
Array#[0] 3.145B (± 2.2%) i/s - 15.798B in 5.026166s
Array#first 3.168B (± 2.3%) i/s - 15.936B in 5.033800s
Comparison:
Array#first: 3167546016.9 i/s
Array#[0]: 3144775281.0 i/s - same-ish: difference falls within error
$ ruby -v code/array/array-last-vs-index.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#[-1] 291.679M i/100ms
Array#last 313.426M i/100ms
Calculating -------------------------------------
Array#[-1] 3.144B (± 2.4%) i/s - 15.751B in 5.013562s
Array#last 3.093B (± 4.1%) i/s - 15.671B in 5.076606s
Comparison:
Array#[-1]: 3143566169.9 i/s
Array#last: 3093067133.5 i/s - same-ish: difference falls within error
$ ruby -v code/array/bsearch-vs-find.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
find 1.000 i/100ms
bsearch 926.510k i/100ms
Calculating -------------------------------------
find 13.705 (± 0.0%) i/s - 69.000 in 5.034605s
bsearch 9.299M (± 3.6%) i/s - 47.252M in 5.088687s
Comparison:
bsearch: 9298716.4 i/s
find: 13.7 i/s - 678475.02x (± 0.00) slower
$ ruby -v code/array/insert-vs-unshift.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#unshift 1.000 i/100ms
Array#insert 1.000 i/100ms
Calculating -------------------------------------
Array#unshift 0.211 (± 0.0%) i/s - 2.000 in 9.462702s
Array#insert 1.385 (± 0.0%) i/s - 7.000 in 5.055869s
Comparison:
Array#insert: 1.4 i/s
Array#unshift: 0.2 i/s - 6.55x (± 0.00) slower
$ ruby -v code/array/length-vs-size-vs-count.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#length 315.818M i/100ms
Array#size 315.527M i/100ms
Array#count 320.963M i/100ms
Calculating -------------------------------------
Array#length 3.159B (± 3.4%) i/s - 15.791B in 5.005642s
Array#size 3.183B (± 2.3%) i/s - 16.092B in 5.058585s
Array#count 3.162B (± 5.0%) i/s - 16.048B in 5.092647s
Comparison:
Array#size: 3182993262.3 i/s
Array#count: 3162310091.4 i/s - same-ish: difference falls within error
Array#length: 3158665848.3 i/s - same-ish: difference falls within error
$ ruby -v code/array/shuffle-first-vs-sample.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#shuffle.first 36.205k i/100ms
Array#sample 3.708M i/100ms
Calculating -------------------------------------
Array#shuffle.first 369.605k (± 2.9%) i/s - 1.846M in 5.000268s
Array#sample 36.929M (± 2.1%) i/s - 185.404M in 5.023076s
Comparison:
Array#sample: 36929030.3 i/s
Array#shuffle.first: 369604.7 i/s - 99.91x (± 0.00) slower
$ ruby -v code/date/iso8601-vs-parse.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Date.iso8601 927.000 i/100ms
Date.parse 563.000 i/100ms
Calculating -------------------------------------
Date.iso8601 16.058k (±30.3%) i/s - 73.233k in 5.016969s
Date.parse 7.853k (±24.5%) i/s - 36.595k in 5.029869s
Comparison:
Date.iso8601: 16058.0 i/s
Date.parse: 7853.0 i/s - 2.04x (± 0.00) slower
$ ruby -v code/enumerable/each-push-vs-map.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#each + push 293.437k i/100ms
Array#map 1.796M i/100ms
Calculating -------------------------------------
Array#each + push 3.244M (± 7.1%) i/s - 16.139M in 5.011134s
Array#map 18.430M (± 9.1%) i/s - 91.580M in 5.017192s
Comparison:
Array#map: 18429956.3 i/s
Array#each + push: 3243974.5 i/s - 5.68x (± 0.00) slower
$ ruby -v code/enumerable/each-vs-for-loop.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
For loop 11.538M i/100ms
#each 35.460M i/100ms
Calculating -------------------------------------
For loop 117.854M (± 1.0%) i/s - 599.987M in 5.091503s
#each 350.839M (± 2.8%) i/s - 1.773B in 5.058148s
Comparison:
#each: 350838846.1 i/s
For loop: 117854435.6 i/s - 2.98x (± 0.00) slower
$ ruby -v code/enumerable/each_with_index-vs-while-loop.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
While Loop 1.388M i/100ms
each_with_index 2.368M i/100ms
Calculating -------------------------------------
While Loop 14.080M (± 2.3%) i/s - 70.806M in 5.031586s
each_with_index 26.755M (± 6.0%) i/s - 134.978M in 5.064557s
Comparison:
each_with_index: 26755059.0 i/s
While Loop: 14079918.3 i/s - 1.90x (± 0.00) slower
$ ruby -v code/enumerable/inject-symbol-vs-block.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
inject symbol 305.514k i/100ms
inject to_proc 308.687k i/100ms
inject block 310.870k i/100ms
Calculating -------------------------------------
inject symbol 3.086M (± 2.9%) i/s - 15.581M in 5.054230s
inject to_proc 3.096M (± 1.4%) i/s - 15.743M in 5.085627s
inject block 3.080M (± 4.1%) i/s - 15.543M in 5.057928s
Comparison:
inject to_proc: 3096266.2 i/s
inject symbol: 3085640.5 i/s - same-ish: difference falls within error
inject block: 3079787.0 i/s - same-ish: difference falls within error
$ ruby -v code/enumerable/map-flatten-vs-flat_map.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#map.flatten(1) 20.066k i/100ms
Array#map.flatten 24.420k i/100ms
Array#flat_map 56.520k i/100ms
Calculating -------------------------------------
Array#map.flatten(1) 257.135k (± 8.2%) i/s - 1.284M in 5.050815s
Array#map.flatten 263.144k (± 6.2%) i/s - 1.319M in 5.031122s
Array#flat_map 584.882k (± 4.4%) i/s - 2.939M in 5.035523s
Comparison:
Array#flat_map: 584881.9 i/s
Array#map.flatten: 263144.2 i/s - 2.22x (± 0.00) slower
Array#map.flatten(1): 257135.0 i/s - 2.27x (± 0.00) slower
$ ruby -v code/enumerable/reverse-each-vs-reverse_each.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Array#reverse.each 281.504k i/100ms
Array#reverse_each 2.854M i/100ms
Calculating -------------------------------------
Array#reverse.each 3.441M (± 6.6%) i/s - 17.172M in 5.024581s
Array#reverse_each 28.434M (± 3.4%) i/s - 142.709M in 5.026029s
Comparison:
Array#reverse_each: 28434433.3 i/s
Array#reverse.each: 3440676.7 i/s - 8.26x (± 0.00) slower
$ ruby -v code/enumerable/select-first-vs-detect.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Enumerable#select.first
932.434k i/100ms
Enumerable#detect 4.677M i/100ms
Calculating -------------------------------------
Enumerable#select.first
10.287M (± 8.2%) i/s - 204.203M in 20.040827s
Enumerable#detect 46.330M (± 2.3%) i/s - 926.064M in 20.001079s
Comparison:
Enumerable#detect: 46329781.5 i/s
Enumerable#select.first: 10286958.1 i/s - 4.50x (± 0.00) slower
$ ruby -v code/enumerable/select-last-vs-reverse-detect.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Enumerable#reverse.detect
367.580k i/100ms
Enumerable#select.last
500.887k i/100ms
Calculating -------------------------------------
Enumerable#reverse.detect
3.653M (± 6.5%) i/s - 18.379M in 5.061947s
Enumerable#select.last
5.349M (± 6.3%) i/s - 27.048M in 5.085039s
Comparison:
Enumerable#select.last: 5349396.5 i/s
Enumerable#reverse.detect: 3652610.7 i/s - 1.46x (± 0.00) slower
$ ruby -v code/enumerable/sort-vs-sort_by.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Enumerable#sort_by (Symbol#to_proc)
3.813k i/100ms
Enumerable#sort_by 1.068k i/100ms
Enumerable#sort 4.650k i/100ms
Calculating -------------------------------------
Enumerable#sort_by (Symbol#to_proc)
29.364k (±22.6%) i/s - 141.081k in 5.037378s
Enumerable#sort_by 33.056k (±32.9%) i/s - 134.568k in 4.998894s
Enumerable#sort 53.362k (± 4.8%) i/s - 269.700k in 5.067723s
Comparison:
Enumerable#sort: 53362.3 i/s
Enumerable#sort_by: 33056.2 i/s - 1.61x (± 0.00) slower
Enumerable#sort_by (Symbol#to_proc): 29364.4 i/s - 1.82x (± 0.00) slower
$ ruby -v code/enumerable/sort_by-first-vs-min_by.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Enumerable#min_by 980.917k i/100ms
Enumerable#sort_by...first
9.205k i/100ms
Calculating -------------------------------------
Enumerable#min_by 9.903M (± 1.8%) i/s - 50.027M in 5.053580s
Enumerable#sort_by...first
112.743k (± 6.4%) i/s - 561.505k in 5.011948s
Comparison:
Enumerable#min_by: 9902539.7 i/s
Enumerable#sort_by...first: 112743.4 i/s - 87.83x (± 0.00) slower
$ ruby -v code/hash/bracket-vs-dup.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash[] 621.470k i/100ms
Hash#dup 674.508k i/100ms
Calculating -------------------------------------
Hash[] 7.501M (± 9.5%) i/s - 37.288M in 5.038540s
Hash#dup 7.193M (±12.3%) i/s - 35.749M in 5.049931s
Comparison:
Hash[]: 7501245.9 i/s
Hash#dup: 7193220.0 i/s - same-ish: difference falls within error
$ ruby -v code/hash/bracket-vs-fetch.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#[], symbol 303.492M i/100ms
Hash#fetch, symbol 301.341M i/100ms
Hash#[], string 29.221M i/100ms
Hash#fetch, string 26.746M i/100ms
Calculating -------------------------------------
Hash#[], symbol 3.114B (± 1.8%) i/s - 15.782B in 5.069295s
Hash#fetch, symbol 3.138B (± 2.3%) i/s - 15.971B in 5.091615s
Hash#[], string 290.945M (± 1.3%) i/s - 1.461B in 5.022739s
Hash#fetch, string 266.578M (± 1.4%) i/s - 1.337B in 5.017495s
Comparison:
Hash#fetch, symbol: 3138468152.9 i/s
Hash#[], symbol: 3114166046.2 i/s - same-ish: difference falls within error
Hash#[], string: 290945006.8 i/s - 10.79x (± 0.00) slower
Hash#fetch, string: 266577710.9 i/s - 11.77x (± 0.00) slower
$ ruby -v code/hash/dig-vs-[]-vs-fetch.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#dig 90.708M i/100ms
Hash#[] 90.312M i/100ms
Hash#[] || 91.253M i/100ms
Hash#[] && 91.859M i/100ms
Hash#fetch 91.882M i/100ms
Hash#fetch fallback 91.532M i/100ms
Calculating -------------------------------------
Hash#dig 911.549M (± 1.9%) i/s - 4.626B in 5.076895s
Hash#[] 915.577M (± 1.5%) i/s - 4.606B in 5.031755s
Hash#[] || 912.470M (± 1.8%) i/s - 4.563B in 5.002015s
Hash#[] && 917.017M (± 1.0%) i/s - 4.593B in 5.009097s
Hash#fetch 914.347M (± 1.4%) i/s - 4.594B in 5.025569s
Hash#fetch fallback 911.157M (± 2.9%) i/s - 4.577B in 5.027662s
Comparison:
Hash#[] &&: 917016789.0 i/s
Hash#[]: 915577295.9 i/s - same-ish: difference falls within error
Hash#fetch: 914347496.3 i/s - same-ish: difference falls within error
Hash#[] ||: 912470131.4 i/s - same-ish: difference falls within error
Hash#dig: 911548947.3 i/s - same-ish: difference falls within error
Hash#fetch fallback: 911157378.7 i/s - same-ish: difference falls within error
$ ruby -v code/hash/fetch-vs-fetch-with-block.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#fetch + const 314.243M i/100ms
Hash#fetch + block 307.857M i/100ms
Hash#fetch + arg 308.180M i/100ms
Calculating -------------------------------------
Hash#fetch + const 3.121B (± 2.9%) i/s - 15.712B in 5.039418s
Hash#fetch + block 3.111B (± 2.0%) i/s - 15.701B in 5.049395s
Hash#fetch + arg 3.034B (± 2.0%) i/s - 15.409B in 5.081505s
Comparison:
Hash#fetch + const: 3120599707.6 i/s
Hash#fetch + block: 3110729995.5 i/s - same-ish: difference falls within error
Hash#fetch + arg: 3033550737.0 i/s - same-ish: difference falls within error
$ ruby -v code/hash/hash-key-sort_by-vs-sort.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
sort_by + to_h 36.871k i/100ms
sort + to_h 3.349k i/100ms
Calculating -------------------------------------
sort_by + to_h 511.163k (± 7.5%) i/s - 2.544M in 5.008235s
sort + to_h 208.036k (±24.1%) i/s - 974.559k in 5.062117s
Comparison:
sort_by + to_h: 511162.7 i/s
sort + to_h: 208036.1 i/s - 2.46x (± 0.00) slower
$ ruby -v code/hash/keys-each-vs-each_key.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#keys.each 223.322k i/100ms
Hash#each_key 251.264k i/100ms
Calculating -------------------------------------
Hash#keys.each 2.313M (±10.9%) i/s - 11.389M in 5.033712s
Hash#each_key 2.510M (± 4.2%) i/s - 12.563M in 5.014297s
Comparison:
Hash#each_key: 2510244.6 i/s
Hash#keys.each: 2313216.3 i/s - same-ish: difference falls within error
$ ruby -v code/hash/keys-include-vs-key.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#keys.include? 290.000 i/100ms
Hash#key? 12.845M i/100ms
Calculating -------------------------------------
Hash#keys.include? 3.009k (±12.7%) i/s - 14.790k in 5.033898s
Hash#key? 123.548M (± 3.6%) i/s - 629.418M in 5.102646s
Comparison:
Hash#key?: 123547972.1 i/s
Hash#keys.include?: 3009.2 i/s - 41056.22x (± 0.00) slower
$ ruby -v code/hash/merge-bang-vs-[]=.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#merge! 52.433k i/100ms
Hash#[]= 56.800k i/100ms
Calculating -------------------------------------
Hash#merge! 583.076k (± 6.7%) i/s - 2.936M in 5.059380s
Hash#[]= 604.035k (± 7.5%) i/s - 3.010M in 5.025272s
Comparison:
Hash#[]=: 604035.4 i/s
Hash#merge!: 583076.1 i/s - same-ish: difference falls within error
$ ruby -v code/hash/merge-bang-vs-merge-vs-dup-merge-bang.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
{}#merge!(Hash) do end
34.146k i/100ms
Hash#merge({}) 20.303k i/100ms
Hash#dup#merge!({}) 31.603k i/100ms
Calculating -------------------------------------
{}#merge!(Hash) do end
392.050k (±11.6%) i/s - 1.946M in 5.048969s
Hash#merge({}) 199.043k (± 9.2%) i/s - 994.847k in 5.058089s
Hash#dup#merge!({}) 315.009k (± 9.5%) i/s - 1.580M in 5.081493s
Comparison:
{}#merge!(Hash) do end: 392049.9 i/s
Hash#dup#merge!({}): 315008.9 i/s - 1.24x (± 0.00) slower
Hash#merge({}): 199042.9 i/s - 1.97x (± 0.00) slower
$ ruby -v code/hash/merge-vs-double-splat-operator.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#**other 318.931M i/100ms
Hash#merge 318.892M i/100ms
Calculating -------------------------------------
Hash#**other 3.174B (± 1.7%) i/s - 15.947B in 5.026182s
Hash#merge 3.174B (± 2.8%) i/s - 15.945B in 5.028193s
Comparison:
Hash#**other: 3173686054.3 i/s
Hash#merge: 3173618929.4 i/s - same-ish: difference falls within error
$ ruby -v code/hash/merge-vs-merge-bang.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#merge 707.000 i/100ms
Hash#merge! 58.863k i/100ms
Calculating -------------------------------------
Hash#merge 12.172k (±12.7%) i/s - 60.095k in 5.044329s
Hash#merge! 582.872k (± 8.8%) i/s - 2.943M in 5.092045s
Comparison:
Hash#merge!: 582871.9 i/s
Hash#merge: 12172.1 i/s - 47.89x (± 0.00) slower
$ ruby -v code/hash/slice-native-vs-before-native.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#native-slice 1.284M i/100ms
Array#each 1.435M i/100ms
Array#each_w/_object 1.576M i/100ms
Hash#select-include 2.402M i/100ms
Calculating -------------------------------------
Hash#native-slice 19.561M (± 6.7%) i/s - 97.554M in 5.011279s
Array#each 15.580M (± 2.8%) i/s - 78.918M in 5.069198s
Array#each_w/_object 15.587M (± 4.7%) i/s - 78.780M in 5.065990s
Hash#select-include 24.735M (± 4.9%) i/s - 124.920M in 5.062602s
Comparison:
Hash#select-include : 24735149.1 i/s
Hash#native-slice : 19560570.3 i/s - 1.26x (± 0.00) slower
Array#each_w/_object: 15587295.7 i/s - 1.59x (± 0.00) slower
Array#each : 15580363.8 i/s - 1.59x (± 0.00) slower
$ ruby -v code/hash/values-include-vs-value.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Hash#values.include? 225.000 i/100ms
Hash#value? 692.000 i/100ms
Calculating -------------------------------------
Hash#values.include? 2.950k (±13.4%) i/s - 14.400k in 5.005772s
Hash#value? 6.922k (± 1.0%) i/s - 35.292k in 5.099244s
Comparison:
Hash#value?: 6921.7 i/s
Hash#values.include?: 2950.3 i/s - 2.35x (± 0.00) slower
$ ruby -v code/method/call-vs-send-vs-method_missing.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
call 313.767M i/100ms
send 320.529M i/100ms
method_missing 319.182M i/100ms
Calculating -------------------------------------
call 3.158B (± 2.3%) i/s - 16.002B in 5.069354s
send 3.181B (± 2.4%) i/s - 16.026B in 5.041009s
method_missing 3.172B (± 2.4%) i/s - 15.959B in 5.033618s
Comparison:
send: 3181231692.2 i/s
method_missing: 3172490479.3 i/s - same-ish: difference falls within error
call: 3158302836.0 i/s - same-ish: difference falls within error
$ ruby -v code/proc-and-block/block-vs-to_proc.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Block 62.311k i/100ms
Symbol#to_proc 67.886k i/100ms
Calculating -------------------------------------
Block 734.413k (±11.6%) i/s - 3.614M in 5.022020s
Symbol#to_proc 708.004k (±11.5%) i/s - 3.530M in 5.061658s
Comparison:
Block: 734413.0 i/s
Symbol#to_proc: 708004.0 i/s - same-ish: difference falls within error
$ ruby -v code/proc-and-block/proc-call-vs-yield.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
block.call 320.706M i/100ms
block + yield 319.048M i/100ms
unused block 311.042M i/100ms
yield 321.652M i/100ms
Calculating -------------------------------------
block.call 3.186B (± 2.2%) i/s - 16.035B in 5.035060s
block + yield 3.201B (± 1.2%) i/s - 16.271B in 5.084529s
unused block 3.198B (± 1.5%) i/s - 16.174B in 5.059201s
yield 3.192B (± 1.7%) i/s - 16.083B in 5.040260s
Comparison:
block + yield: 3200717925.8 i/s
unused block: 3197711460.9 i/s - same-ish: difference falls within error
yield: 3191794945.5 i/s - same-ish: difference falls within error
block.call: 3186352302.9 i/s - same-ish: difference falls within error
$ ruby -v code/range/cover-vs-include.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
range#cover? 4.457k i/100ms
range#include? 138.000 i/100ms
range#member? 233.000 i/100ms
plain compare 7.818k i/100ms
Calculating -------------------------------------
range#cover? 63.960k (±33.8%) i/s - 271.877k in 5.043618s
range#include? 2.369k (±39.4%) i/s - 9.936k in 5.025627s
range#member? 2.278k (±27.8%) i/s - 10.252k in 5.054656s
plain compare 85.442k (±26.8%) i/s - 383.082k in 5.037279s
Comparison:
plain compare: 85441.9 i/s
range#cover?: 63959.6 i/s - same-ish: difference falls within error
range#include?: 2368.7 i/s - 36.07x (± 0.00) slower
range#member?: 2277.6 i/s - 37.51x (± 0.00) slower
$ ruby -v code/string/===-vs-=~-vs-match.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#match? 34.396M i/100ms
String#=~ 32.122M i/100ms
Regexp#=== 31.940M i/100ms
String#match 31.357M i/100ms
Calculating -------------------------------------
String#match? 345.330M (± 1.1%) i/s - 1.754B in 5.080432s
String#=~ 319.779M (± 0.9%) i/s - 1.606B in 5.022876s
Regexp#=== 318.212M (± 1.7%) i/s - 1.597B in 5.020303s
String#match 312.687M (± 2.5%) i/s - 1.568B in 5.017582s
Comparison:
String#match?: 345329744.8 i/s
String#=~: 319778993.9 i/s - 1.08x (± 0.00) slower
Regexp#===: 318211610.6 i/s - 1.09x (± 0.00) slower
String#match: 312687371.1 i/s - 1.10x (± 0.00) slower
$ ruby -v code/string/casecmp-vs-downcase-==.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#downcase + == 2.669M i/100ms
String#casecmp 4.931M i/100ms
Calculating -------------------------------------
String#downcase + == 29.874M (± 8.5%) i/s - 149.455M in 5.051551s
String#casecmp 49.197M (± 7.7%) i/s - 246.555M in 5.057465s
Comparison:
String#casecmp: 49196837.1 i/s
String#downcase + ==: 29874162.5 i/s - 1.65x (± 0.00) slower
$ ruby -v code/string/concatenation.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#+ 10.554M i/100ms
String#concat 10.896M i/100ms
String#append 10.657M i/100ms
"foo" "bar" 319.451M i/100ms
"#{'foo'}#{'bar'}" 11.301M i/100ms
Calculating -------------------------------------
String#+ 83.730M (± 6.5%) i/s - 422.161M in 5.059062s
String#concat 109.932M (± 6.0%) i/s - 555.710M in 5.081013s
String#append 108.507M (± 6.8%) i/s - 543.525M in 5.040528s
"foo" "bar" 3.157B (± 2.5%) i/s - 15.973B in 5.062594s
"#{'foo'}#{'bar'}" 109.257M (± 6.6%) i/s - 553.762M in 5.098140s
Comparison:
"foo" "bar": 3157025878.2 i/s
String#concat: 109932262.5 i/s - 28.72x (± 0.00) slower
"#{'foo'}#{'bar'}": 109256819.2 i/s - 28.90x (± 0.00) slower
String#append: 108506550.9 i/s - 29.10x (± 0.00) slower
String#+: 83730230.8 i/s - 37.70x (± 0.00) slower
$ ruby -v code/string/dup-vs-unary-plus.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#+@ 317.811M i/100ms
String#dup 317.147M i/100ms
Calculating -------------------------------------
String#+@ 3.158B (± 2.9%) i/s - 15.891B in 5.036677s
String#dup 3.157B (± 3.1%) i/s - 15.857B in 5.028901s
Comparison:
String#+@: 3157865996.0 i/s
String#dup: 3156746956.7 i/s - same-ish: difference falls within error
$ ruby -v code/string/end-string-checking-match-vs-end_with.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#=~ 1.444M i/100ms
String#match? 1.783M i/100ms
String#end_with? 10.711M i/100ms
Calculating -------------------------------------
String#=~ 14.571M (± 3.0%) i/s - 73.639M in 5.058398s
String#match? 17.781M (± 1.5%) i/s - 89.171M in 5.016210s
String#end_with? 106.226M (± 2.1%) i/s - 535.548M in 5.043845s
Comparison:
String#end_with?: 106225908.0 i/s
String#match?: 17780800.8 i/s - 5.97x (± 0.00) slower
String#=~: 14571468.6 i/s - 7.29x (± 0.00) slower
$ ruby -v code/string/gsub-vs-sub.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#gsub 232.846k i/100ms
String#sub 943.098k i/100ms
String#dup["string"]=
10.242M i/100ms
Calculating -------------------------------------
String#gsub 8.073M (±12.0%) i/s - 39.584M in 5.019559s
String#sub 9.553M (±10.6%) i/s - 47.155M in 5.007950s
String#dup["string"]=
102.757M (± 2.5%) i/s - 522.336M in 5.086826s
Comparison:
String#dup["string"]=: 102756642.4 i/s
String#sub: 9552658.5 i/s - 10.76x (± 0.00) slower
String#gsub: 8073181.2 i/s - 12.73x (± 0.00) slower
$ ruby -v code/string/gsub-vs-tr.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#gsub 86.963k i/100ms
String#tr 179.954k i/100ms
Calculating -------------------------------------
String#gsub 4.608M (±12.5%) i/s - 22.523M in 5.003848s
String#tr 1.834M (± 2.7%) i/s - 9.178M in 5.008240s
Comparison:
String#gsub: 4608399.9 i/s
String#tr: 1833883.9 i/s - 2.51x (± 0.00) slower
$ ruby -v code/string/mutable_vs_immutable_strings.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Without Freeze 314.206M i/100ms
With Freeze 313.054M i/100ms
Calculating -------------------------------------
Without Freeze 3.153B (± 2.5%) i/s - 16.025B in 5.085097s
With Freeze 3.174B (± 1.7%) i/s - 15.966B in 5.031089s
Comparison:
With Freeze: 3174370019.2 i/s
Without Freeze: 3153368569.6 i/s - same-ish: difference falls within error
$ ruby -v code/string/remove-extra-spaces-or-other-chars.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#gsub/regex+/ 5.910k i/100ms
String#squeeze 82.013k i/100ms
Calculating -------------------------------------
String#gsub/regex+/ 174.206k (±12.6%) i/s - 851.040k in 5.018483s
String#squeeze 823.294k (± 4.7%) i/s - 4.183M in 5.092863s
Comparison:
String#squeeze: 823294.1 i/s
String#gsub/regex+/: 174206.5 i/s - 4.73x (± 0.00) slower
$ ruby -v code/string/start-string-checking-match-vs-start_with.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#=~ 14.396M i/100ms
String#match? 13.896M i/100ms
String#start_with? 16.004M i/100ms
Calculating -------------------------------------
String#=~ 145.585M (± 6.5%) i/s - 734.202M in 5.072424s
String#match? 138.986M (± 1.8%) i/s - 694.810M in 5.000928s
String#start_with? 158.955M (± 2.9%) i/s - 800.197M in 5.038662s
Comparison:
String#start_with?: 158954887.9 i/s
String#=~: 145585422.3 i/s - same-ish: difference falls within error
String#match?: 138986474.0 i/s - 1.14x (± 0.00) slower
$ ruby -v code/string/start_with-vs-substring-==.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#start_with? 189.120k i/100ms
String#[0, n] == 653.953k i/100ms
String#[RANGE] == 194.235k i/100ms
String#[0...n] == 650.093k i/100ms
Calculating -------------------------------------
String#start_with? 7.409M (± 2.5%) i/s - 37.068M in 5.007791s
String#[0, n] == 7.318M (± 3.3%) i/s - 36.621M in 5.010149s
String#[RANGE] == 13.765M (±12.0%) i/s - 67.205M in 5.006773s
String#[0...n] == 6.485M (± 5.6%) i/s - 32.505M in 5.028995s
Comparison:
String#[RANGE] ==: 13764546.4 i/s
String#start_with?: 7408690.8 i/s - 1.86x (± 0.00) slower
String#[0, n] ==: 7317740.6 i/s - 1.88x (± 0.00) slower
String#[0...n] ==: 6484525.0 i/s - 2.12x (± 0.00) slower
$ ruby -v code/string/sub!-vs-gsub!-vs-[]=.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#['string']= 10.133M i/100ms
String#sub!'string' 470.468k i/100ms
String#gsub!'string' 638.677k i/100ms
String#[/regexp/]= 9.540M i/100ms
String#sub!/regexp/ 1.142M i/100ms
String#gsub!/regexp/ 703.101k i/100ms
Calculating -------------------------------------
String#['string']= 102.708M (± 2.3%) i/s - 516.775M in 5.034687s
String#sub!'string' 10.914M (±12.9%) i/s - 53.633M in 5.031124s
String#gsub!'string' 6.346M (± 7.6%) i/s - 31.934M in 5.072021s
String#[/regexp/]= 99.761M (± 2.3%) i/s - 505.646M in 5.071724s
String#sub!/regexp/ 32.246M (± 5.0%) i/s - 160.985M in 5.007474s
String#gsub!/regexp/ 8.965M (±10.0%) i/s - 44.295M in 5.001873s
Comparison:
String#['string']=: 102707796.7 i/s
String#[/regexp/]=: 99760993.8 i/s - same-ish: difference falls within error
String#sub!/regexp/: 32246008.8 i/s - 3.19x (± 0.00) slower
String#sub!'string': 10913512.6 i/s - 9.41x (± 0.00) slower
String#gsub!/regexp/: 8965142.2 i/s - 11.46x (± 0.00) slower
String#gsub!'string': 6345766.6 i/s - 16.19x (± 0.00) slower
$ ruby -v code/string/sub-vs-chomp-vs-delete_suffix.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#sub 200.095k i/100ms
String#chomp 6.509M i/100ms
String#delete_suffix 11.263M i/100ms
Calculating -------------------------------------
String#sub 76.300M (±12.5%) i/s - 366.574M in 4.998909s
String#chomp 65.060M (± 0.6%) i/s - 325.467M in 5.002812s
String#delete_suffix 116.513M (± 8.3%) i/s - 585.691M in 5.075067s
Comparison:
String#delete_suffix: 116513147.0 i/s
String#sub: 76299923.4 i/s - 1.53x (± 0.00) slower
String#chomp: 65059502.1 i/s - 1.79x (± 0.00) slower
$ ruby -v code/string/sub-vs-delete_prefix.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#delete_prefix 290.986M i/100ms
String#sub 1.456M i/100ms
Calculating -------------------------------------
String#delete_prefix 3.154B (± 2.7%) i/s - 16.004B in 5.078514s
String#sub 340.723M (± 3.2%) i/s - 1.702B in 5.002405s
Comparison:
String#delete_prefix: 3153746280.9 i/s
String#sub: 340722711.6 i/s - 9.26x (± 0.00) slower
$ ruby -v code/string/unpack1-vs-unpack[0].rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
String#unpack1 1.861M i/100ms
String#unpack[0] 1.889M i/100ms
Calculating -------------------------------------
String#unpack1 19.999M (± 6.5%) i/s - 100.477M in 5.055421s
String#unpack[0] 20.264M (± 4.8%) i/s - 101.986M in 5.044738s
Comparison:
String#unpack[0]: 20263880.6 i/s
String#unpack1: 19999235.1 i/s - same-ish: difference falls within error
$ ruby -v code/time/iso8601-vs-parse.rb
truffleruby 25.0.0-dev-2790c4ed, like ruby 3.3.5, GraalVM CE Native [x86_64-linux]
Warming up --------------------------------------
Time.iso8601 24.252k i/100ms
Time.parse 260.000 i/100ms
Calculating -------------------------------------
Time.iso8601 876.878k (±13.7%) i/s - 4.244M in 5.016818s
Time.parse 6.178k (±12.0%) i/s - 30.160k in 4.999016s
Comparison:
Time.iso8601: 876878.5 i/s
Time.parse: 6177.8 i/s - 141.94x (± 0.00) slower