Hiperspace.Rocks
2.5.26
Prefix Reserved
See the version list below for details.
dotnet add package Hiperspace.Rocks --version 2.5.26
NuGet\Install-Package Hiperspace.Rocks -Version 2.5.26
<PackageReference Include="Hiperspace.Rocks" Version="2.5.26" />
<PackageVersion Include="Hiperspace.Rocks" Version="2.5.26" />
<PackageReference Include="Hiperspace.Rocks" />
paket add Hiperspace.Rocks --version 2.5.26
#r "nuget: Hiperspace.Rocks, 2.5.26"
#:package Hiperspace.Rocks@2.5.26
#addin nuget:?package=Hiperspace.Rocks&version=2.5.26
#tool nuget:?package=Hiperspace.Rocks&version=2.5.26
Hiperspace.Rocks
RocksDB is a remarkable technology, originally developed by Google (LevelDB) and optimized by Facebook for
absolutely lowest possible latency writing to SSD devices.
RocksDB used Log-structured-Merge (LSM) to stream updates while maintaining fast key access.
It is used both as a key/value database, and also as a driver for relational-databases, message-stores,
blockchain and various analytical services. The use of LSM optimizes performance and life of SSD devices.
Hiperspace.Rocks uses RockDB to store elements in durable SSD memory
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. 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 is compatible. 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. |
-
net10.0
- Hiperspace (>= 2.5.26)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.56)
- RocksDB (>= 10.4.2.62659)
- System.Numerics.Tensors (>= 10.0.1)
-
net8.0
- Hiperspace (>= 2.5.26)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.56)
- RocksDB (>= 10.4.2.62659)
- System.Numerics.Tensors (>= 10.0.1)
-
net9.0
- Hiperspace (>= 2.5.26)
- Microsoft.Bcl.HashCode (>= 6.0.0)
- protobuf-net.Core (>= 3.2.56)
- RocksDB (>= 10.4.2.62659)
- System.Numerics.Tensors (>= 10.0.1)
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 |
|---|---|---|
| 2.5.35 | 42 | 2/27/2026 |
| 2.5.33 | 94 | 2/14/2026 |
| 2.5.32 | 96 | 1/30/2026 |
| 2.5.29 | 97 | 1/17/2026 |
| 2.5.28 | 102 | 12/31/2025 |
| 2.5.26 | 182 | 12/21/2025 |
| 2.5.21 | 435 | 12/10/2025 |
| 2.5.18 | 669 | 12/3/2025 |
| 2.5.13 | 205 | 11/24/2025 |
| 2.5.8 | 188 | 11/15/2025 |
| 2.5.2 | 223 | 11/6/2025 |
| 2.5.0 | 206 | 10/20/2025 |
| 2.4.6 | 211 | 9/23/2025 |
| 2.4.4 | 293 | 8/7/2025 |
| 2.4.2 | 181 | 7/28/2025 |
| 2.4.0 | 211 | 7/10/2025 |
| 2.3.8 | 210 | 7/1/2025 |
| 2.3.7 | 208 | 6/18/2025 |
| 2.3.3 | 211 | 6/5/2025 |
| 2.2.2 | 233 | 5/5/2025 |
https://www.cepheis.com/hiperspace/20251221
# Overview
Change method signatures for Path functions to use Route instead of RouteMap for remote calls.
Add Session2 to Subspace to support time-travel sessions over a graph space to support partial refresh of GPU cache for GPU parallel search of Graph methods without the need for recursive cycle detection.
-----
## Sequence support
Sequence numbers are a relational database feature that has largely been replaced been replaced by [UUID](https://en.wikipedia.org/wiki/Universally_unique_identifier) (*especially v7*) since they do not require a sequence source and can be allocated within a client, but they still have a use as an alternate key especially with [GPGPU](https://en.wikipedia.org/wiki/General-purpose_computing_on_graphics_processing_units) that need primitive points, *but do not wish to use the expense of mapping UUID to int128 values that may not be supported by the device*
**Hiperspace** implements *sequences* as unsigned 64-bit integers (*1 to 18,446,744,073,709,551,616*), and can be stored for any *element* key value
### Hiperspace
Added `UseSequenceAsync()` for driver implementation, together with proxy methods in {`BrowserSpace, FailoverSpace, GenerationSpace, PartitionSpace, SessionSpace`}
### Hiperspace.Heap
Implemented `UseSequenceAsync()` in `Hiperspace.Heap` and added additional driver `CacheHeapSpace` for use by caches that do not require history to be maintained for elements. **CacheHeapSpace** should *only* be used by *caches* since it lacks the ability to reconcile concurrent changes through version inspection.
`LatestSpace` is replaced by `CacheHeapSpace` and will be removed in a future release.
### Hiperspace.Rocks
Implemented UseSequenceAsync()` in `Hiperspace.Rocks` and added additional driver `CacheRockSpace` for use by caches that do not require history to be maintained for elements. **CacheRockSpace** should *only* be used by *caches* since it lacks the ability to reconcile concurrent changes through version inspection.
The underlying RocksDB driver has been updated.
### SubSpace
`SubSpace` forwards the `UseSequenceAsync()` function to the underlying driver
### SetSpace
Added two functions to get a sequence counter from the driver:
* `GetSequenceAsync<TEntity>(TEntity? element)` to get the current sequence number associated with the domain key
* `UseSequenceAsync<TEntity>(TEntity? element)` to get a new sequence number for the with the domain key
**NB** While the main use of Sequence numbers is to provide an alternate (*GPGPU friendly*) sequence number for a `Node`, it can be applied to any key value.
```
// get an order number that is unique within all orders
var orderNo = await space.Orders.UseSequenceAsync (new Order { });
// get a line number within the owning Order {1,2,3..}
var lineNo = await space.Lines.UseSequenceAsync (new Line { Order = order });
```
-----
### HiLang
Added code generation for the SubSpace methods.
-----
## OnInitialized
Addition of `virtual void OnInitialized()` function to SubSpace to allow domian subspaces to perform additional initialization after the Domain Space has been created by a generic container (e.g. **Hiperspace.DB**)