SwiftCollections 1.0.0
dotnet add package SwiftCollections --version 1.0.0
NuGet\Install-Package SwiftCollections -Version 1.0.0
<PackageReference Include="SwiftCollections" Version="1.0.0" />
paket add SwiftCollections --version 1.0.0
#r "nuget: SwiftCollections, 1.0.0"
// Install SwiftCollections as a Cake Addin #addin nuget:?package=SwiftCollections&version=1.0.0 // Install SwiftCollections as a Cake Tool #tool nuget:?package=SwiftCollections&version=1.0.0
SwiftCollections
SwiftCollections is a high-performance, memory-efficient library of collections designed for game development, simulations, and other performance-critical applications.
๐ ๏ธ Key Features
- Optimized for Performance: Designed for low time complexity and minimal memory allocations.
- Versatile Use Cases: Suitable for data structures in 3D environments and complex spatial queries.
- Unity-Compatible: Fully functional within Unity's ecosystem.
- Customizable: Use pre-built implementations or extend functionality with custom interfaces.
๐ Installation
Clone the repository and add it to your project:
Non-Unity Projects
Install via NuGet:
Add SwiftCollections to your project using the following command:
dotnet add package SwiftCollections
Or Download/Clone:
Clone the repository or download the source code.
git clone https://github.com/mrdav30/SwiftCollections.git
Add to Project:
- Include the
SwiftCollections
project or its DLLs in your build process.
- Include the
Unity
To integrate SwiftCollections into your Unity project:
Download the Package:
- Obtain the latest
SwiftCollections{{VERSION}}.unitypackage
from the Releases section of the repository.
- Obtain the latest
Import into Unity:
- In Unity, navigate to Assets > Import Package > Custom Package....
- Select the downloaded
SwiftCollections{{VERSION}}.unitypackage
file.
Verify the Integration:
- After importing, confirm that the
SwiftCollections
namespace is accessible in your scripts.
- After importing, confirm that the
๐ฆ Library Overview
Core Data Structures
- SwiftDictionary: A high-performance dictionary optimized for O(1) operations and minimal memory usage.
- SwiftBiDictionary: A bidirectional dictionary for efficient forward and reverse lookups in O(1).
- SwiftHashSet: An optimized set for unique values with fast operations.
- SwiftBucket: High-performance collection for O(1) addition and removal with stable indexing.
- SwiftQueue: Circular-buffer-based queue for ultra-low-latency operations.
- SwiftList: A dynamic list optimized for speed-critical applications.
- SwiftSortedList: Dynamically sorted collection with O(log n) operations.
- SwiftStack: Fast array-based stack with O(1) operations.
- SwiftArray2D / SwiftArray3D: Efficient, flat-mapped arrays for 2D and 3D data.
- SwiftBVH: A Bounding Volume Hierarchy optimized for spatial queries.
Pools
- SwiftObjectPool: Thread-safe generic object pooling for improved memory usage and performance.
- SwiftArrayPool: Array-specific pool for efficient reuse of arrays.
- SwiftCollectionPool: Pool for reusable collection instances (e.g., List, HashSet).
Spatial Data Structures
- SwiftBVH: Bounding Volume Hierarchy for efficient spatial queries.
Observable Collections
- ObservableArray / ObservableSwiftList / ObservableDictionary: Reactive, observable collections with property and collection change notifications.
๐ Usage Examples
SwiftBVH for Spatial Queries
var bvh = new SwiftBVH<int>(100);
var volume = new BoundingVolume(new Vector3(0, 0, 0), new Vector3(1, 1, 1));
bvh.Insert(1, volume);
var results = new List<int>();
bvh.Query(new BoundingVolume(new Vector3(0, 0, 0), new Vector3(2, 2, 2)), results);
Console.WriteLine(results.Count); // Output: 1
SwiftArray2D
var array2D = new Array2D<int>(10, 10);
array2D[3, 4] = 42;
Console.WriteLine(array2D[3, 4]); // Output: 42
SwiftQueue
var queue = new SwiftQueue<int>(10);
queue.Enqueue(5);
Console.WriteLine(queue.Dequeue()); // Output: 5
Populating Arrays
var array = new int[10].Populate(() => new Random().Next(1, 100));
๐งช Testing and Validation
SwiftCollections includes a comprehensive suite of xUnit tests for validation.
Running Unit Tests
To execute all unit tests, use the following command:
dotnet test -c debug
Running Benchmarks
The library includes benchmarks to measure the performance of its collections. Benchmarks are powered by BenchmarkDotNet and can be run as follows:
Open the SwiftCollections.Benchmarks project.
Modify the Program.cs file to select the desired benchmark. Uncomment the relevant BenchmarkRunner lines.
- Example Program.cs setup:
using BenchmarkDotNet.Running;
namespace SwiftCollections.Benchmarks
{
class Program
{
static void Main(string[] args)
{
// Uncomment the benchmark you want to run:
// var ListIntegerBenchmarksSummary = BenchmarkRunner.Run<ListIntegerBenchmarks>();
var StackIntegerBenchmarksSummary = BenchmarkRunner.Run<StackIntegerBenchmarks>();
// var DictionaryStringBenchmarksSummary = BenchmarkRunner.Run<DictionaryStringBenchmarks>();
}
}
}
- Build and run the project. The results will be displayed in the console and saved to a results file for further analysis.
๐ ๏ธ Compatibility
Frameworks: .NET Framework 4.7.2+, .NET Core, Unity 2020+
Query Collections Precision: Supports both System.Numerics and FixedMathSharp.
๐ License
This project is licensed under the MIT License - see the LICENSE
file
for details.
๐ฅ Contributors
- mrdav30 - Lead Developer
- Contributions are welcome! Feel free to submit pull requests or report issues.
๐ง Contact
For questions or support, reach out to mrdav30 via GitHub or open an issue in the repository.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net48 is compatible. net481 was computed. |
-
.NETFramework 4.8
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.0 | 73 | 1/2/2025 |