ktsu.Containers
1.0.5
Prefix Reserved
dotnet add package ktsu.Containers --version 1.0.5
NuGet\Install-Package ktsu.Containers -Version 1.0.5
<PackageReference Include="ktsu.Containers" Version="1.0.5" />
<PackageVersion Include="ktsu.Containers" Version="1.0.5" />
<PackageReference Include="ktsu.Containers" />
paket add ktsu.Containers --version 1.0.5
#r "nuget: ktsu.Containers, 1.0.5"
#addin nuget:?package=ktsu.Containers&version=1.0.5
#tool nuget:?package=ktsu.Containers&version=1.0.5
ktsu.Containers
A high-performance collection library for .NET providing specialized container implementations with focus on performance, memory efficiency, and developer experience.
🚀 Features
- OrderedCollection<T>: Maintains elements in sorted order with efficient binary search operations
- OrderedSet<T>: Unique elements maintained in sorted order with full ISet<T> support
- RingBuffer<T>: Fixed-size circular buffer optimized for streaming data scenarios
- Comprehensive Benchmarking: World-class performance validation against .NET collections
📦 Collections
OrderedCollection<T>
A collection that maintains elements in sorted order with efficient insertion and search operations.
Key Features:
- O(log n) insertion maintaining sort order
- O(log n) search operations via binary search
- Multiple constructors with capacity and comparer support
- Implements ICollection<T>, IReadOnlyCollection<T>, IReadOnlyList<T>
Best Use Cases:
- Incremental sorted data building
- Frequent search operations on ordered data
- Scenarios requiring both order and random access
OrderedSet<T>
A set implementation that maintains unique elements in sorted order.
Key Features:
- O(log n) Add/Remove/Contains operations
- Full ISet<T> interface support (Union, Intersection, Except, etc.)
- Sorted enumeration without additional sorting cost
- Memory-efficient list-based implementation
Best Use Cases:
- Unique sorted collections
- Set operations with maintained order
- Mathematical set operations with sorted results
RingBuffer<T>
A fixed-size circular buffer optimized for continuous data streams.
Key Features:
- O(1) insertion and access operations
- Automatic wrapping when capacity is reached
- Index-based access to buffer elements
- Resizing and resampling capabilities
- Power-of-two sizing for optimal performance
Best Use Cases:
- Streaming data processing
- Fixed-size caches
- Sliding window algorithms
- Audio/signal processing buffers
🏆 Performance & Benchmarking
We've implemented a comprehensive benchmarking system using BenchmarkDotNet that validates our implementations against standard .NET collections.
Benchmark Categories
🎯 Container-Specific Benchmarks
- OrderedCollection vs List<T> + Sort vs SortedList<T>
- OrderedSet vs HashSet<T> vs SortedSet<T>
- RingBuffer vs Queue<T> vs List<T> with size limiting
📊 Standard Collection Baselines
Performance baselines for all major .NET collections:
- List<T>, HashSet<T>, SortedSet<T>
- Dictionary<TKey,TValue>, SortedDictionary<TKey,TValue>
- Queue<T>, Stack<T>
- ConcurrentDictionary<TKey,TValue>, ConcurrentQueue<T>
🔄 Cross-Collection Comparisons
Direct comparisons for common scenarios:
- Building ordered collections (incremental vs bulk)
- Set operations across different implementations
- Memory efficiency patterns
- Real-world usage workflows
📈 Performance Analysis
Advanced scenarios including:
- Scalability testing (1K to 100K+ elements)
- Edge cases and worst-case scenarios
- Memory pressure analysis
- Specialized use cases (sliding windows, priority queues)
Running Benchmarks
Quick Start
# Fast development feedback
.\scripts\run-benchmarks.ps1 -Target Quick
# Compare specific containers
.\scripts\run-benchmarks.ps1 -Target OrderedSet -Export Html
# Cross-collection analysis
.\scripts\run-benchmarks.ps1 -Target CrossComparison -Export All
# Full benchmark suite
.\scripts\run-benchmarks.ps1 -Target All -Export Html
Available Targets
Target | Description |
---|---|
Quick |
Fast subset for development feedback |
OrderedCollection |
OrderedCollection<T> vs alternatives |
OrderedSet |
OrderedSet<T> vs alternatives |
RingBuffer |
RingBuffer<T> vs alternatives |
Standard |
Built-in .NET collection baselines |
CrossComparison |
Direct cross-collection comparisons |
PerformanceAnalysis |
Scalability and edge case analysis |
All |
Complete benchmark suite |
Command Line Options
# Manual benchmark execution
dotnet run --project Containers.Benchmarks --configuration Release
# Filtered benchmarks
dotnet run --project Containers.Benchmarks --configuration Release -- --filter "*Add*"
# Export results
dotnet run --project Containers.Benchmarks --configuration Release -- --exporters html,csv,json
📋 Installation
<PackageReference Include="ktsu.Containers" Version="1.0.0" />
🔧 Usage Examples
OrderedCollection<T>
// Create and populate
var collection = new OrderedCollection<int>();
collection.Add(3);
collection.Add(1);
collection.Add(2);
// Collection automatically maintains order: [1, 2, 3]
// Efficient search
bool contains = collection.Contains(2); // O(log n) binary search
// Access by index
int first = collection[0]; // 1
OrderedSet<T>
// Create with initial data
var set = new OrderedSet<int> { 3, 1, 4, 1, 5 };
// Set contains unique elements in order: [1, 3, 4, 5]
// Set operations
var other = new OrderedSet<int> { 4, 5, 6 };
set.UnionWith(other); // [1, 3, 4, 5, 6]
RingBuffer<T>
// Create fixed-size buffer
var buffer = new RingBuffer<int>(3);
buffer.PushBack(1);
buffer.PushBack(2);
buffer.PushBack(3);
buffer.PushBack(4); // Overwrites first element
// Buffer contains: [2, 3, 4]
// Index access
int latest = buffer[buffer.Count - 1]; // 4 (most recent)
🛠️ Development
Building
dotnet build
Testing
dotnet test
Benchmarking
# Quick performance check
.\scripts\run-benchmarks.ps1 -Target Quick
# Comprehensive analysis
.\scripts\run-benchmarks.ps1 -Target All -Export Html
📊 Performance Characteristics
OrderedCollection<T>
- ✅ Excellent for: Incremental sorted insertions, frequent searches
- ⚠️ Consider alternatives for: Large bulk operations (List<T> + Sort may be faster)
- 🎯 Sweet spot: 100-10,000 elements with mixed insert/search operations
OrderedSet<T>
- ✅ Excellent for: Unique sorted collections, set operations with order
- ⚠️ Consider alternatives for: Pure membership testing (HashSet<T> is faster)
- 🎯 Sweet spot: Mathematical set operations requiring sorted results
RingBuffer<T>
- ✅ Excellent for: Streaming data, fixed-size caches, sliding windows
- ⚠️ Consider alternatives for: Dynamic growth requirements
- 🎯 Sweet spot: Continuous data streams with occasional random access
🤝 Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add comprehensive tests
- Run benchmarks to validate performance
- Submit a pull request
Adding New Containers
When adding new containers:
- Implement the container in
Containers/
- Add comprehensive tests in
Containers.Test/
- Create benchmark comparisons in
Containers.Benchmarks/
- Update documentation
📝 License
Licensed under the MIT License. See LICENSE.md for details.
🏗️ Architecture
The library is built with performance and reliability in mind:
- Zero-allocation operations where possible
- Power-of-two sizing for optimal memory access patterns
- Binary search algorithms for O(log n) performance
- Comprehensive test coverage ensuring reliability
- Benchmark-driven development validating performance claims
🎯 Design Principles
- Performance First: Every operation is optimized for speed and memory efficiency
- Standard Compliance: Full compatibility with .NET collection interfaces
- Predictable Behavior: Clear performance characteristics and edge case handling
- Developer Experience: Intuitive APIs with comprehensive documentation
- Validation: Extensive testing and benchmarking ensures reliability
This library provides high-performance alternatives to standard .NET collections while maintaining familiar APIs and adding specialized functionality for common use cases.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net9.0
- No dependencies.
NuGet packages (1)
Showing the top 1 NuGet packages that depend on ktsu.Containers:
Package | Downloads |
---|---|
Containers.Benchmarks
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.5 | 219 | 6/13/2025 |
1.0.4 | 219 | 6/13/2025 |
1.0.3 | 236 | 6/13/2025 |
1.0.2 | 255 | 6/13/2025 |
1.0.2-pre.2 | 111 | 5/20/2025 |
1.0.2-pre.1 | 118 | 5/18/2025 |
1.0.1 | 106 | 5/17/2025 |
1.0.0 | 108 | 5/17/2025 |
## v1.0.5 (patch)
Changes since v1.0.4:
- Add script to automate winget manifest updates ([@matt-edmondson](https://github.com/matt-edmondson))
## v1.0.4 (patch)
Changes since v1.0.3:
- Update project configuration and dependencies ([@matt-edmondson](https://github.com/matt-edmondson))
## v1.0.3 (patch)
Changes since v1.0.2:
- Enhance ktsu.Containers with new benchmarks and tests ([@matt-edmondson](https://github.com/matt-edmondson))
- Fix IDE0052 errors by removing unused private members in derived cursor rules ([@matt-edmondson](https://github.com/matt-edmondson))
- Add new collection types and update documentation ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor RingBuffer to improve efficiency and documentation ([@matt-edmondson](https://github.com/matt-edmondson))
- Add OrderedMap and its benchmarks to ktsu.Containers ([@matt-edmondson](https://github.com/matt-edmondson))
- Fix compilation errors in ContiguousSetBenchmarks and improve collection initialization ([@matt-edmondson](https://github.com/matt-edmondson))
- Fix compilation errors and improve tests in collection classes ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor collection classes to use properties for Count ([@matt-edmondson](https://github.com/matt-edmondson))
- Implement equality logic and XML documentation for ContiguousMap.Entry ([@matt-edmondson](https://github.com/matt-edmondson))
- Add OrderedSet and benchmarking framework for ktsu.Containers ([@matt-edmondson](https://github.com/matt-edmondson))
## v1.0.2 (patch)
Changes since v1.0.1:
- Add configuration files and implement new features ([@matt-edmondson](https://github.com/matt-edmondson))
## v1.0.2-pre.2 (prerelease)
Changes since v1.0.2-pre.1:
- Sync .gitattributes ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Sync scripts\PSBuild.psm1 ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Sync .gitignore ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Sync .editorconfig ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Sync .mailmap ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Sync .runsettings ([@ktsu[bot]](https://github.com/ktsu[bot]))
- Merge remote-tracking branch 'refs/remotes/origin/main' ([@ktsu[bot]](https://github.com/ktsu[bot]))
## v1.0.2-pre.1 (prerelease)
Incremental prerelease update.
## v1.0.1 (patch)
Changes since v1.0.0:
- Add Clear method to RingBuffer and update documentation ([@matt-edmondson](https://github.com/matt-edmondson))
## v1.0.0 (major)
- Remove locking to simplify, I can make a concurrent one if I need that ([@matt-edmondson](https://github.com/matt-edmondson))
- Code chaneg to force a build ([@matt-edmondson](https://github.com/matt-edmondson))
- Improve tag handling in Get-VersionInfoFromGit function ([@matt-edmondson](https://github.com/matt-edmondson))
- Reset licence file ([@matt-edmondson](https://github.com/matt-edmondson))
- Initial Commit ([@matt-edmondson](https://github.com/matt-edmondson))
- Update SDK versions and enhance documentation tags ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor locking mechanism in RingBuffer class ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor PSBuild.psm1 to improve array handling ([@matt-edmondson](https://github.com/matt-edmondson))
- Enhance documentation and update project files ([@matt-edmondson](https://github.com/matt-edmondson))
- Rename from collections to containers, and implement standard interfaces ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor tag handling and error management in PSBuild.psm1 ([@matt-edmondson](https://github.com/matt-edmondson))
- Enhance versioning logic in PSBuild.psm1 ([@matt-edmondson](https://github.com/matt-edmondson))
- Add tests and constructors for RingBuffer functionality ([@matt-edmondson](https://github.com/matt-edmondson))
- Refactor RingBuffer class and add unit tests ([@matt-edmondson](https://github.com/matt-edmondson))
- Rename library from ktsu.Collections to ktsu.Containers ([@matt-edmondson](https://github.com/matt-edmondson))