Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

[Heap] Performance tweaks #78

Merged
merged 16 commits into from Aug 17, 2021
Merged

[Heap] Performance tweaks #78

merged 16 commits into from Aug 17, 2021

Conversation

lorentey
Copy link
Member

@lorentey lorentey commented Aug 7, 2021

Checklist

  • I've read the Contribution Guidelines
  • My contributions are licensed under the Swift license.
  • I've followed the coding style of the rest of the project.
  • I've added tests covering all new code paths my change adds to the project (if appropriate).
  • I've added benchmarks covering new functionality (if appropriate).
  • I've verified that my change does not break any existing tests or introduce unexplained benchmark regressions.
  • I've updated the documentation if necessary.

@lorentey
Copy link
Member Author

lorentey commented Aug 7, 2021

@swift-ci test

@AquaGeek
Copy link
Contributor

AquaGeek commented Aug 7, 2021

I'd be interested to see the performance difference here.

@lorentey lorentey changed the title [Heap] Don't always inline large functions [Heap] Performance tweaks Aug 8, 2021
@lorentey
Copy link
Member Author

lorentey commented Aug 8, 2021

Removing @inline(__always) turned out to be a significant regression. 😅This won't land as is.

I'd like to keep an eye on code size though -- always inlining large(ish) functions is generally a bad move. We'll see if followup work can make some of this work better.

@lorentey
Copy link
Member Author

lorentey commented Aug 8, 2021

The thing I'm worried about is that the sequence-based initializer, insertions, removals are currently all emitted as large monolithic functions, with no code sharing between them.

They aren't terribly large (e.g., the sequence initializer is 1200 bytes on x86_64), but they get duplicated with each specialization, and this can add up.

If we can arrange things so that the bubbleUp/Down function calls remain intact without ruining performance, then that would calm my nerves a bit. :-)

(The original link was pointing to course materials at a random university.)
`_Node` is a new struct that consists of a storage offset (the old index) along with its level in the tree. The level can be incrementally calculated, saving some time vs counting bits whenever it's needed.
Introduce `Heap._UnsafeHandle` (a thin wrapper around an unsafe buffer pointer) and rebase most heap algorithms on top of that instead of array operations.

