SwiftCollections 1.0.0

dotnet add package SwiftCollections --version 1.0.0                
NuGet\Install-Package SwiftCollections -Version 1.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SwiftCollections" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SwiftCollections --version 1.0.0                
#r "nuget: SwiftCollections, 1.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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 Icon

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

  1. Install via NuGet:

    • Add SwiftCollections to your project using the following command:

      dotnet add package SwiftCollections
      
  2. Or Download/Clone:

    • Clone the repository or download the source code.

      git clone https://github.com/mrdav30/SwiftCollections.git
      
  3. Add to Project:

    • Include the SwiftCollections project or its DLLs in your build process.

Unity

To integrate SwiftCollections into your Unity project:

  1. Download the Package:

    • Obtain the latest SwiftCollections{{VERSION}}.unitypackage from the Releases section of the repository.
  2. Import into Unity:

    • In Unity, navigate to Assets > Import Package > Custom Package....
    • Select the downloaded SwiftCollections{{VERSION}}.unitypackage file.
  3. Verify the Integration:

    • After importing, confirm that the SwiftCollections namespace is accessible in your scripts.

๐Ÿ“ฆ 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:

  1. Open the SwiftCollections.Benchmarks project.

  2. 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>();
        }
    }
}
  1. 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 Compatible and additional computed target framework versions.
.NET Framework net48 is compatible.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .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