data-structure-typed 2.4.0 → 2.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (750) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +2 -3
  3. package/README_CN.md +0 -1
  4. package/dist/cjs/index.cjs +85 -30
  5. package/dist/cjs-legacy/index.cjs +85 -30
  6. package/dist/esm/index.mjs +85 -30
  7. package/dist/esm-legacy/index.mjs +85 -30
  8. package/dist/types/data-structures/binary-tree/tree-map.d.ts +17 -6
  9. package/dist/types/data-structures/binary-tree/tree-multi-map.d.ts +13 -5
  10. package/dist/types/data-structures/binary-tree/tree-multi-set.d.ts +12 -5
  11. package/dist/types/data-structures/binary-tree/tree-set.d.ts +15 -4
  12. package/dist/types/types/data-structures/binary-tree/tree-map.d.ts +6 -1
  13. package/dist/types/types/data-structures/binary-tree/tree-multi-set.d.ts +6 -1
  14. package/dist/types/types/data-structures/binary-tree/tree-set.d.ts +6 -1
  15. package/dist/umd/data-structure-typed.js +85 -29
  16. package/dist/umd/data-structure-typed.min.js +4 -4
  17. package/package.json +11 -5
  18. package/src/data-structures/binary-tree/tree-map.ts +35 -13
  19. package/src/data-structures/binary-tree/tree-multi-map.ts +41 -20
  20. package/src/data-structures/binary-tree/tree-multi-set.ts +17 -6
  21. package/src/data-structures/binary-tree/tree-set.ts +19 -6
  22. package/src/data-structures/trie/trie.ts +6 -8
  23. package/src/types/data-structures/binary-tree/tree-map.ts +7 -1
  24. package/src/types/data-structures/binary-tree/tree-multi-set.ts +7 -1
  25. package/src/types/data-structures/binary-tree/tree-set.ts +7 -1
  26. package/CMakeLists.txt +0 -52
  27. package/benchmark/report.html +0 -143
  28. package/benchmark/report.json +0 -1972
  29. package/build/CMakeCache.txt +0 -603
  30. package/build/CMakeFiles/4.0.3/CMakeCXXCompiler.cmake +0 -104
  31. package/build/CMakeFiles/4.0.3/CMakeDetermineCompilerABI_CXX.bin +0 -0
  32. package/build/CMakeFiles/4.0.3/CMakeSystem.cmake +0 -15
  33. package/build/CMakeFiles/4.0.3/CompilerIdCXX/CMakeCXXCompilerId.cpp +0 -920
  34. package/build/CMakeFiles/4.0.3/CompilerIdCXX/a.out +0 -0
  35. package/build/CMakeFiles/4.0.3/CompilerIdCXX/apple-sdk.cpp +0 -1
  36. package/build/CMakeFiles/CMakeConfigureLog.yaml +0 -2146
  37. package/build/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  38. package/build/CMakeFiles/InstallScripts.json +0 -9
  39. package/build/CMakeFiles/Makefile.cmake +0 -100
  40. package/build/CMakeFiles/Makefile2 +0 -720
  41. package/build/CMakeFiles/TargetDirectories.txt +0 -23
  42. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/DependInfo.cmake +0 -23
  43. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/build.make +0 -114
  44. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/cmake_clean.cmake +0 -11
  45. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.internal +0 -839
  46. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.make +0 -2506
  47. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.ts +0 -2
  48. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/depend.make +0 -2
  49. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/flags.make +0 -10
  50. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/link.txt +0 -1
  51. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/progress.make +0 -3
  52. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp.o +0 -0
  53. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp.o.d +0 -835
  54. package/build/CMakeFiles/avl-tree-benchmark.dir/DependInfo.cmake +0 -23
  55. package/build/CMakeFiles/avl-tree-benchmark.dir/build.make +0 -114
  56. package/build/CMakeFiles/avl-tree-benchmark.dir/cmake_clean.cmake +0 -11
  57. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.internal +0 -839
  58. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.make +0 -2506
  59. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.ts +0 -2
  60. package/build/CMakeFiles/avl-tree-benchmark.dir/depend.make +0 -2
  61. package/build/CMakeFiles/avl-tree-benchmark.dir/flags.make +0 -10
  62. package/build/CMakeFiles/avl-tree-benchmark.dir/link.txt +0 -1
  63. package/build/CMakeFiles/avl-tree-benchmark.dir/progress.make +0 -3
  64. package/build/CMakeFiles/avl-tree-benchmark.dir/test/performance/data-structures/binary-tree/avl-tree.test.cpp.o +0 -0
  65. package/build/CMakeFiles/avl-tree-benchmark.dir/test/performance/data-structures/binary-tree/avl-tree.test.cpp.o.d +0 -835
  66. package/build/CMakeFiles/cmake.check_cache +0 -1
  67. package/build/CMakeFiles/deque-benchmark.dir/DependInfo.cmake +0 -23
  68. package/build/CMakeFiles/deque-benchmark.dir/build.make +0 -114
  69. package/build/CMakeFiles/deque-benchmark.dir/cmake_clean.cmake +0 -11
  70. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.internal +0 -791
  71. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.make +0 -2362
  72. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.ts +0 -2
  73. package/build/CMakeFiles/deque-benchmark.dir/depend.make +0 -2
  74. package/build/CMakeFiles/deque-benchmark.dir/flags.make +0 -10
  75. package/build/CMakeFiles/deque-benchmark.dir/link.txt +0 -1
  76. package/build/CMakeFiles/deque-benchmark.dir/progress.make +0 -3
  77. package/build/CMakeFiles/deque-benchmark.dir/test/performance/data-structures/queue/deque.test.cpp.o +0 -0
  78. package/build/CMakeFiles/deque-benchmark.dir/test/performance/data-structures/queue/deque.test.cpp.o.d +0 -787
  79. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/DependInfo.cmake +0 -23
  80. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/build.make +0 -114
  81. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/cmake_clean.cmake +0 -11
  82. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.internal +0 -790
  83. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.make +0 -2359
  84. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.ts +0 -2
  85. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/depend.make +0 -2
  86. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/flags.make +0 -10
  87. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/link.txt +0 -1
  88. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/progress.make +0 -3
  89. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp.o +0 -0
  90. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp.o.d +0 -786
  91. package/build/CMakeFiles/hash-map-benchmark.dir/DependInfo.cmake +0 -23
  92. package/build/CMakeFiles/hash-map-benchmark.dir/build.make +0 -114
  93. package/build/CMakeFiles/hash-map-benchmark.dir/cmake_clean.cmake +0 -11
  94. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.internal +0 -790
  95. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.make +0 -2359
  96. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.ts +0 -2
  97. package/build/CMakeFiles/hash-map-benchmark.dir/depend.make +0 -2
  98. package/build/CMakeFiles/hash-map-benchmark.dir/flags.make +0 -10
  99. package/build/CMakeFiles/hash-map-benchmark.dir/link.txt +0 -1
  100. package/build/CMakeFiles/hash-map-benchmark.dir/progress.make +0 -3
  101. package/build/CMakeFiles/hash-map-benchmark.dir/test/performance/data-structures/hash/hash-map.test.cpp.o +0 -0
  102. package/build/CMakeFiles/hash-map-benchmark.dir/test/performance/data-structures/hash/hash-map.test.cpp.o.d +0 -786
  103. package/build/CMakeFiles/heap-benchmark.dir/DependInfo.cmake +0 -23
  104. package/build/CMakeFiles/heap-benchmark.dir/build.make +0 -114
  105. package/build/CMakeFiles/heap-benchmark.dir/cmake_clean.cmake +0 -11
  106. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.internal +0 -843
  107. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.make +0 -2518
  108. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.ts +0 -2
  109. package/build/CMakeFiles/heap-benchmark.dir/depend.make +0 -2
  110. package/build/CMakeFiles/heap-benchmark.dir/flags.make +0 -10
  111. package/build/CMakeFiles/heap-benchmark.dir/link.txt +0 -1
  112. package/build/CMakeFiles/heap-benchmark.dir/progress.make +0 -3
  113. package/build/CMakeFiles/heap-benchmark.dir/test/performance/data-structures/heap/heap.test.cpp.o +0 -0
  114. package/build/CMakeFiles/heap-benchmark.dir/test/performance/data-structures/heap/heap.test.cpp.o.d +0 -839
  115. package/build/CMakeFiles/priority-queue-benchmark.dir/DependInfo.cmake +0 -23
  116. package/build/CMakeFiles/priority-queue-benchmark.dir/build.make +0 -114
  117. package/build/CMakeFiles/priority-queue-benchmark.dir/cmake_clean.cmake +0 -11
  118. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.internal +0 -793
  119. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.make +0 -2368
  120. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.ts +0 -2
  121. package/build/CMakeFiles/priority-queue-benchmark.dir/depend.make +0 -2
  122. package/build/CMakeFiles/priority-queue-benchmark.dir/flags.make +0 -10
  123. package/build/CMakeFiles/priority-queue-benchmark.dir/link.txt +0 -1
  124. package/build/CMakeFiles/priority-queue-benchmark.dir/progress.make +0 -3
  125. package/build/CMakeFiles/priority-queue-benchmark.dir/test/performance/data-structures/priority-queue/priority-queue.test.cpp.o +0 -0
  126. package/build/CMakeFiles/priority-queue-benchmark.dir/test/performance/data-structures/priority-queue/priority-queue.test.cpp.o.d +0 -789
  127. package/build/CMakeFiles/progress.marks +0 -1
  128. package/build/CMakeFiles/queue-benchmark.dir/DependInfo.cmake +0 -23
  129. package/build/CMakeFiles/queue-benchmark.dir/build.make +0 -114
  130. package/build/CMakeFiles/queue-benchmark.dir/cmake_clean.cmake +0 -11
  131. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.internal +0 -793
  132. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.make +0 -2368
  133. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.ts +0 -2
  134. package/build/CMakeFiles/queue-benchmark.dir/depend.make +0 -2
  135. package/build/CMakeFiles/queue-benchmark.dir/flags.make +0 -10
  136. package/build/CMakeFiles/queue-benchmark.dir/link.txt +0 -1
  137. package/build/CMakeFiles/queue-benchmark.dir/progress.make +0 -3
  138. package/build/CMakeFiles/queue-benchmark.dir/test/performance/data-structures/queue/queue.test.cpp.o +0 -0
  139. package/build/CMakeFiles/queue-benchmark.dir/test/performance/data-structures/queue/queue.test.cpp.o.d +0 -789
  140. package/build/CMakeFiles/red-black-tree-benchmark.dir/DependInfo.cmake +0 -23
  141. package/build/CMakeFiles/red-black-tree-benchmark.dir/build.make +0 -114
  142. package/build/CMakeFiles/red-black-tree-benchmark.dir/cmake_clean.cmake +0 -11
  143. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.internal +0 -839
  144. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.make +0 -2506
  145. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.ts +0 -2
  146. package/build/CMakeFiles/red-black-tree-benchmark.dir/depend.make +0 -2
  147. package/build/CMakeFiles/red-black-tree-benchmark.dir/flags.make +0 -10
  148. package/build/CMakeFiles/red-black-tree-benchmark.dir/link.txt +0 -1
  149. package/build/CMakeFiles/red-black-tree-benchmark.dir/progress.make +0 -3
  150. package/build/CMakeFiles/red-black-tree-benchmark.dir/test/performance/data-structures/binary-tree/red-black-tree.test.cpp.o +0 -0
  151. package/build/CMakeFiles/red-black-tree-benchmark.dir/test/performance/data-structures/binary-tree/red-black-tree.test.cpp.o.d +0 -835
  152. package/build/CMakeFiles/singly-linked-list-benchmark.dir/DependInfo.cmake +0 -23
  153. package/build/CMakeFiles/singly-linked-list-benchmark.dir/build.make +0 -114
  154. package/build/CMakeFiles/singly-linked-list-benchmark.dir/cmake_clean.cmake +0 -11
  155. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.internal +0 -790
  156. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.make +0 -2359
  157. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.ts +0 -2
  158. package/build/CMakeFiles/singly-linked-list-benchmark.dir/depend.make +0 -2
  159. package/build/CMakeFiles/singly-linked-list-benchmark.dir/flags.make +0 -10
  160. package/build/CMakeFiles/singly-linked-list-benchmark.dir/link.txt +0 -1
  161. package/build/CMakeFiles/singly-linked-list-benchmark.dir/progress.make +0 -3
  162. package/build/CMakeFiles/singly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/singly-linked-list.test.cpp.o +0 -0
  163. package/build/CMakeFiles/singly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/singly-linked-list.test.cpp.o.d +0 -786
  164. package/build/CMakeFiles/stack-benchmark.dir/DependInfo.cmake +0 -23
  165. package/build/CMakeFiles/stack-benchmark.dir/build.make +0 -114
  166. package/build/CMakeFiles/stack-benchmark.dir/cmake_clean.cmake +0 -11
  167. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.internal +0 -793
  168. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.make +0 -2368
  169. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.ts +0 -2
  170. package/build/CMakeFiles/stack-benchmark.dir/depend.make +0 -2
  171. package/build/CMakeFiles/stack-benchmark.dir/flags.make +0 -10
  172. package/build/CMakeFiles/stack-benchmark.dir/link.txt +0 -1
  173. package/build/CMakeFiles/stack-benchmark.dir/progress.make +0 -3
  174. package/build/CMakeFiles/stack-benchmark.dir/test/performance/data-structures/stack/stack.test.cpp.o +0 -0
  175. package/build/CMakeFiles/stack-benchmark.dir/test/performance/data-structures/stack/stack.test.cpp.o.d +0 -789
  176. package/build/CMakeFiles/tree-map-benchmark.dir/DependInfo.cmake +0 -23
  177. package/build/CMakeFiles/tree-map-benchmark.dir/build.make +0 -114
  178. package/build/CMakeFiles/tree-map-benchmark.dir/cmake_clean.cmake +0 -11
  179. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.internal +0 -839
  180. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.make +0 -2506
  181. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.ts +0 -2
  182. package/build/CMakeFiles/tree-map-benchmark.dir/depend.make +0 -2
  183. package/build/CMakeFiles/tree-map-benchmark.dir/flags.make +0 -10
  184. package/build/CMakeFiles/tree-map-benchmark.dir/link.txt +0 -1
  185. package/build/CMakeFiles/tree-map-benchmark.dir/progress.make +0 -3
  186. package/build/CMakeFiles/tree-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-map.test.cpp.o +0 -0
  187. package/build/CMakeFiles/tree-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-map.test.cpp.o.d +0 -835
  188. package/build/CMakeFiles/tree-multi-map-benchmark.dir/DependInfo.cmake +0 -23
  189. package/build/CMakeFiles/tree-multi-map-benchmark.dir/build.make +0 -114
  190. package/build/CMakeFiles/tree-multi-map-benchmark.dir/cmake_clean.cmake +0 -11
  191. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.internal +0 -839
  192. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.make +0 -2506
  193. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.ts +0 -2
  194. package/build/CMakeFiles/tree-multi-map-benchmark.dir/depend.make +0 -2
  195. package/build/CMakeFiles/tree-multi-map-benchmark.dir/flags.make +0 -10
  196. package/build/CMakeFiles/tree-multi-map-benchmark.dir/link.txt +0 -1
  197. package/build/CMakeFiles/tree-multi-map-benchmark.dir/progress.make +0 -3
  198. package/build/CMakeFiles/tree-multi-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp.o +0 -0
  199. package/build/CMakeFiles/tree-multi-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp.o.d +0 -835
  200. package/build/CMakeFiles/tree-multi-set-benchmark.dir/DependInfo.cmake +0 -23
  201. package/build/CMakeFiles/tree-multi-set-benchmark.dir/build.make +0 -114
  202. package/build/CMakeFiles/tree-multi-set-benchmark.dir/cmake_clean.cmake +0 -11
  203. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.internal +0 -839
  204. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.make +0 -2506
  205. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.ts +0 -2
  206. package/build/CMakeFiles/tree-multi-set-benchmark.dir/depend.make +0 -2
  207. package/build/CMakeFiles/tree-multi-set-benchmark.dir/flags.make +0 -10
  208. package/build/CMakeFiles/tree-multi-set-benchmark.dir/link.txt +0 -1
  209. package/build/CMakeFiles/tree-multi-set-benchmark.dir/progress.make +0 -3
  210. package/build/CMakeFiles/tree-multi-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp.o +0 -0
  211. package/build/CMakeFiles/tree-multi-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp.o.d +0 -835
  212. package/build/CMakeFiles/tree-set-benchmark.dir/DependInfo.cmake +0 -23
  213. package/build/CMakeFiles/tree-set-benchmark.dir/build.make +0 -114
  214. package/build/CMakeFiles/tree-set-benchmark.dir/cmake_clean.cmake +0 -11
  215. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.internal +0 -839
  216. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.make +0 -2506
  217. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.ts +0 -2
  218. package/build/CMakeFiles/tree-set-benchmark.dir/depend.make +0 -2
  219. package/build/CMakeFiles/tree-set-benchmark.dir/flags.make +0 -10
  220. package/build/CMakeFiles/tree-set-benchmark.dir/link.txt +0 -1
  221. package/build/CMakeFiles/tree-set-benchmark.dir/progress.make +0 -3
  222. package/build/CMakeFiles/tree-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-set.test.cpp.o +0 -0
  223. package/build/CMakeFiles/tree-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-set.test.cpp.o.d +0 -835
  224. package/build/Makefile +0 -783
  225. package/build/_deps/benchmark-build/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  226. package/build/_deps/benchmark-build/CMakeFiles/progress.marks +0 -1
  227. package/build/_deps/benchmark-build/Makefile +0 -140
  228. package/build/_deps/benchmark-build/benchmark.pc +0 -12
  229. package/build/_deps/benchmark-build/benchmarkConfig.cmake +0 -14
  230. package/build/_deps/benchmark-build/benchmarkConfigVersion.cmake +0 -65
  231. package/build/_deps/benchmark-build/benchmarkTargets.cmake +0 -84
  232. package/build/_deps/benchmark-build/cmake_install.cmake +0 -50
  233. package/build/_deps/benchmark-build/src/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  234. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/DependInfo.cmake +0 -41
  235. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark.cc.o +0 -0
  236. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark.cc.o.d +0 -875
  237. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_api_internal.cc.o +0 -0
  238. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_api_internal.cc.o.d +0 -802
  239. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_name.cc.o +0 -0
  240. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_name.cc.o.d +0 -772
  241. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_register.cc.o +0 -0
  242. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_register.cc.o.d +0 -841
  243. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_runner.cc.o +0 -0
  244. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_runner.cc.o.d +0 -833
  245. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/build.make +0 -402
  246. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/check.cc.o +0 -0
  247. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/check.cc.o.d +0 -784
  248. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/cmake_clean.cmake +0 -47
  249. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/cmake_clean_target.cmake +0 -3
  250. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/colorprint.cc.o +0 -0
  251. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/colorprint.cc.o.d +0 -791
  252. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/commandlineflags.cc.o +0 -0
  253. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/commandlineflags.cc.o.d +0 -795
  254. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.internal +0 -15519
  255. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.make +0 -17500
  256. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.ts +0 -2
  257. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/complexity.cc.o +0 -0
  258. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/complexity.cc.o.d +0 -793
  259. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/console_reporter.cc.o +0 -0
  260. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/console_reporter.cc.o.d +0 -802
  261. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/counter.cc.o +0 -0
  262. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/counter.cc.o.d +0 -773
  263. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/csv_reporter.cc.o +0 -0
  264. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/csv_reporter.cc.o.d +0 -799
  265. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/depend.make +0 -2
  266. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/flags.make +0 -10
  267. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/json_reporter.cc.o +0 -0
  268. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/json_reporter.cc.o.d +0 -800
  269. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/link.txt +0 -2
  270. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/perf_counters.cc.o +0 -0
  271. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/perf_counters.cc.o.d +0 -807
  272. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/progress.make +0 -21
  273. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/reporter.cc.o +0 -0
  274. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/reporter.cc.o.d +0 -798
  275. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/statistics.cc.o +0 -0
  276. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/statistics.cc.o.d +0 -800
  277. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/string_util.cc.o +0 -0
  278. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/string_util.cc.o.d +0 -795
  279. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/sysinfo.cc.o +0 -0
  280. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/sysinfo.cc.o.d +0 -933
  281. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/timers.cc.o +0 -0
  282. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/timers.cc.o.d +0 -904
  283. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/DependInfo.cmake +0 -23
  284. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/benchmark_main.cc.o +0 -0
  285. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/benchmark_main.cc.o.d +0 -772
  286. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/build.make +0 -114
  287. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/cmake_clean.cmake +0 -11
  288. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/cmake_clean_target.cmake +0 -3
  289. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.internal +0 -776
  290. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.make +0 -2317
  291. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.ts +0 -2
  292. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/depend.make +0 -2
  293. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/flags.make +0 -10
  294. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/link.txt +0 -2
  295. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/progress.make +0 -3
  296. package/build/_deps/benchmark-build/src/CMakeFiles/progress.marks +0 -1
  297. package/build/_deps/benchmark-build/src/Makefile +0 -710
  298. package/build/_deps/benchmark-build/src/cmake_install.cmake +0 -45
  299. package/build/_deps/benchmark-build/src/libbenchmark.a +0 -0
  300. package/build/_deps/benchmark-build/src/libbenchmark_main.a +0 -0
  301. package/build/_deps/benchmark-src/.clang-format +0 -5
  302. package/build/_deps/benchmark-src/.clang-tidy +0 -7
  303. package/build/_deps/benchmark-src/.github/ISSUE_TEMPLATE/bug_report.md +0 -32
  304. package/build/_deps/benchmark-src/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  305. package/build/_deps/benchmark-src/.github/install_bazel.sh +0 -13
  306. package/build/_deps/benchmark-src/.github/libcxx-setup.sh +0 -26
  307. package/build/_deps/benchmark-src/.github/workflows/bazel.yml +0 -35
  308. package/build/_deps/benchmark-src/.github/workflows/build-and-test-min-cmake.yml +0 -46
  309. package/build/_deps/benchmark-src/.github/workflows/build-and-test-perfcounters.yml +0 -51
  310. package/build/_deps/benchmark-src/.github/workflows/build-and-test.yml +0 -114
  311. package/build/_deps/benchmark-src/.github/workflows/clang-format-lint.yml +0 -17
  312. package/build/_deps/benchmark-src/.github/workflows/clang-tidy.yml +0 -38
  313. package/build/_deps/benchmark-src/.github/workflows/doxygen.yml +0 -28
  314. package/build/_deps/benchmark-src/.github/workflows/pylint.yml +0 -28
  315. package/build/_deps/benchmark-src/.github/workflows/sanitizer.yml +0 -96
  316. package/build/_deps/benchmark-src/.github/workflows/test_bindings.yml +0 -29
  317. package/build/_deps/benchmark-src/.github/workflows/wheels.yml +0 -79
  318. package/build/_deps/benchmark-src/.travis.yml +0 -208
  319. package/build/_deps/benchmark-src/.ycm_extra_conf.py +0 -115
  320. package/build/_deps/benchmark-src/AUTHORS +0 -71
  321. package/build/_deps/benchmark-src/BUILD.bazel +0 -87
  322. package/build/_deps/benchmark-src/CMakeLists.txt +0 -340
  323. package/build/_deps/benchmark-src/CONTRIBUTING.md +0 -58
  324. package/build/_deps/benchmark-src/CONTRIBUTORS +0 -95
  325. package/build/_deps/benchmark-src/LICENSE +0 -202
  326. package/build/_deps/benchmark-src/MODULE.bazel +0 -24
  327. package/build/_deps/benchmark-src/README.md +0 -223
  328. package/build/_deps/benchmark-src/WORKSPACE +0 -22
  329. package/build/_deps/benchmark-src/WORKSPACE.bzlmod +0 -2
  330. package/build/_deps/benchmark-src/_config.yml +0 -2
  331. package/build/_deps/benchmark-src/appveyor.yml +0 -50
  332. package/build/_deps/benchmark-src/bazel/benchmark_deps.bzl +0 -65
  333. package/build/_deps/benchmark-src/bindings/python/BUILD +0 -3
  334. package/build/_deps/benchmark-src/bindings/python/build_defs.bzl +0 -25
  335. package/build/_deps/benchmark-src/bindings/python/google_benchmark/BUILD +0 -40
  336. package/build/_deps/benchmark-src/bindings/python/google_benchmark/__init__.py +0 -162
  337. package/build/_deps/benchmark-src/bindings/python/google_benchmark/benchmark.cc +0 -184
  338. package/build/_deps/benchmark-src/bindings/python/google_benchmark/example.py +0 -136
  339. package/build/_deps/benchmark-src/bindings/python/nanobind.BUILD +0 -17
  340. package/build/_deps/benchmark-src/bindings/python/python_headers.BUILD +0 -6
  341. package/build/_deps/benchmark-src/cmake/AddCXXCompilerFlag.cmake +0 -78
  342. package/build/_deps/benchmark-src/cmake/CXXFeatureCheck.cmake +0 -82
  343. package/build/_deps/benchmark-src/cmake/Config.cmake.in +0 -7
  344. package/build/_deps/benchmark-src/cmake/GetGitVersion.cmake +0 -58
  345. package/build/_deps/benchmark-src/cmake/GoogleTest.cmake +0 -58
  346. package/build/_deps/benchmark-src/cmake/GoogleTest.cmake.in +0 -59
  347. package/build/_deps/benchmark-src/cmake/benchmark.pc.in +0 -12
  348. package/build/_deps/benchmark-src/cmake/gnu_posix_regex.cpp +0 -12
  349. package/build/_deps/benchmark-src/cmake/llvm-toolchain.cmake +0 -8
  350. package/build/_deps/benchmark-src/cmake/posix_regex.cpp +0 -14
  351. package/build/_deps/benchmark-src/cmake/pthread_affinity.cpp +0 -16
  352. package/build/_deps/benchmark-src/cmake/split_list.cmake +0 -3
  353. package/build/_deps/benchmark-src/cmake/std_regex.cpp +0 -10
  354. package/build/_deps/benchmark-src/cmake/steady_clock.cpp +0 -7
  355. package/build/_deps/benchmark-src/cmake/thread_safety_attributes.cpp +0 -4
  356. package/build/_deps/benchmark-src/docs/AssemblyTests.md +0 -149
  357. package/build/_deps/benchmark-src/docs/_config.yml +0 -3
  358. package/build/_deps/benchmark-src/docs/assets/images/icon.png +0 -0
  359. package/build/_deps/benchmark-src/docs/assets/images/icon.xcf +0 -0
  360. package/build/_deps/benchmark-src/docs/assets/images/icon_black.png +0 -0
  361. package/build/_deps/benchmark-src/docs/assets/images/icon_black.xcf +0 -0
  362. package/build/_deps/benchmark-src/docs/dependencies.md +0 -13
  363. package/build/_deps/benchmark-src/docs/index.md +0 -12
  364. package/build/_deps/benchmark-src/docs/perf_counters.md +0 -35
  365. package/build/_deps/benchmark-src/docs/platform_specific_build_instructions.md +0 -48
  366. package/build/_deps/benchmark-src/docs/python_bindings.md +0 -34
  367. package/build/_deps/benchmark-src/docs/random_interleaving.md +0 -13
  368. package/build/_deps/benchmark-src/docs/reducing_variance.md +0 -100
  369. package/build/_deps/benchmark-src/docs/releasing.md +0 -41
  370. package/build/_deps/benchmark-src/docs/tools.md +0 -343
  371. package/build/_deps/benchmark-src/docs/user_guide.md +0 -1266
  372. package/build/_deps/benchmark-src/include/benchmark/benchmark.h +0 -1991
  373. package/build/_deps/benchmark-src/include/benchmark/export.h +0 -47
  374. package/build/_deps/benchmark-src/pyproject.toml +0 -50
  375. package/build/_deps/benchmark-src/setup.py +0 -113
  376. package/build/_deps/benchmark-src/src/CMakeLists.txt +0 -170
  377. package/build/_deps/benchmark-src/src/arraysize.h +0 -33
  378. package/build/_deps/benchmark-src/src/benchmark.cc +0 -779
  379. package/build/_deps/benchmark-src/src/benchmark_api_internal.cc +0 -118
  380. package/build/_deps/benchmark-src/src/benchmark_api_internal.h +0 -87
  381. package/build/_deps/benchmark-src/src/benchmark_main.cc +0 -18
  382. package/build/_deps/benchmark-src/src/benchmark_name.cc +0 -59
  383. package/build/_deps/benchmark-src/src/benchmark_register.cc +0 -520
  384. package/build/_deps/benchmark-src/src/benchmark_register.h +0 -109
  385. package/build/_deps/benchmark-src/src/benchmark_runner.cc +0 -497
  386. package/build/_deps/benchmark-src/src/benchmark_runner.h +0 -131
  387. package/build/_deps/benchmark-src/src/check.cc +0 -11
  388. package/build/_deps/benchmark-src/src/check.h +0 -106
  389. package/build/_deps/benchmark-src/src/colorprint.cc +0 -200
  390. package/build/_deps/benchmark-src/src/colorprint.h +0 -33
  391. package/build/_deps/benchmark-src/src/commandlineflags.cc +0 -298
  392. package/build/_deps/benchmark-src/src/commandlineflags.h +0 -133
  393. package/build/_deps/benchmark-src/src/complexity.cc +0 -244
  394. package/build/_deps/benchmark-src/src/complexity.h +0 -55
  395. package/build/_deps/benchmark-src/src/console_reporter.cc +0 -206
  396. package/build/_deps/benchmark-src/src/counter.cc +0 -80
  397. package/build/_deps/benchmark-src/src/counter.h +0 -32
  398. package/build/_deps/benchmark-src/src/csv_reporter.cc +0 -161
  399. package/build/_deps/benchmark-src/src/cycleclock.h +0 -230
  400. package/build/_deps/benchmark-src/src/internal_macros.h +0 -115
  401. package/build/_deps/benchmark-src/src/json_reporter.cc +0 -320
  402. package/build/_deps/benchmark-src/src/log.h +0 -88
  403. package/build/_deps/benchmark-src/src/mutex.h +0 -155
  404. package/build/_deps/benchmark-src/src/perf_counters.cc +0 -282
  405. package/build/_deps/benchmark-src/src/perf_counters.h +0 -200
  406. package/build/_deps/benchmark-src/src/re.h +0 -158
  407. package/build/_deps/benchmark-src/src/reporter.cc +0 -118
  408. package/build/_deps/benchmark-src/src/statistics.cc +0 -209
  409. package/build/_deps/benchmark-src/src/statistics.h +0 -44
  410. package/build/_deps/benchmark-src/src/string_util.cc +0 -254
  411. package/build/_deps/benchmark-src/src/string_util.h +0 -70
  412. package/build/_deps/benchmark-src/src/sysinfo.cc +0 -855
  413. package/build/_deps/benchmark-src/src/thread_manager.h +0 -63
  414. package/build/_deps/benchmark-src/src/thread_timer.h +0 -86
  415. package/build/_deps/benchmark-src/src/timers.cc +0 -272
  416. package/build/_deps/benchmark-src/src/timers.h +0 -48
  417. package/build/_deps/benchmark-src/test/AssemblyTests.cmake +0 -67
  418. package/build/_deps/benchmark-src/test/BUILD +0 -127
  419. package/build/_deps/benchmark-src/test/CMakeLists.txt +0 -309
  420. package/build/_deps/benchmark-src/test/args_product_test.cc +0 -77
  421. package/build/_deps/benchmark-src/test/basic_test.cc +0 -180
  422. package/build/_deps/benchmark-src/test/benchmark_gtest.cc +0 -169
  423. package/build/_deps/benchmark-src/test/benchmark_min_time_flag_iters_test.cc +0 -66
  424. package/build/_deps/benchmark-src/test/benchmark_min_time_flag_time_test.cc +0 -90
  425. package/build/_deps/benchmark-src/test/benchmark_name_gtest.cc +0 -82
  426. package/build/_deps/benchmark-src/test/benchmark_random_interleaving_gtest.cc +0 -126
  427. package/build/_deps/benchmark-src/test/benchmark_setup_teardown_test.cc +0 -157
  428. package/build/_deps/benchmark-src/test/benchmark_test.cc +0 -274
  429. package/build/_deps/benchmark-src/test/clobber_memory_assembly_test.cc +0 -64
  430. package/build/_deps/benchmark-src/test/commandlineflags_gtest.cc +0 -228
  431. package/build/_deps/benchmark-src/test/complexity_test.cc +0 -228
  432. package/build/_deps/benchmark-src/test/cxx03_test.cc +0 -62
  433. package/build/_deps/benchmark-src/test/diagnostics_test.cc +0 -91
  434. package/build/_deps/benchmark-src/test/display_aggregates_only_test.cc +0 -45
  435. package/build/_deps/benchmark-src/test/donotoptimize_assembly_test.cc +0 -201
  436. package/build/_deps/benchmark-src/test/donotoptimize_test.cc +0 -69
  437. package/build/_deps/benchmark-src/test/filter_test.cc +0 -117
  438. package/build/_deps/benchmark-src/test/fixture_test.cc +0 -51
  439. package/build/_deps/benchmark-src/test/internal_threading_test.cc +0 -185
  440. package/build/_deps/benchmark-src/test/link_main_test.cc +0 -9
  441. package/build/_deps/benchmark-src/test/map_test.cc +0 -59
  442. package/build/_deps/benchmark-src/test/memory_manager_test.cc +0 -47
  443. package/build/_deps/benchmark-src/test/min_time_parse_gtest.cc +0 -30
  444. package/build/_deps/benchmark-src/test/multiple_ranges_test.cc +0 -96
  445. package/build/_deps/benchmark-src/test/options_test.cc +0 -77
  446. package/build/_deps/benchmark-src/test/output_test.h +0 -211
  447. package/build/_deps/benchmark-src/test/output_test_helper.cc +0 -519
  448. package/build/_deps/benchmark-src/test/perf_counters_gtest.cc +0 -307
  449. package/build/_deps/benchmark-src/test/perf_counters_test.cc +0 -92
  450. package/build/_deps/benchmark-src/test/register_benchmark_test.cc +0 -196
  451. package/build/_deps/benchmark-src/test/repetitions_test.cc +0 -214
  452. package/build/_deps/benchmark-src/test/report_aggregates_only_test.cc +0 -41
  453. package/build/_deps/benchmark-src/test/reporter_output_test.cc +0 -1130
  454. package/build/_deps/benchmark-src/test/skip_with_error_test.cc +0 -199
  455. package/build/_deps/benchmark-src/test/spec_arg_test.cc +0 -105
  456. package/build/_deps/benchmark-src/test/spec_arg_verbosity_test.cc +0 -43
  457. package/build/_deps/benchmark-src/test/state_assembly_test.cc +0 -68
  458. package/build/_deps/benchmark-src/test/statistics_gtest.cc +0 -35
  459. package/build/_deps/benchmark-src/test/string_util_gtest.cc +0 -199
  460. package/build/_deps/benchmark-src/test/templated_fixture_test.cc +0 -28
  461. package/build/_deps/benchmark-src/test/time_unit_gtest.cc +0 -37
  462. package/build/_deps/benchmark-src/test/user_counters_tabular_test.cc +0 -558
  463. package/build/_deps/benchmark-src/test/user_counters_test.cc +0 -561
  464. package/build/_deps/benchmark-src/test/user_counters_thousands_test.cc +0 -186
  465. package/build/_deps/benchmark-src/tools/BUILD.bazel +0 -19
  466. package/build/_deps/benchmark-src/tools/compare.py +0 -432
  467. package/build/_deps/benchmark-src/tools/gbench/Inputs/test1_run1.json +0 -127
  468. package/build/_deps/benchmark-src/tools/gbench/Inputs/test1_run2.json +0 -127
  469. package/build/_deps/benchmark-src/tools/gbench/Inputs/test2_run.json +0 -81
  470. package/build/_deps/benchmark-src/tools/gbench/Inputs/test3_run0.json +0 -65
  471. package/build/_deps/benchmark-src/tools/gbench/Inputs/test3_run1.json +0 -65
  472. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run.json +0 -96
  473. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run0.json +0 -21
  474. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run1.json +0 -21
  475. package/build/_deps/benchmark-src/tools/gbench/__init__.py +0 -8
  476. package/build/_deps/benchmark-src/tools/gbench/report.py +0 -1201
  477. package/build/_deps/benchmark-src/tools/gbench/util.py +0 -203
  478. package/build/_deps/benchmark-src/tools/libpfm.BUILD.bazel +0 -22
  479. package/build/_deps/benchmark-src/tools/requirements.txt +0 -2
  480. package/build/_deps/benchmark-src/tools/strip_asm.py +0 -151
  481. package/build/_deps/benchmark-subbuild/CMakeCache.txt +0 -133
  482. package/build/_deps/benchmark-subbuild/CMakeFiles/4.0.3/CMakeSystem.cmake +0 -15
  483. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeConfigureLog.yaml +0 -11
  484. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  485. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeRuleHashes.txt +0 -11
  486. package/build/_deps/benchmark-subbuild/CMakeFiles/InstallScripts.json +0 -7
  487. package/build/_deps/benchmark-subbuild/CMakeFiles/Makefile.cmake +0 -52
  488. package/build/_deps/benchmark-subbuild/CMakeFiles/Makefile2 +0 -122
  489. package/build/_deps/benchmark-subbuild/CMakeFiles/TargetDirectories.txt +0 -3
  490. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate-complete +0 -0
  491. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/DependInfo.cmake +0 -22
  492. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/Labels.json +0 -46
  493. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/Labels.txt +0 -14
  494. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/build.make +0 -162
  495. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/cmake_clean.cmake +0 -17
  496. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/compiler_depend.make +0 -2
  497. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/compiler_depend.ts +0 -2
  498. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/progress.make +0 -10
  499. package/build/_deps/benchmark-subbuild/CMakeFiles/cmake.check_cache +0 -1
  500. package/build/_deps/benchmark-subbuild/CMakeFiles/progress.marks +0 -1
  501. package/build/_deps/benchmark-subbuild/CMakeLists.txt +0 -42
  502. package/build/_deps/benchmark-subbuild/Makefile +0 -162
  503. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-build +0 -0
  504. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-configure +0 -0
  505. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-done +0 -0
  506. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-download +0 -0
  507. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-gitclone-lastrun.txt +0 -15
  508. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-gitinfo.txt +0 -15
  509. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-install +0 -0
  510. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-mkdir +0 -0
  511. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-patch +0 -0
  512. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-patch-info.txt +0 -6
  513. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-test +0 -0
  514. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-update-info.txt +0 -7
  515. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-cfgcmd.txt +0 -1
  516. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-gitclone.cmake +0 -87
  517. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-gitupdate.cmake +0 -317
  518. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-mkdirs.cmake +0 -27
  519. package/build/_deps/benchmark-subbuild/cmake_install.cmake +0 -56
  520. package/build/bin/avl-rb-range-search-benchmark +0 -0
  521. package/build/bin/avl-tree-benchmark +0 -0
  522. package/build/bin/deque-benchmark +0 -0
  523. package/build/bin/doubly-linked-list-benchmark +0 -0
  524. package/build/bin/hash-map-benchmark +0 -0
  525. package/build/bin/heap-benchmark +0 -0
  526. package/build/bin/priority-queue-benchmark +0 -0
  527. package/build/bin/queue-benchmark +0 -0
  528. package/build/bin/red-black-tree-benchmark +0 -0
  529. package/build/bin/singly-linked-list-benchmark +0 -0
  530. package/build/bin/stack-benchmark +0 -0
  531. package/build/bin/tree-map-benchmark +0 -0
  532. package/build/bin/tree-multi-map-benchmark +0 -0
  533. package/build/bin/tree-multi-set-benchmark +0 -0
  534. package/build/bin/tree-set-benchmark +0 -0
  535. package/build/cmake_install.cmake +0 -66
  536. package/dist/cjs/index.cjs.map +0 -1
  537. package/dist/cjs-legacy/index.cjs.map +0 -1
  538. package/dist/esm/index.mjs.map +0 -1
  539. package/dist/esm-legacy/index.mjs.map +0 -1
  540. package/dist/umd/data-structure-typed.js.map +0 -1
  541. package/dist/umd/data-structure-typed.min.js.map +0 -1
  542. package/eslint.config.mjs +0 -73
  543. package/test/config.ts +0 -4
  544. package/test/integration/all-in-one.test.ts +0 -110
  545. package/test/integration/avl-tree.test.ts +0 -127
  546. package/test/integration/bst.test.ts +0 -385
  547. package/test/integration/compile.test.mjs +0 -159
  548. package/test/integration/compile.test.ts +0 -176
  549. package/test/integration/heap.test.js +0 -21
  550. package/test/integration/index.html +0 -462
  551. package/test/performance/benchmark-runner-enhanced.mjs +0 -818
  552. package/test/performance/cmake-benchmark-runner.mjs +0 -234
  553. package/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp +0 -112
  554. package/test/performance/data-structures/binary-tree/avl-rb-range-search.test.mjs +0 -51
  555. package/test/performance/data-structures/binary-tree/avl-tree.test.cpp +0 -181
  556. package/test/performance/data-structures/binary-tree/avl-tree.test.mjs +0 -138
  557. package/test/performance/data-structures/binary-tree/binary-tree-overall.test.mjs +0 -85
  558. package/test/performance/data-structures/binary-tree/binary-tree.test.mjs +0 -100
  559. package/test/performance/data-structures/binary-tree/bst.test.mjs +0 -61
  560. package/test/performance/data-structures/binary-tree/red-black-tree-cjs.test.mjs +0 -259
  561. package/test/performance/data-structures/binary-tree/red-black-tree.test.cpp +0 -213
  562. package/test/performance/data-structures/binary-tree/red-black-tree.test.mjs +0 -275
  563. package/test/performance/data-structures/binary-tree/tree-map.test.cpp +0 -129
  564. package/test/performance/data-structures/binary-tree/tree-map.test.mjs +0 -171
  565. package/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp +0 -205
  566. package/test/performance/data-structures/binary-tree/tree-multi-map.test.mjs +0 -106
  567. package/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp +0 -217
  568. package/test/performance/data-structures/binary-tree/tree-multi-set.test.mjs +0 -91
  569. package/test/performance/data-structures/binary-tree/tree-set.test.cpp +0 -127
  570. package/test/performance/data-structures/binary-tree/tree-set.test.mjs +0 -174
  571. package/test/performance/data-structures/comparison/comparison.test.mjs +0 -99
  572. package/test/performance/data-structures/graph/directed-graph.test.mjs +0 -38
  573. package/test/performance/data-structures/hash/hash-map.test.cpp +0 -183
  574. package/test/performance/data-structures/hash/hash-map.test.mjs +0 -187
  575. package/test/performance/data-structures/heap/heap.test.cpp +0 -61
  576. package/test/performance/data-structures/heap/heap.test.mjs +0 -31
  577. package/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp +0 -84
  578. package/test/performance/data-structures/linked-list/doubly-linked-list.test.mjs +0 -125
  579. package/test/performance/data-structures/linked-list/singly-linked-list.test.cpp +0 -77
  580. package/test/performance/data-structures/linked-list/singly-linked-list.test.mjs +0 -84
  581. package/test/performance/data-structures/priority-queue/max-priority-queue.test.mjs +0 -40
  582. package/test/performance/data-structures/priority-queue/priority-queue.test.cpp +0 -59
  583. package/test/performance/data-structures/priority-queue/priority-queue.test.mjs +0 -64
  584. package/test/performance/data-structures/queue/deque.test.cpp +0 -119
  585. package/test/performance/data-structures/queue/deque.test.mjs +0 -144
  586. package/test/performance/data-structures/queue/queue.test.cpp +0 -59
  587. package/test/performance/data-structures/queue/queue.test.mjs +0 -77
  588. package/test/performance/data-structures/stack/stack.test.cpp +0 -40
  589. package/test/performance/data-structures/stack/stack.test.mjs +0 -69
  590. package/test/performance/data-structures/trie/trie.test.mjs +0 -43
  591. package/test/performance/reportor-enhanced.mjs +0 -871
  592. package/test/performance/runner-config.json +0 -51
  593. package/test/types/index.ts +0 -1
  594. package/test/types/utils/big-o.ts +0 -1
  595. package/test/types/utils/index.ts +0 -2
  596. package/test/types/utils/json2html.ts +0 -5
  597. package/test/unit/data-structures/base/iterable-element-base.coverage.test.ts +0 -106
  598. package/test/unit/data-structures/base/iterable-element-base.more-branches.coverage.test.ts +0 -61
  599. package/test/unit/data-structures/base/linear-base.array.coverage.test.ts +0 -168
  600. package/test/unit/data-structures/base/linear-base.concat-else.coverage.test.ts +0 -82
  601. package/test/unit/data-structures/base/linear-base.coverage.test.ts +0 -72
  602. package/test/unit/data-structures/base/linear-base.more-branches.coverage.test.ts +0 -414
  603. package/test/unit/data-structures/binary-tree/avl-tree-node.familyPosition-root-left.coverage.test.ts +0 -17
  604. package/test/unit/data-structures/binary-tree/avl-tree.more-branches-2.coverage.test.ts +0 -99
  605. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +0 -729
  606. package/test/unit/data-structures/binary-tree/binary-index-tree.test.ts +0 -345
  607. package/test/unit/data-structures/binary-tree/binary-indexed-tree.more-branches.coverage.test.ts +0 -18
  608. package/test/unit/data-structures/binary-tree/binary-tree.more-branches.coverage.test.ts +0 -56
  609. package/test/unit/data-structures/binary-tree/binary-tree.remaining-branches.coverage.test.ts +0 -232
  610. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +0 -1912
  611. package/test/unit/data-structures/binary-tree/bst.bound-by-predicate.coverage.test.ts +0 -33
  612. package/test/unit/data-structures/binary-tree/bst.coverage.test.ts +0 -94
  613. package/test/unit/data-structures/binary-tree/bst.deletebykey.coverage.test.ts +0 -70
  614. package/test/unit/data-structures/binary-tree/bst.deletewhere.coverage.test.ts +0 -37
  615. package/test/unit/data-structures/binary-tree/bst.floor-lower-predicate.coverage.test.ts +0 -29
  616. package/test/unit/data-structures/binary-tree/bst.floor-setmany.coverage.test.ts +0 -72
  617. package/test/unit/data-structures/binary-tree/bst.getnode.range-ensure.coverage.test.ts +0 -22
  618. package/test/unit/data-structures/binary-tree/bst.misc-branches.coverage.test.ts +0 -100
  619. package/test/unit/data-structures/binary-tree/bst.more-branches-2.coverage.test.ts +0 -133
  620. package/test/unit/data-structures/binary-tree/bst.more-branches-3.coverage.test.ts +0 -45
  621. package/test/unit/data-structures/binary-tree/bst.more-branches-4.coverage.test.ts +0 -36
  622. package/test/unit/data-structures/binary-tree/bst.more-branches-5.coverage.test.ts +0 -40
  623. package/test/unit/data-structures/binary-tree/bst.more.coverage.test.ts +0 -39
  624. package/test/unit/data-structures/binary-tree/bst.node-family.coverage.test.ts +0 -29
  625. package/test/unit/data-structures/binary-tree/bst.range-pruning.coverage.test.ts +0 -43
  626. package/test/unit/data-structures/binary-tree/bst.search-fastpath.coverage.test.ts +0 -30
  627. package/test/unit/data-structures/binary-tree/bst.test.ts +0 -3472
  628. package/test/unit/data-structures/binary-tree/data/cost-of-living-by-country.ts +0 -259
  629. package/test/unit/data-structures/binary-tree/overall.test.ts +0 -219
  630. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-corruption-repair.coverage.test.ts +0 -66
  631. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-max-update.coverage.test.ts +0 -18
  632. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-null.coverage.test.ts +0 -53
  633. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-stale-cache.coverage.test.ts +0 -25
  634. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-update.coverage.test.ts +0 -23
  635. package/test/unit/data-structures/binary-tree/red-black-tree.cache-delete.coverage.test.ts +0 -49
  636. package/test/unit/data-structures/binary-tree/red-black-tree.cache-edge.coverage.test.ts +0 -37
  637. package/test/unit/data-structures/binary-tree/red-black-tree.cache-stale-insert.coverage.test.ts +0 -39
  638. package/test/unit/data-structures/binary-tree/red-black-tree.coverage.test.ts +0 -334
  639. package/test/unit/data-structures/binary-tree/red-black-tree.delete-fixup.coverage.test.ts +0 -68
  640. package/test/unit/data-structures/binary-tree/red-black-tree.delete-successor.coverage.test.ts +0 -75
  641. package/test/unit/data-structures/binary-tree/red-black-tree.factories.coverage.test.ts +0 -26
  642. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-compare-update.coverage.test.ts +0 -74
  643. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-no-update.coverage.test.ts +0 -44
  644. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-nullish.coverage.test.ts +0 -61
  645. package/test/unit/data-structures/binary-tree/red-black-tree.hint-mapmode-defined.coverage.test.ts +0 -35
  646. package/test/unit/data-structures/binary-tree/red-black-tree.hint-mapmode-undefined.coverage.test.ts +0 -43
  647. package/test/unit/data-structures/binary-tree/red-black-tree.hint-more.coverage.test.ts +0 -99
  648. package/test/unit/data-structures/binary-tree/red-black-tree.hint.coverage.test.ts +0 -60
  649. package/test/unit/data-structures/binary-tree/red-black-tree.insert-cache-nullish.coverage.test.ts +0 -29
  650. package/test/unit/data-structures/binary-tree/red-black-tree.insert-header-parent-nullish.coverage.test.ts +0 -17
  651. package/test/unit/data-structures/binary-tree/red-black-tree.internal-walk.coverage.test.ts +0 -57
  652. package/test/unit/data-structures/binary-tree/red-black-tree.minmax-cache.test.ts +0 -65
  653. package/test/unit/data-structures/binary-tree/red-black-tree.misc-inputs.coverage.test.ts +0 -17
  654. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-2.coverage.test.ts +0 -121
  655. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-3.coverage.test.ts +0 -55
  656. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-4.coverage.test.ts +0 -44
  657. package/test/unit/data-structures/binary-tree/red-black-tree.predsucc.coverage.test.ts +0 -40
  658. package/test/unit/data-structures/binary-tree/red-black-tree.remaining-branches.coverage.test.ts +0 -123
  659. package/test/unit/data-structures/binary-tree/red-black-tree.set-inputs.coverage.test.ts +0 -64
  660. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-parent-cache.coverage.test.ts +0 -79
  661. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-remaining.coverage.test.ts +0 -44
  662. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-uncovered.coverage.test.ts +0 -74
  663. package/test/unit/data-structures/binary-tree/red-black-tree.test.ts +0 -936
  664. package/test/unit/data-structures/binary-tree/red-black-tree.update-branches.coverage.test.ts +0 -30
  665. package/test/unit/data-structures/binary-tree/segment-tree.more-branches.coverage.test.ts +0 -31
  666. package/test/unit/data-structures/binary-tree/segment-tree.test.ts +0 -104
  667. package/test/unit/data-structures/binary-tree/tree-map.test.ts +0 -270
  668. package/test/unit/data-structures/binary-tree/tree-multi-map.coverage.test.ts +0 -245
  669. package/test/unit/data-structures/binary-tree/tree-multi-map.legacy.test.ts.skip +0 -1115
  670. package/test/unit/data-structures/binary-tree/tree-multi-map.more-branches-2.coverage.test.ts.skip +0 -59
  671. package/test/unit/data-structures/binary-tree/tree-multi-map.rfc.test.ts +0 -99
  672. package/test/unit/data-structures/binary-tree/tree-multi-map.simplified.test.ts +0 -482
  673. package/test/unit/data-structures/binary-tree/tree-multi-set.test.ts +0 -545
  674. package/test/unit/data-structures/binary-tree/tree-set.test.ts +0 -187
  675. package/test/unit/data-structures/graph/abstract-graph.more-branches-2.coverage.test.ts +0 -40
  676. package/test/unit/data-structures/graph/abstract-graph.more-branches-3.coverage.test.ts +0 -65
  677. package/test/unit/data-structures/graph/abstract-graph.more-branches-4.coverage.test.ts +0 -98
  678. package/test/unit/data-structures/graph/abstract-graph.more-branches-5.coverage.test.ts +0 -51
  679. package/test/unit/data-structures/graph/abstract-graph.more-branches.coverage.test.ts +0 -62
  680. package/test/unit/data-structures/graph/abstract-graph.test.ts +0 -117
  681. package/test/unit/data-structures/graph/directed-graph.more-branches-2.coverage.test.ts +0 -38
  682. package/test/unit/data-structures/graph/directed-graph.more-branches-3.coverage.test.ts +0 -25
  683. package/test/unit/data-structures/graph/directed-graph.more-branches.coverage.test.ts +0 -82
  684. package/test/unit/data-structures/graph/directed-graph.test.ts +0 -1185
  685. package/test/unit/data-structures/graph/map-graph.more-branches.coverage.test.ts +0 -22
  686. package/test/unit/data-structures/graph/map-graph.test.ts +0 -148
  687. package/test/unit/data-structures/graph/overall.test.ts +0 -49
  688. package/test/unit/data-structures/graph/salty-edges.json +0 -875
  689. package/test/unit/data-structures/graph/salty-vertexes.json +0 -200
  690. package/test/unit/data-structures/graph/undirected-graph.more-branches-2.coverage.test.ts +0 -35
  691. package/test/unit/data-structures/graph/undirected-graph.more-branches.coverage.test.ts +0 -87
  692. package/test/unit/data-structures/graph/undirected-graph.test.ts +0 -782
  693. package/test/unit/data-structures/hash/hash-map.more-branches.coverage.test.ts +0 -64
  694. package/test/unit/data-structures/hash/hash-map.test.ts +0 -1125
  695. package/test/unit/data-structures/hash/hash-map.toEntryFn-branch.coverage.test.ts +0 -9
  696. package/test/unit/data-structures/heap/heap.misc-branches.coverage.test.ts +0 -110
  697. package/test/unit/data-structures/heap/heap.remaining-branches.coverage.test.ts +0 -22
  698. package/test/unit/data-structures/heap/heap.test.ts +0 -760
  699. package/test/unit/data-structures/heap/max-heap.coverage.test.ts +0 -29
  700. package/test/unit/data-structures/heap/max-heap.test.ts +0 -98
  701. package/test/unit/data-structures/heap/min-heap.test.ts +0 -117
  702. package/test/unit/data-structures/linked-list/doubly-linked-list.more-branches.coverage.test.ts +0 -72
  703. package/test/unit/data-structures/linked-list/doubly-linked-list.test.ts +0 -1150
  704. package/test/unit/data-structures/linked-list/linked-list.test.ts +0 -8
  705. package/test/unit/data-structures/linked-list/linked-list.unshiftMany-else.coverage.test.ts +0 -15
  706. package/test/unit/data-structures/linked-list/singly-linked-list.coverage.test.ts +0 -221
  707. package/test/unit/data-structures/linked-list/singly-linked-list.more-branches.coverage.test.ts +0 -86
  708. package/test/unit/data-structures/linked-list/singly-linked-list.test.ts +0 -836
  709. package/test/unit/data-structures/linked-list/skip-linked-list.more-branches.coverage.test.ts +0 -31
  710. package/test/unit/data-structures/linked-list/skip-linked-list.test.ts +0 -13
  711. package/test/unit/data-structures/linked-list/skip-list.test.ts +0 -86
  712. package/test/unit/data-structures/matrix/matrix.more-branches.coverage.test.ts +0 -81
  713. package/test/unit/data-structures/matrix/matrix.pivotElement-nullish.coverage.test.ts +0 -28
  714. package/test/unit/data-structures/matrix/matrix.test.ts +0 -377
  715. package/test/unit/data-structures/matrix/navigator.test.ts +0 -244
  716. package/test/unit/data-structures/priority-queue/max-priority-queue.more-branches.coverage.test.ts +0 -10
  717. package/test/unit/data-structures/priority-queue/max-priority-queue.test.ts +0 -160
  718. package/test/unit/data-structures/priority-queue/min-priority-queue.test.ts +0 -78
  719. package/test/unit/data-structures/priority-queue/priority-queue.coverage.test.ts +0 -21
  720. package/test/unit/data-structures/priority-queue/priority-queue.test.ts +0 -101
  721. package/test/unit/data-structures/queue/deque.coverage.test.ts +0 -173
  722. package/test/unit/data-structures/queue/deque.more-branches-2.coverage.test.ts +0 -39
  723. package/test/unit/data-structures/queue/deque.more-branches-3.coverage.test.ts +0 -9
  724. package/test/unit/data-structures/queue/deque.more-branches.coverage.test.ts +0 -95
  725. package/test/unit/data-structures/queue/deque.test.ts +0 -936
  726. package/test/unit/data-structures/queue/queue.coverage.test.ts +0 -138
  727. package/test/unit/data-structures/queue/queue.more-branches-2.coverage.test.ts +0 -27
  728. package/test/unit/data-structures/queue/queue.test.ts +0 -703
  729. package/test/unit/data-structures/stack/stack.coverage.test.ts +0 -112
  730. package/test/unit/data-structures/stack/stack.test.ts +0 -438
  731. package/test/unit/data-structures/tree/tree.more-branches.coverage.test.ts +0 -9
  732. package/test/unit/data-structures/tree/tree.test.ts +0 -58
  733. package/test/unit/data-structures/trie/trie.more-branches-2.coverage.test.ts +0 -51
  734. package/test/unit/data-structures/trie/trie.test.ts +0 -1181
  735. package/test/unit/unrestricted-interconversion.test.ts +0 -299
  736. package/test/unit/utils/utils.test.ts +0 -174
  737. package/test/utils/array.ts +0 -5517
  738. package/test/utils/big-o.ts +0 -228
  739. package/test/utils/console.ts +0 -31
  740. package/test/utils/index.ts +0 -8
  741. package/test/utils/is.ts +0 -56
  742. package/test/utils/json2html.ts +0 -164
  743. package/test/utils/number.ts +0 -13
  744. package/test/utils/patch.ts +0 -33
  745. package/test/utils/perf.mjs +0 -34
  746. package/test/utils/performanc.ts +0 -7
  747. package/test/utils/string.ts +0 -49
  748. package/tsconfig.types.json +0 -15
  749. package/tsup.config.js +0 -63
  750. package/tsup.umd.config.js +0 -29