This simplifies things by reducing (hopefully) unnecessary index validation, resulting in some measurable performance improvements.
Not inlining such a large function speeds things up by leaving some headroom for the optimizer to make better inlining decisions elsewhere. (Force inlining this resulted in the compiler not inlining the closure passed to `_update` instead, which isn't a great tradeoff.

To speed things up, mark `bubbleUp` with `@_effects(releasenone)`. This may be questionable (because it calls `Element.<`), but it results in better codegen, making `insert` match the performance of `std::priority_queue`.
@lorentey
Copy link
Member Author

@swift-ci test

@lorentey
Copy link
Member Author

Benchmark progression:

chart

chart

chart

chart

chart

chart

@lorentey
Copy link
Member Author

@swift-ci test

@lorentey
Copy link
Member Author

This gets us to ~parity with std::priority_queue, even slightly beating it on large heaps. We still have a slight disadvantage at small sizes, though. (apple/swift#38867 might help close that gap.)

01 initializers

02 insert

03 pop

@lorentey
Copy link
Member Author

Cc @AquaGeek

Most of these are dirty tricks that reduce code readability (with the possible exception of _Node), but they are probably worth it for the performance boost.

The addition of the @_effects attributes isn't entirely justified; if we have to take those out, then that will impact insert quite a bit. 🤔

@hassila
Copy link
Contributor

hassila commented Aug 13, 2021

Looks like interesting progress - just one thought, wouldn’t it make sense to use e.g https://github.com/skarupke/heap as the reference for the heap performance rather than the std-prioq? (And compare the actual PriorityQueue with the std-prioq).

@xwu
Copy link
Contributor

xwu commented Aug 13, 2021

Seems 891eb7a: _Node is a straight-up win in performance over the original, and the rest speed up some and regress some here and there.

@lorentey
Copy link
Member Author

just one thought, wouldn’t it make sense to use e.g https://github.com/skarupke/heap as the reference for the heap performance rather than the std-prioq? (And compare the actual PriorityQueue with the std-prioq).

std::priority_queue implements a heap, closely matching our Heap (although one-sided) -- I think the comparison against it is fair (although these are never really apple-to-apples comparisons). The PriorityQueue concept doesn't directly exist in the STL, although (depending on the internal impl) I expect std::priority_queue with a custom comparator would still serve as a useful baseline for it.

std::priority_queue being one-sided does not make it a bad baseline -- it solves a simpler problem than Heap, but our hypothesis was that min-max heaps will provide matching or better performance anyway.

It would be interesting to see benchmarks against @skarupke's implementation! I'll see if I have time to run some experiments over the weekend. 🤔 We won't add those benchmarks to this repository though.

Another interesting source of data structure implementations would be LLVM's ADT library.

I don't think we need to add an extensive library of reference benchmarks though -- verifying against some plausible baseline is useful during the initial implementation effort, but afterwards I believe we should be primarily comparing potential changes against earlier versions of this package, not against other languages.

@lorentey
Copy link
Member Author

One thing that we still need to address is that the code does not currently implement the optimization techniques that make https://github.com/skarupke/heap fast. We need to reorder comparisons in the grandchild min/max search, and use a more clever heapify loop.

@lorentey
Copy link
Member Author

lorentey commented Aug 14, 2021

The results above were collected on a 5-years old MacBook Pro. M1 results below!

The insert benchmark results are significantly different on M1 -- for insertions on M1, 6822d83 was an even more significant regression, not an improvement. This may be related to apple/swift#38867, although I expected swift_retain/relase would be less costly on the M1, not more. More analysis is needed.

chart

chart

chart

chart

chart

chart

Versus baselines:

01 initializers

02 insert

03 pop

@karwa
Copy link

karwa commented Aug 14, 2021

Drive-by comment:

Have you tried using a ContiguousArray for Heap._storage? It may help reduce code size, as regular Array needs to account for potential bridged storage. There may be places where the compiler can’t prove it isn’t bridged.

If you need it as an Array elsewhere, constructing an Array from a ContiguousArray is basically free. It just retains the existing storage, it doesn’t copy.

@lorentey
Copy link
Member Author

Oh yeah, that's a good suggestion; OrderedSet does the same. It shouldn't* have an effect on the current benchmarks, as Element is always Int and Array<Int> is statically known to never be verbatim-bridged -- but I expect there would be a benefit for class-keyed heaps.

* Although ContinuousArray sometimes misses some of the optimization love that Array gets, so it could be slower sometimes -- for instance, I forgot to apply apple/swift#38867 to ContiguousArray just now. 🤦

This improves popMin/popMax (and the sequence initializer) by reviewing trickleDown and optimizing things:

- Replace swapAt with a scheme where we keep a hold in the storage buffer
- Slightly shorten min/max dependency chain in primary sink loop

In exchange, we get even less readable code.
@lorentey
Copy link
Member Author

lorentey commented Aug 17, 2021

c4282ca improves popMin/popMax (and the sequence initializer) by reviewing trickleDown and optimizing things:

  • Replace swapAt with a scheme where we keep a hole in the storage buffer
  • Slightly shorten min/max dependency chain in primary sink loop

In exchange, we get even less readable code.

M1 benchmarks:

chart

chart

chart

chart

chart

chart

@lorentey
Copy link
Member Author

@swift-ci test

This reintroduces retain/release operations for the empty array until apple/swift#38898 lands.

Mitigate the performance costs of this by refactoring code to reduce the size of the inlined bubbleUpMin/Max invocations.
@lorentey
Copy link
Member Author

OK, I'm happy with where we are now. I think insert could probably be improved if we could maintain a hole in the storage array rather than swapping things in it -- but that would need an append variant of Array.init(uninitializedCapacity:initializingWith:) so that's for later.

Final measurements with a toolchain that includes apple/swift#38867 & apple/swift#38898: (taken on a Mac Pro this time)

01 Heap Int  init from range

02 Heap Int  init from buffer

03 Heap Int  popMin

04 Heap Int  popMax

05 Heap Int  insert(contentsOf:)

06 Heap Int  insert

@lorentey
Copy link
Member Author

@swift-ci test

@lorentey lorentey merged commit cd33954 into apple:main Aug 17, 2021
@compnerd
Copy link
Contributor

compnerd added a commit to compnerd/swift-collections that referenced this pull request Aug 18, 2021
Update source list of priority queue implementation after apple#78
@compnerd compnerd mentioned this pull request Aug 18, 2021
7 tasks
kylemacomber pushed a commit that referenced this pull request Aug 18, 2021
Update source list of priority queue implementation after #78
@lorentey lorentey added the Heap Min-max heap module label Nov 16, 2022
cgrindel-self-hosted-renovate bot added a commit to cgrindel/rules_swift_package_manager that referenced this pull request Feb 8, 2024
…v1.1.0 (#906)

This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
|
[com_github_apple_swift_collections](https://togithub.com/apple/swift-collections)
| http_archive | minor | `1.0.6` -> `1.1.0` |

---

### Release Notes

<details>
<summary>apple/swift-collections
(com_github_apple_swift_collections)</summary>

###
[`v1.1.0`](https://togithub.com/apple/swift-collections/releases/tag/1.1.0):
Swift Collections 1.1.0

[Compare
Source](https://togithub.com/apple/swift-collections/compare/1.0.6...1.1.0)

This feature release adds a number of new data structure
implementations, along with minor changes to existing constructs.

##### New Data Structures

- `Heap` implements a min-max heap, backed by a native array.
(Contributed by [@&#8203;AquaGeek](https://togithub.com/AquaGeek))
- `BitSet` and `BitArray` are two alternate representations of a bitmap
type, backed by dynamically allocated storage. (Contributed by
[@&#8203;MahanazAtiqullah](https://togithub.com/MahanazAtiqullah))
- `TreeSet` and `TreeDictionary` are hashed collections implementing
Compressed Hash-Array Mapped Prefix Trees (CHAMP). They provide similar
API as `Set`/`Dictionary` in the Standard Library, but as persistent
data structures, supporting incremental mutations of shared instances
and efficient structural diffing. (Contributed by
[@&#8203;msteindorfer](https://togithub.com/msteindorfer))

##### Other Changes

- This version of the package can only be built using Swift 5.7 or
later.
- New methods: the `OrderedSet.isEqualSet` family of functions provide a
way to test that two containers contain the same members, ignoring the
order of elements.
([apple/swift-collections#183,
[apple/swift-collections#234)
- New method: `OrderedSet.filter` implements a version of the standard
filter operation that returns an `OrderedSet` instead of an `Array`.
([apple/swift-collections#159)
- `debugDescription` implementations have been updated to follow Swift
best practice. (These are called by container types like `Array` to
print their elements, so they work best when they're succinct variants
of `description` that are suitable for embedding in structured output:
specifically, they must not produce unpaired delimiter characters
(`[`/`]`, `(`/`)`, `{`/`}`, `<`/`>` etc), raw top level commas,
semicolons, colons, unquoted strings etc. `debugDescription` should not
needlessly print type names etc.)

##### New Contributors

- [@&#8203;AquaGeek](https://togithub.com/AquaGeek) made their first
contribution in
[apple/swift-collections#61
- [@&#8203;ejmarchant](https://togithub.com/ejmarchant) made their first
contribution in
[apple/swift-collections#82
- [@&#8203;just-gull](https://togithub.com/just-gull) made their first
contribution in
[apple/swift-collections#115
- [@&#8203;jPaolantonio](https://togithub.com/jPaolantonio) made their
first contribution in
[apple/swift-collections#121
- [@&#8203;MahanazAtiqullah](https://togithub.com/MahanazAtiqullah) made
their first contribution in
[apple/swift-collections#83
- [@&#8203;hectormatos2011](https://togithub.com/hectormatos2011) made
their first contribution in
[apple/swift-collections#155
- [@&#8203;ktoso](https://togithub.com/ktoso) made their first
contribution in
[apple/swift-collections#159
- [@&#8203;CTMacUser](https://togithub.com/CTMacUser) made their first
contribution in
[apple/swift-collections#116
- [@&#8203;hassila](https://togithub.com/hassila) made their first
contribution in
[apple/swift-collections#297

Many thanks to our contributors for their great work (and patience)!

##### List of Pull Requests

**Full Changelog**:
apple/swift-collections@1.0.6...1.1.0

- Add a min-max heap implementation that can be used to back a priority
queue by [@&#8203;AquaGeek](https://togithub.com/AquaGeek) in
[apple/swift-collections#61
- \[benchmark] Review and extend Heap benchmarks by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#76
- Add reference benchmarks for bit vector implementations by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#79
- Fix Markdown link in README by
[@&#8203;AquaGeek](https://togithub.com/AquaGeek) in
[apple/swift-collections#77
- Fix documentation for types conforming to ExpressibleByArrayLiteral o…
by [@&#8203;ejmarchant](https://togithub.com/ejmarchant) in
[apple/swift-collections#82
- \[Heap] Performance tweaks by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#78
- Fix typos: missing subscript parameters by
[@&#8203;ejmarchant](https://togithub.com/ejmarchant) in
[apple/swift-collections#81
- \[Heap] Update implementation details section in docs by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#84
- Update CMakeLists.txt by
[@&#8203;compnerd](https://togithub.com/compnerd) in
[apple/swift-collections#85
- Stop depending on swift-collections-benchmark by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#86
- \[OrderedDictionary] modifyValue → updateValue by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#91
- Add Benchmarks package to workspace by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#93
- \[OrderedDictionary] Deprecate `subscript(offset:)` for now by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#92
- Documentation: Remove in-place mutation comments by
[@&#8203;ejmarchant](https://togithub.com/ejmarchant) in
[apple/swift-collections#96
- \[main] Freeze some types for consistency with their inlinable
initializers by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#98
- Follow stdlib's leading underscore rule by
[@&#8203;ejmarchant](https://togithub.com/ejmarchant) in
[apple/swift-collections#95
- \[Heap] Disable heap tests in release builds by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#100
- \[NFC] Merge release/1.0 to main by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#105
- Merge `release/1.0` into `main` by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#108
- \[README] Note that `Heap` hasn't been tagged yet & list other
enhancements in progress by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#109
- PriorityQueueModule: remove `import Foundation` by
[@&#8203;compnerd](https://togithub.com/compnerd) in
[apple/swift-collections#118
- \[Heap] Remove Heap's `ascending` and `descending` views by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#119
- \[Heap] Enable heap tests in optimized builds
([#&#8203;101](https://togithub.com/apple/swift-collections/issues/101))
by [@&#8203;just-gull](https://togithub.com/just-gull) in
[apple/swift-collections#115
- Update CMakeLists.txt by
[@&#8203;compnerd](https://togithub.com/compnerd) in
[apple/swift-collections#122
- Fix link to package internal documentation by
[@&#8203;jPaolantonio](https://togithub.com/jPaolantonio) in
[apple/swift-collections#121
- Merge release/1.0 to main by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#130
- BitArray and BitSet data structures by
[@&#8203;MahanazAtiqullah](https://togithub.com/MahanazAtiqullah) in
[apple/swift-collections#83
- Sorted collections by [@&#8203;vihanb](https://togithub.com/vihanb) in
[apple/swift-collections#65
- Merge `release/1.0` to `main` by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#141
- Remove Swift PM Artifacts to avoid Generated Schemes in Xcode by
[@&#8203;hectormatos2011](https://togithub.com/hectormatos2011) in
[apple/swift-collections#155
- Reinstate custom schemes under Utils/swift-collections.xcworkspace by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#156
- \+OrderedSet add filter
[#&#8203;158](https://togithub.com/apple/swift-collections/issues/158)
by [@&#8203;ktoso](https://togithub.com/ktoso) in
[apple/swift-collections#159
- \[Xcode] Update schemes & file template by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#161
- \[OrderedCollection] Use standard temp allocation facility, if
available by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#160
- \[OrderedSet] Work around weird name lookup issue in compiler by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#162
- \=OrderedSet.filter Attempt to optimize filter impl by
[@&#8203;ktoso](https://togithub.com/ktoso) in
[apple/swift-collections#163
- Force-inline \_modify accessors to work around a performance issue by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#165
- Merge release/1.0 branch to main by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#172
- Incubate persistent data structures by
[@&#8203;msteindorfer](https://togithub.com/msteindorfer) in
[apple/swift-collections#31
- Persistent collections updates by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#174
- Persistent collections updates by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#175
- Persistent collections updates (part 3) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#176
- Persistent collections updates (part 4) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#177
- \[OrderedDictionary] Tiny documentation fix by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#178
- Persistent collections updates (part 5) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#179
- Integrate PriorityQueueModule, BitCollections, PersistentCollections,
SortedCollections into release/1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#181
- Persistent collections updates (part 6) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#180
- Persistent collections updates (part 7) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#182
- \[BitSet] Fix decoding format on 32 bit architectures by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#185
- Persistent collections updates (part 8) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#184
- Persistent collections updates (part 9) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#188
- Add Sendable conformances to all public types by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#191
- \[test] Check baseline API expectations for set-like types by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#192
- Fleshing out `PersistentSet` by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#193
- Rename `PriorityQueueModule` to `HeapModule` by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#194
- \[BitSet] Fix invariant violation in member subscript by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#195
- \[1.1.0] Bump minimum required Swift toolchain to 5.5 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#196
- Restore support for building with Swift 5.5 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#198
- Merge release/1.0 to release/1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#199
- Update CMake configuration in preparation for 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#200
- Update CMakeLists.txt by
[@&#8203;compnerd](https://togithub.com/compnerd) in
[apple/swift-collections#202
- \[1.1]\[SortedCollections] Remove for now by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#205
- \[Heap] Change value of minimum or maximum element by
[@&#8203;CTMacUser](https://togithub.com/CTMacUser) in
[apple/swift-collections#116
- \[Heap] Prerelease preparations by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#210
- Update README files by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#212
- \[manifest] Exclude CMakeLists.txt; remove unnecessary path settings;
reindent file by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#213
- Review and finalize (?) set relation predicates for 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#216
- Merge.1.0→1.1 by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#217
- Update CMake configuration by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#218
- Cherry pick changes from main to release/1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#219
- Fix unusual build problems by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#221
- Review & update descriptions throughout the package by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#222
- Review and finalize (?) binary set operations for 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#223
- \[Xcode] Disable implicit dependencies by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#227
- \[OrderedSet] Improve sequence-taking initializer by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#226
- \[OrderedSet, BitSet] Fix custom mirror display style by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#225
- Finalize persistent collections API by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#224
- Start working on DocC support by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#228
- Update CMake build configuration by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#230
- \[PersistentSet] Iterator.next(): Make inlinable by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#233
- \[SetAlgebra types] isEqual(to:) → isEqualSet(to:) by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#234
- \[PersistentCollections] Doc & benchmark updates in preparation of API
review by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#235
- Apply changes from in-progress review thread by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#237
- \[ShareableHashedCollections] API Review: add missing `mutating`
keywords by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#238
- \[Benchmarks] Split default huge library up into individual files, one
per type by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#240
- \[ShareableHashedCollections] Add missing import by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#243
- Unify unsafe bit set implementations by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#244
- Fix warnings in development versions of Swift by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#245
- \[HashTreeCollections] Change prefix `Shareable` to `Tree` by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#242
- \[TreeDictionary] Fix in-place merge operation to properly update the
count by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#247
- \[cmake] Update CMake configuration by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#249
- Add not so experimental rope implementation by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#264
- Fix off by one error in BitSet by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#267
- Monomodule support by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#266
- Expose a handful of BigString.Index methods by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#269
- BitArray API refinements & additions by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#263
- Make most of Rope inlinable by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#270
- BigString: Fix String.Index.\_knownScalarAligned by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#272
- Rope: Fix `Sendable` conformance by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#271
- Require Swift 5.6 by [@&#8203;lorentey](https://togithub.com/lorentey)
in
[apple/swift-collections#273
- \[OrderedDictionary] Explicitly mention in documentation that
keys/values are ordered by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#275
- \[HashCollections] Ensure `self` doesn’t get destroyed before we’re
done working with it by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#276
- Remove obsolete swift(>=5.5)/swift(>=5.6) checks by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#277
- \[Xcode] Update Xcode project by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#278
- Minor rope updates by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#279
- \[Rope] remove(at:): Fix assertion when removing the last item creates
a deficiency by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#280
- Merge changes from release 1.0 to release 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#283
- \[CollectionUtilities] Silence a warning on 32 bit platforms by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#286
- \[BitSet] Fix a thinko in BitSet.isEqualSet by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#287
- Grab bag of fixes for small test issues by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#288
- \[Xcode] Set a code sign identity in the Xcode project by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#285
- Rope: Fix trap when replaceSubrange is called on an empty rope by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#290
- `Rope.find` returns a bogus remainder for the end position by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#291
- Update TreeSet.md by [@&#8203;hassila](https://togithub.com/hassila)
in
[apple/swift-collections#297
- Fix CustomStringConvertible/CustomDebugStringConvertible conformances
by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#302
- \[RopeModule] Fix issues in Swift's ABI stable dialect by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#318
- \[CMake, Xcode] Update configurations for alternate build systems by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#319
- \[RopeModule] Remove unnecessary typealiases by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#320
- \[Heap] Improve type-level doc comment by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#326
- \[Heap] insert(contentsOf:) Switch to Floyd’s if we’re inserting too
many items by [@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#327
- \[1.1] build: support building in Debug mode on Windows by
[@&#8203;compnerd](https://togithub.com/compnerd) in
[apple/swift-collections#336
- Merge release/1.0 to release/1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#348
- \[Heap] Convert min() and max() to properties by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#328
- \[BitArray] Disable bitwise operators for now by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#353
- \[Heap] Final(?) Heap API adjustments for 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#354
- \[Benchmarks] Add Collection Equality Benchmarks by
[@&#8203;vanvoorden](https://togithub.com/vanvoorden) in
[apple/swift-collections#351
- Release preparations for 1.1 by
[@&#8203;lorentey](https://togithub.com/lorentey) in
[apple/swift-collections#355
- \[1.1] Fix typos by [@&#8203;lorentey](https://togithub.com/lorentey)
in
[apple/swift-collections#357
- \[TreeDictionary]\[Keys] Add Equatable and Hashable Conformance to
TreeDictionary.Keys by
[@&#8203;vanvoorden](https://togithub.com/vanvoorden) in
[apple/swift-collections#352

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR is behind base branch, or you tick the
rebase/retry checkbox.

👻 **Immortal**: This PR will be recreated if closed unmerged. Get
[config help](https://togithub.com/renovatebot/renovate/discussions) if
that's undesired.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNi4xMDAuMCIsInVwZGF0ZWRJblZlciI6IjM2LjEwMC4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9-->

Co-authored-by: Self-hosted Renovate Bot <361546+cgrindel-self-hosted-renovate[bot]@users.noreply.github.enterprise.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Heap Min-max heap module
Projects
None yet
6 participants