@@ -1,1201 +0,0 @@
1
- """report.py - Utilities for reporting statistics about benchmark results
2
- """
3
-
4
- import unittest
5
- import os
6
- import re
7
- import copy
8
- import random
9
-
10
- from scipy.stats import mannwhitneyu, gmean
11
- from numpy import array
12
-
13
-
14
- class BenchmarkColor(object):
15
- def __init__(self, name, code):
16
- self.name = name
17
- self.code = code
18
-
19
- def __repr__(self):
20
- return '%s%r' % (self.__class__.__name__,
21
- (self.name, self.code))
22
-
23
- def __format__(self, format):
24
- return self.code
25
-
26
-
27
- # Benchmark Colors Enumeration
28
- BC_NONE = BenchmarkColor('NONE', '')
29
- BC_MAGENTA = BenchmarkColor('MAGENTA', '\033[95m')
30
- BC_CYAN = BenchmarkColor('CYAN', '\033[96m')
31
- BC_OKBLUE = BenchmarkColor('OKBLUE', '\033[94m')
32
- BC_OKGREEN = BenchmarkColor('OKGREEN', '\033[32m')
33
- BC_HEADER = BenchmarkColor('HEADER', '\033[92m')
34
- BC_WARNING = BenchmarkColor('WARNING', '\033[93m')
35
- BC_WHITE = BenchmarkColor('WHITE', '\033[97m')
36
- BC_FAIL = BenchmarkColor('FAIL', '\033[91m')
37
- BC_ENDC = BenchmarkColor('ENDC', '\033[0m')
38
- BC_BOLD = BenchmarkColor('BOLD', '\033[1m')
39
- BC_UNDERLINE = BenchmarkColor('UNDERLINE', '\033[4m')
40
-
41
- UTEST_MIN_REPETITIONS = 2
42
- UTEST_OPTIMAL_REPETITIONS = 9 # Lowest reasonable number, More is better.
43
- UTEST_COL_NAME = "_pvalue"
44
-
45
- _TIME_UNIT_TO_SECONDS_MULTIPLIER = {
46
- "s": 1.0,
47
- "ms": 1e-3,
48
- "us": 1e-6,
49
- "ns": 1e-9,
50
- }
51
-
52
-
53
- def color_format(use_color, fmt_str, *args, **kwargs):
54
- """
55
- Return the result of 'fmt_str.format(*args, **kwargs)' after transforming
56
- 'args' and 'kwargs' according to the value of 'use_color'. If 'use_color'
57
- is False then all color codes in 'args' and 'kwargs' are replaced with
58
- the empty string.
59
- """
60
- assert use_color is True or use_color is False
61
- if not use_color:
62
- args = [arg if not isinstance(arg, BenchmarkColor) else BC_NONE
63
- for arg in args]
64
- kwargs = {key: arg if not isinstance(arg, BenchmarkColor) else BC_NONE
65
- for key, arg in kwargs.items()}
66
- return fmt_str.format(*args, **kwargs)
67
-
68
-
69
- def find_longest_name(benchmark_list):
70
- """
71
- Return the length of the longest benchmark name in a given list of
72
- benchmark JSON objects
73
- """
74
- longest_name = 1
75
- for bc in benchmark_list:
76
- if len(bc['name']) > longest_name:
77
- longest_name = len(bc['name'])
78
- return longest_name
79
-
80
-
81
- def calculate_change(old_val, new_val):
82
- """
83
- Return a float representing the decimal change between old_val and new_val.
84
- """
85
- if old_val == 0 and new_val == 0:
86
- return 0.0
87
- if old_val == 0:
88
- return float(new_val - old_val) / (float(old_val + new_val) / 2)
89
- return float(new_val - old_val) / abs(old_val)
90
-
91
-
92
- def filter_benchmark(json_orig, family, replacement=""):
93
- """
94
- Apply a filter to the json, and only leave the 'family' of benchmarks.
95
- """
96
- regex = re.compile(family)
97
- filtered = {}
98
- filtered['benchmarks'] = []
99
- for be in json_orig['benchmarks']:
100
- if not regex.search(be['name']):
101
- continue
102
- filteredbench = copy.deepcopy(be) # Do NOT modify the old name!
103
- filteredbench['name'] = regex.sub(replacement, filteredbench['name'])
104
- filtered['benchmarks'].append(filteredbench)
105
- return filtered
106
-
107
-
108
- def get_unique_benchmark_names(json):
109
- """
110
- While *keeping* the order, give all the unique 'names' used for benchmarks.
111
- """
112
- seen = set()
113
- uniqued = [x['name'] for x in json['benchmarks']
114
- if x['name'] not in seen and
115
- (seen.add(x['name']) or True)]
116
- return uniqued
117
-
118
-
119
- def intersect(list1, list2):
120
- """
121
- Given two lists, get a new list consisting of the elements only contained
122
- in *both of the input lists*, while preserving the ordering.
123
- """
124
- return [x for x in list1 if x in list2]
125
-
126
-
127
- def is_potentially_comparable_benchmark(x):
128
- return ('time_unit' in x and 'real_time' in x and 'cpu_time' in x)
129
-
130
-
131
- def partition_benchmarks(json1, json2):
132
- """
133
- While preserving the ordering, find benchmarks with the same names in
134
- both of the inputs, and group them.
135
- (i.e. partition/filter into groups with common name)
136
- """
137
- json1_unique_names = get_unique_benchmark_names(json1)
138
- json2_unique_names = get_unique_benchmark_names(json2)
139
- names = intersect(json1_unique_names, json2_unique_names)
140
- partitions = []
141
- for name in names:
142
- time_unit = None
143
- # Pick the time unit from the first entry of the lhs benchmark.
144
- # We should be careful not to crash with unexpected input.
145
- for x in json1['benchmarks']:
146
- if (x['name'] == name and is_potentially_comparable_benchmark(x)):
147
- time_unit = x['time_unit']
148
- break
149
- if time_unit is None:
150
- continue
151
- # Filter by name and time unit.
152
- # All the repetitions are assumed to be comparable.
153
- lhs = [x for x in json1['benchmarks'] if x['name'] == name and
154
- x['time_unit'] == time_unit]
155
- rhs = [x for x in json2['benchmarks'] if x['name'] == name and
156
- x['time_unit'] == time_unit]
157
- partitions.append([lhs, rhs])
158
- return partitions
159
-
160
-
161
- def get_timedelta_field_as_seconds(benchmark, field_name):
162
- """
163
- Get value of field_name field of benchmark, which is time with time unit
164
- time_unit, as time in seconds.
165
- """
166
- timedelta = benchmark[field_name]
167
- time_unit = benchmark.get('time_unit', 's')
168
- return timedelta * _TIME_UNIT_TO_SECONDS_MULTIPLIER.get(time_unit)
169
-
170
-
171
- def calculate_geomean(json):
172
- """
173
- Extract all real/cpu times from all the benchmarks as seconds,
174
- and calculate their geomean.
175
- """
176
- times = []
177
- for benchmark in json['benchmarks']:
178
- if 'run_type' in benchmark and benchmark['run_type'] == 'aggregate':
179
- continue
180
- times.append([get_timedelta_field_as_seconds(benchmark, 'real_time'),
181
- get_timedelta_field_as_seconds(benchmark, 'cpu_time')])
182
- return gmean(times) if times else array([])
183
-
184
-
185
- def extract_field(partition, field_name):
186
- # The count of elements may be different. We want *all* of them.
187
- lhs = [x[field_name] for x in partition[0]]
188
- rhs = [x[field_name] for x in partition[1]]
189
- return [lhs, rhs]
190
-
191
-
192
- def calc_utest(timings_cpu, timings_time):
193
- min_rep_cnt = min(len(timings_time[0]),
194
- len(timings_time[1]),
195
- len(timings_cpu[0]),
196
- len(timings_cpu[1]))
197
-
198
- # Does *everything* has at least UTEST_MIN_REPETITIONS repetitions?
199
- if min_rep_cnt < UTEST_MIN_REPETITIONS:
200
- return False, None, None
201
-
202
- time_pvalue = mannwhitneyu(
203
- timings_time[0], timings_time[1], alternative='two-sided').pvalue
204
- cpu_pvalue = mannwhitneyu(
205
- timings_cpu[0], timings_cpu[1], alternative='two-sided').pvalue
206
-
207
- return (min_rep_cnt >= UTEST_OPTIMAL_REPETITIONS), cpu_pvalue, time_pvalue
208
-
209
-
210
- def print_utest(bc_name, utest, utest_alpha, first_col_width, use_color=True):
211
- def get_utest_color(pval):
212
- return BC_FAIL if pval >= utest_alpha else BC_OKGREEN
213
-
214
- # Check if we failed miserably with minimum required repetitions for utest
215
- if not utest['have_optimal_repetitions'] and utest['cpu_pvalue'] is None and utest['time_pvalue'] is None:
216
- return []
217
-
218
- dsc = "U Test, Repetitions: {} vs {}".format(
219
- utest['nr_of_repetitions'], utest['nr_of_repetitions_other'])
220
- dsc_color = BC_OKGREEN
221
-
222
- # We still got some results to show but issue a warning about it.
223
- if not utest['have_optimal_repetitions']:
224
- dsc_color = BC_WARNING
225
- dsc += ". WARNING: Results unreliable! {}+ repetitions recommended.".format(
226
- UTEST_OPTIMAL_REPETITIONS)
227
-
228
- special_str = "{}{:<{}s}{endc}{}{:16.4f}{endc}{}{:16.4f}{endc}{} {}"
229
-
230
- return [color_format(use_color,
231
- special_str,
232
- BC_HEADER,
233
- "{}{}".format(bc_name, UTEST_COL_NAME),
234
- first_col_width,
235
- get_utest_color(
236
- utest['time_pvalue']), utest['time_pvalue'],
237
- get_utest_color(
238
- utest['cpu_pvalue']), utest['cpu_pvalue'],
239
- dsc_color, dsc,
240
- endc=BC_ENDC)]
241
-
242
-
243
- def get_difference_report(
244
- json1,
245
- json2,
246
- utest=False):
247
- """
248
- Calculate and report the difference between each test of two benchmarks
249
- runs specified as 'json1' and 'json2'. Output is another json containing
250
- relevant details for each test run.
251
- """
252
- assert utest is True or utest is False
253
-
254
- diff_report = []
255
- partitions = partition_benchmarks(json1, json2)
256
- for partition in partitions:
257
- benchmark_name = partition[0][0]['name']
258
- label = partition[0][0]['label'] if 'label' in partition[0][0] else ''
259
- time_unit = partition[0][0]['time_unit']
260
- measurements = []
261
- utest_results = {}
262
- # Careful, we may have different repetition count.
263
- for i in range(min(len(partition[0]), len(partition[1]))):
264
- bn = partition[0][i]
265
- other_bench = partition[1][i]
266
- measurements.append({
267
- 'real_time': bn['real_time'],
268
- 'cpu_time': bn['cpu_time'],
269
- 'real_time_other': other_bench['real_time'],
270
- 'cpu_time_other': other_bench['cpu_time'],
271
- 'time': calculate_change(bn['real_time'], other_bench['real_time']),
272
- 'cpu': calculate_change(bn['cpu_time'], other_bench['cpu_time'])
273
- })
274
-
275
- # After processing the whole partition, if requested, do the U test.
276
- if utest:
277
- timings_cpu = extract_field(partition, 'cpu_time')
278
- timings_time = extract_field(partition, 'real_time')
279
- have_optimal_repetitions, cpu_pvalue, time_pvalue = calc_utest(
280
- timings_cpu, timings_time)
281
- if cpu_pvalue and time_pvalue:
282
- utest_results = {
283
- 'have_optimal_repetitions': have_optimal_repetitions,
284
- 'cpu_pvalue': cpu_pvalue,
285
- 'time_pvalue': time_pvalue,
286
- 'nr_of_repetitions': len(timings_cpu[0]),
287
- 'nr_of_repetitions_other': len(timings_cpu[1])
288
- }
289
-
290
- # Store only if we had any measurements for given benchmark.
291
- # E.g. partition_benchmarks will filter out the benchmarks having
292
- # time units which are not compatible with other time units in the
293
- # benchmark suite.
294
- if measurements:
295
- run_type = partition[0][0]['run_type'] if 'run_type' in partition[0][0] else ''
296
- aggregate_name = partition[0][0]['aggregate_name'] if run_type == 'aggregate' and 'aggregate_name' in partition[0][0] else ''
297
- diff_report.append({
298
- 'name': benchmark_name,
299
- 'label': label,
300
- 'measurements': measurements,
301
- 'time_unit': time_unit,
302
- 'run_type': run_type,
303
- 'aggregate_name': aggregate_name,
304
- 'utest': utest_results
305
- })
306
-
307
- lhs_gmean = calculate_geomean(json1)
308
- rhs_gmean = calculate_geomean(json2)
309
- if lhs_gmean.any() and rhs_gmean.any():
310
- diff_report.append({
311
- 'name': 'OVERALL_GEOMEAN',
312
- 'label': '',
313
- 'measurements': [{
314
- 'real_time': lhs_gmean[0],
315
- 'cpu_time': lhs_gmean[1],
316
- 'real_time_other': rhs_gmean[0],
317
- 'cpu_time_other': rhs_gmean[1],
318
- 'time': calculate_change(lhs_gmean[0], rhs_gmean[0]),
319
- 'cpu': calculate_change(lhs_gmean[1], rhs_gmean[1])
320
- }],
321
- 'time_unit': 's',
322
- 'run_type': 'aggregate',
323
- 'aggregate_name': 'geomean',
324
- 'utest': {}
325
- })
326
-
327
- return diff_report
328
-
329
-
330
- def print_difference_report(
331
- json_diff_report,
332
- include_aggregates_only=False,
333
- utest=False,
334
- utest_alpha=0.05,
335
- use_color=True):
336
- """
337
- Calculate and report the difference between each test of two benchmarks
338
- runs specified as 'json1' and 'json2'.
339
- """
340
- assert utest is True or utest is False
341
-
342
- def get_color(res):
343
- if res > 0.05:
344
- return BC_FAIL
345
- elif res > -0.07:
346
- return BC_WHITE
347
- else:
348
- return BC_CYAN
349
-
350
- first_col_width = find_longest_name(json_diff_report)
351
- first_col_width = max(
352
- first_col_width,
353
- len('Benchmark'))
354
- first_col_width += len(UTEST_COL_NAME)
355
- first_line = "{:<{}s}Time CPU Time Old Time New CPU Old CPU New".format(
356
- 'Benchmark', 12 + first_col_width)
357
- output_strs = [first_line, '-' * len(first_line)]
358
-
359
- fmt_str = "{}{:<{}s}{endc}{}{:+16.4f}{endc}{}{:+16.4f}{endc}{:14.0f}{:14.0f}{endc}{:14.0f}{:14.0f}"
360
- for benchmark in json_diff_report:
361
- # *If* we were asked to only include aggregates,
362
- # and if it is non-aggregate, then don't print it.
363
- if not include_aggregates_only or not 'run_type' in benchmark or benchmark['run_type'] == 'aggregate':
364
- for measurement in benchmark['measurements']:
365
- output_strs += [color_format(use_color,
366
- fmt_str,
367
- BC_HEADER,
368
- benchmark['name'],
369
- first_col_width,
370
- get_color(measurement['time']),
371
- measurement['time'],
372
- get_color(measurement['cpu']),
373
- measurement['cpu'],
374
- measurement['real_time'],
375
- measurement['real_time_other'],
376
- measurement['cpu_time'],
377
- measurement['cpu_time_other'],
378
- endc=BC_ENDC)]
379
-
380
- # After processing the measurements, if requested and
381
- # if applicable (e.g. u-test exists for given benchmark),
382
- # print the U test.
383
- if utest and benchmark['utest']:
384
- output_strs += print_utest(benchmark['name'],
385
- benchmark['utest'],
386
- utest_alpha=utest_alpha,
387
- first_col_width=first_col_width,
388
- use_color=use_color)
389
-
390
- return output_strs
391
-
392
-
393
- ###############################################################################
394
- # Unit tests
395
-
396
-
397
- class TestGetUniqueBenchmarkNames(unittest.TestCase):
398
- def load_results(self):
399
- import json
400
- testInputs = os.path.join(
401
- os.path.dirname(
402
- os.path.realpath(__file__)),
403
- 'Inputs')
404
- testOutput = os.path.join(testInputs, 'test3_run0.json')
405
- with open(testOutput, 'r') as f:
406
- json = json.load(f)
407
- return json
408
-
409
- def test_basic(self):
410
- expect_lines = [
411
- 'BM_One',
412
- 'BM_Two',
413
- 'short', # These two are not sorted
414
- 'medium', # These two are not sorted
415
- ]
416
- json = self.load_results()
417
- output_lines = get_unique_benchmark_names(json)
418
- print("\n")
419
- print("\n".join(output_lines))
420
- self.assertEqual(len(output_lines), len(expect_lines))
421
- for i in range(0, len(output_lines)):
422
- self.assertEqual(expect_lines[i], output_lines[i])
423
-
424
-
425
- class TestReportDifference(unittest.TestCase):
426
- @classmethod
427
- def setUpClass(cls):
428
- def load_results():
429
- import json
430
- testInputs = os.path.join(
431
- os.path.dirname(
432
- os.path.realpath(__file__)),
433
- 'Inputs')
434
- testOutput1 = os.path.join(testInputs, 'test1_run1.json')
435
- testOutput2 = os.path.join(testInputs, 'test1_run2.json')
436
- with open(testOutput1, 'r') as f:
437
- json1 = json.load(f)
438
- with open(testOutput2, 'r') as f:
439
- json2 = json.load(f)
440
- return json1, json2
441
-
442
- json1, json2 = load_results()
443
- cls.json_diff_report = get_difference_report(json1, json2)
444
-
445
- def test_json_diff_report_pretty_printing(self):
446
- expect_lines = [
447
- ['BM_SameTimes', '+0.0000', '+0.0000', '10', '10', '10', '10'],
448
- ['BM_2xFaster', '-0.5000', '-0.5000', '50', '25', '50', '25'],
449
- ['BM_2xSlower', '+1.0000', '+1.0000', '50', '100', '50', '100'],
450
- ['BM_1PercentFaster', '-0.0100', '-0.0100', '100', '99', '100', '99'],
451
- ['BM_1PercentSlower', '+0.0100', '+0.0100', '100', '101', '100', '101'],
452
- ['BM_10PercentFaster', '-0.1000', '-0.1000', '100', '90', '100', '90'],
453
- ['BM_10PercentSlower', '+0.1000', '+0.1000', '100', '110', '100', '110'],
454
- ['BM_100xSlower', '+99.0000', '+99.0000',
455
- '100', '10000', '100', '10000'],
456
- ['BM_100xFaster', '-0.9900', '-0.9900',
457
- '10000', '100', '10000', '100'],
458
- ['BM_10PercentCPUToTime', '+0.1000',
459
- '-0.1000', '100', '110', '100', '90'],
460
- ['BM_ThirdFaster', '-0.3333', '-0.3334', '100', '67', '100', '67'],
461
- ['BM_NotBadTimeUnit', '-0.9000', '+0.2000', '0', '0', '0', '1'],
462
- ['BM_hasLabel', '+0.0000', '+0.0000', '1', '1', '1', '1'],
463
- ['OVERALL_GEOMEAN', '-0.8113', '-0.7779', '0', '0', '0', '0']
464
- ]
465
- output_lines_with_header = print_difference_report(
466
- self.json_diff_report, use_color=False)
467
- output_lines = output_lines_with_header[2:]
468
- print("\n")
469
- print("\n".join(output_lines_with_header))
470
- self.assertEqual(len(output_lines), len(expect_lines))
471
- for i in range(0, len(output_lines)):
472
- parts = [x for x in output_lines[i].split(' ') if x]
473
- self.assertEqual(len(parts), 7)
474
- self.assertEqual(expect_lines[i], parts)
475
-
476
- def test_json_diff_report_output(self):
477
- expected_output = [
478
- {
479
- 'name': 'BM_SameTimes',
480
- 'label': '',
481
- 'measurements': [{'time': 0.0000, 'cpu': 0.0000,
482
- 'real_time': 10, 'real_time_other': 10,
483
- 'cpu_time': 10, 'cpu_time_other': 10}],
484
- 'time_unit': 'ns',
485
- 'utest': {}
486
- },
487
- {
488
- 'name': 'BM_2xFaster',
489
- 'label': '',
490
- 'measurements': [{'time': -0.5000, 'cpu': -0.5000,
491
- 'real_time': 50, 'real_time_other': 25,
492
- 'cpu_time': 50, 'cpu_time_other': 25}],
493
- 'time_unit': 'ns',
494
- 'utest': {}
495
- },
496
- {
497
- 'name': 'BM_2xSlower',
498
- 'label': '',
499
- 'measurements': [{'time': 1.0000, 'cpu': 1.0000,
500
- 'real_time': 50, 'real_time_other': 100,
501
- 'cpu_time': 50, 'cpu_time_other': 100}],
502
- 'time_unit': 'ns',
503
- 'utest': {}
504
- },
505
- {
506
- 'name': 'BM_1PercentFaster',
507
- 'label': '',
508
- 'measurements': [{'time': -0.0100, 'cpu': -0.0100,
509
- 'real_time': 100, 'real_time_other': 98.9999999,
510
- 'cpu_time': 100, 'cpu_time_other': 98.9999999}],
511
- 'time_unit': 'ns',
512
- 'utest': {}
513
- },
514
- {
515
- 'name': 'BM_1PercentSlower',
516
- 'label': '',
517
- 'measurements': [{'time': 0.0100, 'cpu': 0.0100,
518
- 'real_time': 100, 'real_time_other': 101,
519
- 'cpu_time': 100, 'cpu_time_other': 101}],
520
- 'time_unit': 'ns',
521
- 'utest': {}
522
- },
523
- {
524
- 'name': 'BM_10PercentFaster',
525
- 'label': '',
526
- 'measurements': [{'time': -0.1000, 'cpu': -0.1000,
527
- 'real_time': 100, 'real_time_other': 90,
528
- 'cpu_time': 100, 'cpu_time_other': 90}],
529
- 'time_unit': 'ns',
530
- 'utest': {}
531
- },
532
- {
533
- 'name': 'BM_10PercentSlower',
534
- 'label': '',
535
- 'measurements': [{'time': 0.1000, 'cpu': 0.1000,
536
- 'real_time': 100, 'real_time_other': 110,
537
- 'cpu_time': 100, 'cpu_time_other': 110}],
538
- 'time_unit': 'ns',
539
- 'utest': {}
540
- },
541
- {
542
- 'name': 'BM_100xSlower',
543
- 'label': '',
544
- 'measurements': [{'time': 99.0000, 'cpu': 99.0000,
545
- 'real_time': 100, 'real_time_other': 10000,
546
- 'cpu_time': 100, 'cpu_time_other': 10000}],
547
- 'time_unit': 'ns',
548
- 'utest': {}
549
- },
550
- {
551
- 'name': 'BM_100xFaster',
552
- 'label': '',
553
- 'measurements': [{'time': -0.9900, 'cpu': -0.9900,
554
- 'real_time': 10000, 'real_time_other': 100,
555
- 'cpu_time': 10000, 'cpu_time_other': 100}],
556
- 'time_unit': 'ns',
557
- 'utest': {}
558
- },
559
- {
560
- 'name': 'BM_10PercentCPUToTime',
561
- 'label': '',
562
- 'measurements': [{'time': 0.1000, 'cpu': -0.1000,
563
- 'real_time': 100, 'real_time_other': 110,
564
- 'cpu_time': 100, 'cpu_time_other': 90}],
565
- 'time_unit': 'ns',
566
- 'utest': {}
567
- },
568
- {
569
- 'name': 'BM_ThirdFaster',
570
- 'label': '',
571
- 'measurements': [{'time': -0.3333, 'cpu': -0.3334,
572
- 'real_time': 100, 'real_time_other': 67,
573
- 'cpu_time': 100, 'cpu_time_other': 67}],
574
- 'time_unit': 'ns',
575
- 'utest': {}
576
- },
577
- {
578
- 'name': 'BM_NotBadTimeUnit',
579
- 'label': '',
580
- 'measurements': [{'time': -0.9000, 'cpu': 0.2000,
581
- 'real_time': 0.4, 'real_time_other': 0.04,
582
- 'cpu_time': 0.5, 'cpu_time_other': 0.6}],
583
- 'time_unit': 's',
584
- 'utest': {}
585
- },
586
- {
587
- 'name': 'BM_hasLabel',
588
- 'label': 'a label',
589
- 'measurements': [{'time': 0.0000, 'cpu': 0.0000,
590
- 'real_time': 1, 'real_time_other': 1,
591
- 'cpu_time': 1, 'cpu_time_other': 1}],
592
- 'time_unit': 's',
593
- 'utest': {}
594
- },
595
- {
596
- 'name': 'OVERALL_GEOMEAN',
597
- 'label': '',
598
- 'measurements': [{'real_time': 3.1622776601683826e-06, 'cpu_time': 3.2130844755623912e-06,
599
- 'real_time_other': 1.9768988699420897e-07, 'cpu_time_other': 2.397447755209533e-07,
600
- 'time': -0.8112976497120911, 'cpu': -0.7778551721181174}],
601
- 'time_unit': 's',
602
- 'run_type': 'aggregate',
603
- 'aggregate_name': 'geomean', 'utest': {}
604
- },
605
- ]
606
- self.assertEqual(len(self.json_diff_report), len(expected_output))
607
- for out, expected in zip(
608
- self.json_diff_report, expected_output):
609
- self.assertEqual(out['name'], expected['name'])
610
- self.assertEqual(out['label'], expected['label'])
611
- self.assertEqual(out['time_unit'], expected['time_unit'])
612
- assert_utest(self, out, expected)
613
- assert_measurements(self, out, expected)
614
-
615
-
616
- class TestReportDifferenceBetweenFamilies(unittest.TestCase):
617
- @classmethod
618
- def setUpClass(cls):
619
- def load_result():
620
- import json
621
- testInputs = os.path.join(
622
- os.path.dirname(
623
- os.path.realpath(__file__)),
624
- 'Inputs')
625
- testOutput = os.path.join(testInputs, 'test2_run.json')
626
- with open(testOutput, 'r') as f:
627
- json = json.load(f)
628
- return json
629
-
630
- json = load_result()
631
- json1 = filter_benchmark(json, "BM_Z.ro", ".")
632
- json2 = filter_benchmark(json, "BM_O.e", ".")
633
- cls.json_diff_report = get_difference_report(json1, json2)
634
-
635
- def test_json_diff_report_pretty_printing(self):
636
- expect_lines = [
637
- ['.', '-0.5000', '-0.5000', '10', '5', '10', '5'],
638
- ['./4', '-0.5000', '-0.5000', '40', '20', '40', '20'],
639
- ['Prefix/.', '-0.5000', '-0.5000', '20', '10', '20', '10'],
640
- ['Prefix/./3', '-0.5000', '-0.5000', '30', '15', '30', '15'],
641
- ['OVERALL_GEOMEAN', '-0.5000', '-0.5000', '0', '0', '0', '0']
642
- ]
643
- output_lines_with_header = print_difference_report(
644
- self.json_diff_report, use_color=False)
645
- output_lines = output_lines_with_header[2:]
646
- print("\n")
647
- print("\n".join(output_lines_with_header))
648
- self.assertEqual(len(output_lines), len(expect_lines))
649
- for i in range(0, len(output_lines)):
650
- parts = [x for x in output_lines[i].split(' ') if x]
651
- self.assertEqual(len(parts), 7)
652
- self.assertEqual(expect_lines[i], parts)
653
-
654
- def test_json_diff_report(self):
655
- expected_output = [
656
- {
657
- 'name': u'.',
658
- 'measurements': [{'time': -0.5, 'cpu': -0.5, 'real_time': 10, 'real_time_other': 5, 'cpu_time': 10, 'cpu_time_other': 5}],
659
- 'time_unit': 'ns',
660
- 'utest': {}
661
- },
662
- {
663
- 'name': u'./4',
664
- 'measurements': [{'time': -0.5, 'cpu': -0.5, 'real_time': 40, 'real_time_other': 20, 'cpu_time': 40, 'cpu_time_other': 20}],
665
- 'time_unit': 'ns',
666
- 'utest': {},
667
- },
668
- {
669
- 'name': u'Prefix/.',
670
- 'measurements': [{'time': -0.5, 'cpu': -0.5, 'real_time': 20, 'real_time_other': 10, 'cpu_time': 20, 'cpu_time_other': 10}],
671
- 'time_unit': 'ns',
672
- 'utest': {}
673
- },
674
- {
675
- 'name': u'Prefix/./3',
676
- 'measurements': [{'time': -0.5, 'cpu': -0.5, 'real_time': 30, 'real_time_other': 15, 'cpu_time': 30, 'cpu_time_other': 15}],
677
- 'time_unit': 'ns',
678
- 'utest': {}
679
- },
680
- {
681
- 'name': 'OVERALL_GEOMEAN',
682
- 'measurements': [{'real_time': 2.213363839400641e-08, 'cpu_time': 2.213363839400641e-08,
683
- 'real_time_other': 1.1066819197003185e-08, 'cpu_time_other': 1.1066819197003185e-08,
684
- 'time': -0.5000000000000009, 'cpu': -0.5000000000000009}],
685
- 'time_unit': 's',
686
- 'run_type': 'aggregate',
687
- 'aggregate_name': 'geomean',
688
- 'utest': {}
689
- }
690
- ]
691
- self.assertEqual(len(self.json_diff_report), len(expected_output))
692
- for out, expected in zip(
693
- self.json_diff_report, expected_output):
694
- self.assertEqual(out['name'], expected['name'])
695
- self.assertEqual(out['time_unit'], expected['time_unit'])
696
- assert_utest(self, out, expected)
697
- assert_measurements(self, out, expected)
698
-
699
-
700
- class TestReportDifferenceWithUTest(unittest.TestCase):
701
- @classmethod
702
- def setUpClass(cls):
703
- def load_results():
704
- import json
705
- testInputs = os.path.join(
706
- os.path.dirname(
707
- os.path.realpath(__file__)),
708
- 'Inputs')
709
- testOutput1 = os.path.join(testInputs, 'test3_run0.json')
710
- testOutput2 = os.path.join(testInputs, 'test3_run1.json')
711
- with open(testOutput1, 'r') as f:
712
- json1 = json.load(f)
713
- with open(testOutput2, 'r') as f:
714
- json2 = json.load(f)
715
- return json1, json2
716
-
717
- json1, json2 = load_results()
718
- cls.json_diff_report = get_difference_report(
719
- json1, json2, utest=True)
720
-
721
- def test_json_diff_report_pretty_printing(self):
722
- expect_lines = [
723
- ['BM_One', '-0.1000', '+0.1000', '10', '9', '100', '110'],
724
- ['BM_Two', '+0.1111', '-0.0111', '9', '10', '90', '89'],
725
- ['BM_Two', '-0.1250', '-0.1628', '8', '7', '86', '72'],
726
- ['BM_Two_pvalue',
727
- '1.0000',
728
- '0.6667',
729
- 'U',
730
- 'Test,',
731
- 'Repetitions:',
732
- '2',
733
- 'vs',
734
- '2.',
735
- 'WARNING:',
736
- 'Results',
737
- 'unreliable!',
738
- '9+',
739
- 'repetitions',
740
- 'recommended.'],
741
- ['short', '-0.1250', '-0.0625', '8', '7', '80', '75'],
742
- ['short', '-0.4325', '-0.1351', '8', '5', '77', '67'],
743
- ['short_pvalue',
744
- '0.7671',
745
- '0.2000',
746
- 'U',
747
- 'Test,',
748
- 'Repetitions:',
749
- '2',
750
- 'vs',
751
- '3.',
752
- 'WARNING:',
753
- 'Results',
754
- 'unreliable!',
755
- '9+',
756
- 'repetitions',
757
- 'recommended.'],
758
- ['medium', '-0.3750', '-0.3375', '8', '5', '80', '53'],
759
- ['OVERALL_GEOMEAN', '+1.6405', '-0.6985', '0', '0', '0', '0']
760
- ]
761
- output_lines_with_header = print_difference_report(
762
- self.json_diff_report, utest=True, utest_alpha=0.05, use_color=False)
763
- output_lines = output_lines_with_header[2:]
764
- print("\n")
765
- print("\n".join(output_lines_with_header))
766
- self.assertEqual(len(output_lines), len(expect_lines))
767
- for i in range(0, len(output_lines)):
768
- parts = [x for x in output_lines[i].split(' ') if x]
769
- self.assertEqual(expect_lines[i], parts)
770
-
771
- def test_json_diff_report_pretty_printing_aggregates_only(self):
772
- expect_lines = [
773
- ['BM_One', '-0.1000', '+0.1000', '10', '9', '100', '110'],
774
- ['BM_Two_pvalue',
775
- '1.0000',
776
- '0.6667',
777
- 'U',
778
- 'Test,',
779
- 'Repetitions:',
780
- '2',
781
- 'vs',
782
- '2.',
783
- 'WARNING:',
784
- 'Results',
785
- 'unreliable!',
786
- '9+',
787
- 'repetitions',
788
- 'recommended.'],
789
- ['short', '-0.1250', '-0.0625', '8', '7', '80', '75'],
790
- ['short', '-0.4325', '-0.1351', '8', '5', '77', '67'],
791
- ['short_pvalue',
792
- '0.7671',
793
- '0.2000',
794
- 'U',
795
- 'Test,',
796
- 'Repetitions:',
797
- '2',
798
- 'vs',
799
- '3.',
800
- 'WARNING:',
801
- 'Results',
802
- 'unreliable!',
803
- '9+',
804
- 'repetitions',
805
- 'recommended.'],
806
- ['OVERALL_GEOMEAN', '+1.6405', '-0.6985', '0', '0', '0', '0']
807
- ]
808
- output_lines_with_header = print_difference_report(
809
- self.json_diff_report, include_aggregates_only=True, utest=True, utest_alpha=0.05, use_color=False)
810
- output_lines = output_lines_with_header[2:]
811
- print("\n")
812
- print("\n".join(output_lines_with_header))
813
- self.assertEqual(len(output_lines), len(expect_lines))
814
- for i in range(0, len(output_lines)):
815
- parts = [x for x in output_lines[i].split(' ') if x]
816
- self.assertEqual(expect_lines[i], parts)
817
-
818
- def test_json_diff_report(self):
819
- expected_output = [
820
- {
821
- 'name': u'BM_One',
822
- 'measurements': [
823
- {'time': -0.1,
824
- 'cpu': 0.1,
825
- 'real_time': 10,
826
- 'real_time_other': 9,
827
- 'cpu_time': 100,
828
- 'cpu_time_other': 110}
829
- ],
830
- 'time_unit': 'ns',
831
- 'utest': {}
832
- },
833
- {
834
- 'name': u'BM_Two',
835
- 'measurements': [
836
- {'time': 0.1111111111111111,
837
- 'cpu': -0.011111111111111112,
838
- 'real_time': 9,
839
- 'real_time_other': 10,
840
- 'cpu_time': 90,
841
- 'cpu_time_other': 89},
842
- {'time': -0.125, 'cpu': -0.16279069767441862, 'real_time': 8,
843
- 'real_time_other': 7, 'cpu_time': 86, 'cpu_time_other': 72}
844
- ],
845
- 'time_unit': 'ns',
846
- 'utest': {
847
- 'have_optimal_repetitions': False, 'cpu_pvalue': 0.6666666666666666, 'time_pvalue': 1.0
848
- }
849
- },
850
- {
851
- 'name': u'short',
852
- 'measurements': [
853
- {'time': -0.125,
854
- 'cpu': -0.0625,
855
- 'real_time': 8,
856
- 'real_time_other': 7,
857
- 'cpu_time': 80,
858
- 'cpu_time_other': 75},
859
- {'time': -0.4325,
860
- 'cpu': -0.13506493506493514,
861
- 'real_time': 8,
862
- 'real_time_other': 4.54,
863
- 'cpu_time': 77,
864
- 'cpu_time_other': 66.6}
865
- ],
866
- 'time_unit': 'ns',
867
- 'utest': {
868
- 'have_optimal_repetitions': False, 'cpu_pvalue': 0.2, 'time_pvalue': 0.7670968684102772
869
- }
870
- },
871
- {
872
- 'name': u'medium',
873
- 'measurements': [
874
- {'time': -0.375,
875
- 'cpu': -0.3375,
876
- 'real_time': 8,
877
- 'real_time_other': 5,
878
- 'cpu_time': 80,
879
- 'cpu_time_other': 53}
880
- ],
881
- 'time_unit': 'ns',
882
- 'utest': {}
883
- },
884
- {
885
- 'name': 'OVERALL_GEOMEAN',
886
- 'measurements': [{'real_time': 8.48528137423858e-09, 'cpu_time': 8.441336246629233e-08,
887
- 'real_time_other': 2.2405267593145244e-08, 'cpu_time_other': 2.5453661413660466e-08,
888
- 'time': 1.6404861082353634, 'cpu': -0.6984640740519662}],
889
- 'time_unit': 's',
890
- 'run_type': 'aggregate',
891
- 'aggregate_name': 'geomean',
892
- 'utest': {}
893
- }
894
- ]
895
- self.assertEqual(len(self.json_diff_report), len(expected_output))
896
- for out, expected in zip(
897
- self.json_diff_report, expected_output):
898
- self.assertEqual(out['name'], expected['name'])
899
- self.assertEqual(out['time_unit'], expected['time_unit'])
900
- assert_utest(self, out, expected)
901
- assert_measurements(self, out, expected)
902
-
903
-
904
- class TestReportDifferenceWithUTestWhileDisplayingAggregatesOnly(
905
- unittest.TestCase):
906
- @classmethod
907
- def setUpClass(cls):
908
- def load_results():
909
- import json
910
- testInputs = os.path.join(
911
- os.path.dirname(
912
- os.path.realpath(__file__)),
913
- 'Inputs')
914
- testOutput1 = os.path.join(testInputs, 'test3_run0.json')
915
- testOutput2 = os.path.join(testInputs, 'test3_run1.json')
916
- with open(testOutput1, 'r') as f:
917
- json1 = json.load(f)
918
- with open(testOutput2, 'r') as f:
919
- json2 = json.load(f)
920
- return json1, json2
921
-
922
- json1, json2 = load_results()
923
- cls.json_diff_report = get_difference_report(
924
- json1, json2, utest=True)
925
-
926
- def test_json_diff_report_pretty_printing(self):
927
- expect_lines = [
928
- ['BM_One', '-0.1000', '+0.1000', '10', '9', '100', '110'],
929
- ['BM_Two', '+0.1111', '-0.0111', '9', '10', '90', '89'],
930
- ['BM_Two', '-0.1250', '-0.1628', '8', '7', '86', '72'],
931
- ['BM_Two_pvalue',
932
- '1.0000',
933
- '0.6667',
934
- 'U',
935
- 'Test,',
936
- 'Repetitions:',
937
- '2',
938
- 'vs',
939
- '2.',
940
- 'WARNING:',
941
- 'Results',
942
- 'unreliable!',
943
- '9+',
944
- 'repetitions',
945
- 'recommended.'],
946
- ['short', '-0.1250', '-0.0625', '8', '7', '80', '75'],
947
- ['short', '-0.4325', '-0.1351', '8', '5', '77', '67'],
948
- ['short_pvalue',
949
- '0.7671',
950
- '0.2000',
951
- 'U',
952
- 'Test,',
953
- 'Repetitions:',
954
- '2',
955
- 'vs',
956
- '3.',
957
- 'WARNING:',
958
- 'Results',
959
- 'unreliable!',
960
- '9+',
961
- 'repetitions',
962
- 'recommended.'],
963
- ['medium', '-0.3750', '-0.3375', '8', '5', '80', '53'],
964
- ['OVERALL_GEOMEAN', '+1.6405', '-0.6985', '0', '0', '0', '0']
965
- ]
966
- output_lines_with_header = print_difference_report(
967
- self.json_diff_report,
968
- utest=True, utest_alpha=0.05, use_color=False)
969
- output_lines = output_lines_with_header[2:]
970
- print("\n")
971
- print("\n".join(output_lines_with_header))
972
- self.assertEqual(len(output_lines), len(expect_lines))
973
- for i in range(0, len(output_lines)):
974
- parts = [x for x in output_lines[i].split(' ') if x]
975
- self.assertEqual(expect_lines[i], parts)
976
-
977
- def test_json_diff_report(self):
978
- expected_output = [
979
- {
980
- 'name': u'BM_One',
981
- 'measurements': [
982
- {'time': -0.1,
983
- 'cpu': 0.1,
984
- 'real_time': 10,
985
- 'real_time_other': 9,
986
- 'cpu_time': 100,
987
- 'cpu_time_other': 110}
988
- ],
989
- 'time_unit': 'ns',
990
- 'utest': {}
991
- },
992
- {
993
- 'name': u'BM_Two',
994
- 'measurements': [
995
- {'time': 0.1111111111111111,
996
- 'cpu': -0.011111111111111112,
997
- 'real_time': 9,
998
- 'real_time_other': 10,
999
- 'cpu_time': 90,
1000
- 'cpu_time_other': 89},
1001
- {'time': -0.125, 'cpu': -0.16279069767441862, 'real_time': 8,
1002
- 'real_time_other': 7, 'cpu_time': 86, 'cpu_time_other': 72}
1003
- ],
1004
- 'time_unit': 'ns',
1005
- 'utest': {
1006
- 'have_optimal_repetitions': False, 'cpu_pvalue': 0.6666666666666666, 'time_pvalue': 1.0
1007
- }
1008
- },
1009
- {
1010
- 'name': u'short',
1011
- 'measurements': [
1012
- {'time': -0.125,
1013
- 'cpu': -0.0625,
1014
- 'real_time': 8,
1015
- 'real_time_other': 7,
1016
- 'cpu_time': 80,
1017
- 'cpu_time_other': 75},
1018
- {'time': -0.4325,
1019
- 'cpu': -0.13506493506493514,
1020
- 'real_time': 8,
1021
- 'real_time_other': 4.54,
1022
- 'cpu_time': 77,
1023
- 'cpu_time_other': 66.6}
1024
- ],
1025
- 'time_unit': 'ns',
1026
- 'utest': {
1027
- 'have_optimal_repetitions': False, 'cpu_pvalue': 0.2, 'time_pvalue': 0.7670968684102772
1028
- }
1029
- },
1030
- {
1031
- 'name': u'medium',
1032
- 'measurements': [
1033
- {'real_time_other': 5,
1034
- 'cpu_time': 80,
1035
- 'time': -0.375,
1036
- 'real_time': 8,
1037
- 'cpu_time_other': 53,
1038
- 'cpu': -0.3375
1039
- }
1040
- ],
1041
- 'utest': {},
1042
- 'time_unit': u'ns',
1043
- 'aggregate_name': ''
1044
- },
1045
- {
1046
- 'name': 'OVERALL_GEOMEAN',
1047
- 'measurements': [{'real_time': 8.48528137423858e-09, 'cpu_time': 8.441336246629233e-08,
1048
- 'real_time_other': 2.2405267593145244e-08, 'cpu_time_other': 2.5453661413660466e-08,
1049
- 'time': 1.6404861082353634, 'cpu': -0.6984640740519662}],
1050
- 'time_unit': 's',
1051
- 'run_type': 'aggregate',
1052
- 'aggregate_name': 'geomean',
1053
- 'utest': {}
1054
- }
1055
- ]
1056
- self.assertEqual(len(self.json_diff_report), len(expected_output))
1057
- for out, expected in zip(
1058
- self.json_diff_report, expected_output):
1059
- self.assertEqual(out['name'], expected['name'])
1060
- self.assertEqual(out['time_unit'], expected['time_unit'])
1061
- assert_utest(self, out, expected)
1062
- assert_measurements(self, out, expected)
1063
-
1064
-
1065
- class TestReportDifferenceForPercentageAggregates(
1066
- unittest.TestCase):
1067
- @classmethod
1068
- def setUpClass(cls):
1069
- def load_results():
1070
- import json
1071
- testInputs = os.path.join(
1072
- os.path.dirname(
1073
- os.path.realpath(__file__)),
1074
- 'Inputs')
1075
- testOutput1 = os.path.join(testInputs, 'test4_run0.json')
1076
- testOutput2 = os.path.join(testInputs, 'test4_run1.json')
1077
- with open(testOutput1, 'r') as f:
1078
- json1 = json.load(f)
1079
- with open(testOutput2, 'r') as f:
1080
- json2 = json.load(f)
1081
- return json1, json2
1082
-
1083
- json1, json2 = load_results()
1084
- cls.json_diff_report = get_difference_report(
1085
- json1, json2, utest=True)
1086
-
1087
- def test_json_diff_report_pretty_printing(self):
1088
- expect_lines = [
1089
- ['whocares', '-0.5000', '+0.5000', '0', '0', '0', '0']
1090
- ]
1091
- output_lines_with_header = print_difference_report(
1092
- self.json_diff_report,
1093
- utest=True, utest_alpha=0.05, use_color=False)
1094
- output_lines = output_lines_with_header[2:]
1095
- print("\n")
1096
- print("\n".join(output_lines_with_header))
1097
- self.assertEqual(len(output_lines), len(expect_lines))
1098
- for i in range(0, len(output_lines)):
1099
- parts = [x for x in output_lines[i].split(' ') if x]
1100
- self.assertEqual(expect_lines[i], parts)
1101
-
1102
- def test_json_diff_report(self):
1103
- expected_output = [
1104
- {
1105
- 'name': u'whocares',
1106
- 'measurements': [
1107
- {'time': -0.5,
1108
- 'cpu': 0.5,
1109
- 'real_time': 0.01,
1110
- 'real_time_other': 0.005,
1111
- 'cpu_time': 0.10,
1112
- 'cpu_time_other': 0.15}
1113
- ],
1114
- 'time_unit': 'ns',
1115
- 'utest': {}
1116
- }
1117
- ]
1118
- self.assertEqual(len(self.json_diff_report), len(expected_output))
1119
- for out, expected in zip(
1120
- self.json_diff_report, expected_output):
1121
- self.assertEqual(out['name'], expected['name'])
1122
- self.assertEqual(out['time_unit'], expected['time_unit'])
1123
- assert_utest(self, out, expected)
1124
- assert_measurements(self, out, expected)
1125
-
1126
-
1127
- class TestReportSorting(unittest.TestCase):
1128
- @classmethod
1129
- def setUpClass(cls):
1130
- def load_result():
1131
- import json
1132
- testInputs = os.path.join(
1133
- os.path.dirname(
1134
- os.path.realpath(__file__)),
1135
- 'Inputs')
1136
- testOutput = os.path.join(testInputs, 'test4_run.json')
1137
- with open(testOutput, 'r') as f:
1138
- json = json.load(f)
1139
- return json
1140
-
1141
- cls.json = load_result()
1142
-
1143
- def test_json_diff_report_pretty_printing(self):
1144
- import util
1145
-
1146
- expected_names = [
1147
- "99 family 0 instance 0 repetition 0",
1148
- "98 family 0 instance 0 repetition 1",
1149
- "97 family 0 instance 0 aggregate",
1150
- "96 family 0 instance 1 repetition 0",
1151
- "95 family 0 instance 1 repetition 1",
1152
- "94 family 0 instance 1 aggregate",
1153
- "93 family 1 instance 0 repetition 0",
1154
- "92 family 1 instance 0 repetition 1",
1155
- "91 family 1 instance 0 aggregate",
1156
- "90 family 1 instance 1 repetition 0",
1157
- "89 family 1 instance 1 repetition 1",
1158
- "88 family 1 instance 1 aggregate"
1159
- ]
1160
-
1161
- for n in range(len(self.json['benchmarks']) ** 2):
1162
- random.shuffle(self.json['benchmarks'])
1163
- sorted_benchmarks = util.sort_benchmark_results(self.json)[
1164
- 'benchmarks']
1165
- self.assertEqual(len(expected_names), len(sorted_benchmarks))
1166
- for out, expected in zip(sorted_benchmarks, expected_names):
1167
- self.assertEqual(out['name'], expected)
1168
-
1169
-
1170
- def assert_utest(unittest_instance, lhs, rhs):
1171
- if lhs['utest']:
1172
- unittest_instance.assertAlmostEqual(
1173
- lhs['utest']['cpu_pvalue'],
1174
- rhs['utest']['cpu_pvalue'])
1175
- unittest_instance.assertAlmostEqual(
1176
- lhs['utest']['time_pvalue'],
1177
- rhs['utest']['time_pvalue'])
1178
- unittest_instance.assertEqual(
1179
- lhs['utest']['have_optimal_repetitions'],
1180
- rhs['utest']['have_optimal_repetitions'])
1181
- else:
1182
- # lhs is empty. assert if rhs is not.
1183
- unittest_instance.assertEqual(lhs['utest'], rhs['utest'])
1184
-
1185
-
1186
- def assert_measurements(unittest_instance, lhs, rhs):
1187
- for m1, m2 in zip(lhs['measurements'], rhs['measurements']):
1188
- unittest_instance.assertEqual(m1['real_time'], m2['real_time'])
1189
- unittest_instance.assertEqual(m1['cpu_time'], m2['cpu_time'])
1190
- # m1['time'] and m1['cpu'] hold values which are being calculated,
1191
- # and therefore we must use almost-equal pattern.
1192
- unittest_instance.assertAlmostEqual(m1['time'], m2['time'], places=4)
1193
- unittest_instance.assertAlmostEqual(m1['cpu'], m2['cpu'], places=4)
1194
-
1195
-
1196
- if __name__ == '__main__':
1197
- unittest.main()
1198
-
1199
- # vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4
1200
- # kate: tab-width: 4; replace-tabs on; indent-width 4; tab-indents: off;
1201
- # kate: indent-mode python; remove-trailing-spaces modified;