Ark
Benchmarks

Benchmarks

This chapter gives an overview of the runtime cost of typical Ark operations. All time information is per entity. All components used in the benchmarks have two int64 fields. Batch operations are performed in batches of 1000 entities.

Benchmark code: benchmark/table in the GitHub repository.

Benchmarks are run automatically in the GitHub CI, and are updated on this page on every merge into the main branch. They always reflect the latest development state of Ark.

For comparative benchmarks of different Go ECS implementations, see the go-ecs-benchmarks repository.


Last run: Tue, 19 May 2026 12:47:44 UTC
Version: Ark v0.8.2
Go version: 1.26.2
CPU: AMD EPYC 9V74 80-Core Processor

Query

Operation Time Remark
Query.Next 0.7 ns
Query.Next + Query.Get 1 1.1 ns
Query.Next + Query.Get 2 1.4 ns
Query.Next + Query.Get 5 2.8 ns
Query.Next + Query.Entity 1.2 ns
Query.Next + Query.Relation 1.8 ns
Pos/Vel Next/Get 2.1 ns iter entities
Pos/Vel NextTable/GetColumns 0.8 ns iter tables, w/ nested loop
Filter1.Query + Query1.Close 38.1 ns
Filter1.Query + Query1.Close 38.5 ns registered filter

World access

Operation Time Remark
World.Alive 0.7 ns random, 1000 entities
Map.Get 2.5 ns random, 1000 entities
Map.GetUnchecked 1.9 ns random, 1000 entities
Map.Has 2.0 ns random, 1000 entities
Map.HasUnchecked 1.5 ns random, 1000 entities
Map5.Get 5 9.0 ns random, 1000 entities
Map5.HasAll 5 6.0 ns random, 1000 entities
Map.GetRelation 2.8 ns random, 1000 entities
Map.GetRelationUnchecked 2.3 ns random, 1000 entities

Entities

Operation Time Remark
Entity.IsZero 0.2 ns
World.NewEntity 16.2 ns memory already alloc.
Map1.NewEntityFn w/ 1 Comp 34.8 ns memory already alloc.
Map5.NewEntityFn w/ 5 Comps 48.6 ns memory already alloc.
Map1.NewEntity w/ 1 Comp 52.3 ns memory already alloc.
Map5.NewEntity w/ 5 Comps 65.9 ns memory already alloc.
World.RemoveEntity 30.8 ns
World.RemoveEntity w/ 1 Comp 35.8 ns
World.RemoveEntity w/ 5 Comps 59.9 ns

Entities, batched

Operation Time Remark
World.NewEntities 11.1 ns 1000, memory already alloc.
Map1.NewBatchFn w/ 1 Comp 10.9 ns 1000, memory already alloc.
Map5.NewBatchFn w/ 5 Comps 10.7 ns 1000, memory already alloc.
World.RemoveEntities 4.9 ns 1000
World.RemoveEntities w/ 1 Comp 5.1 ns 1000
World.RemoveEntities w/ 5 Comps 5.9 ns 1000

Components

Operation Time Remark
Map1.AddFn 1 Comp 43.7 ns memory already alloc.
Map5.AddFn 5 Comps 66.6 ns memory already alloc.
Map1.AddFn 1 to 5 Comps 104.6 ns memory already alloc.
Map1.Add 1 Comp 46.2 ns memory already alloc.
Map5.Add 5 Comps 77.0 ns memory already alloc.
Map1.Add 1 to 5 Comps 112.9 ns memory already alloc.
Map1.Remove 1 Comp 44.5 ns memory already alloc.
Map5.Remove 5 Comps 88.9 ns memory already alloc.
Map1.Remove 1 of 5 Comps 95.8 ns memory already alloc.
Exchange1.ExchangeFn 1 Comp 59.4 ns memory already alloc.
Exchange1.ExchangeFn 1 of 5 Comps 108.4 ns memory already alloc.
Exchange1.Exchange 1 Comp 65.2 ns memory already alloc.
Exchange1.Exchange 1 of 5 Comps 116.5 ns memory already alloc.

Components, batched

Operation Time Remark
Map1.AddBatchFn 1 Comp 3.7 ns 1000, memory already alloc.
Map5.AddBatchFn 5 Comps 3.8 ns 1000, memory already alloc.
Map1.AddBatchFn 1 to 5 Comps 7.7 ns 1000, memory already alloc.
Map1.RemoveBatch 1 Comp 4.2 ns 1000, memory already alloc.
Map5.RemoveBatch 5 Comps 5.2 ns 1000, memory already alloc.
Map1.RemoveBatch 1 of 5 Comps 7.0 ns 1000, memory already alloc.
Exchange1.ExchangeBatchFn 1 Comp 4.1 ns 1000, memory already alloc.
Exchange1.ExchangeBatchFn 1 of 5 Comps 6.8 ns 1000, memory already alloc.

Other

Operation Time Remark
ecs.NewWorld 18.5 μs
World.Reset 66.6 ns empty world
ecs.ComponentID 18.7 ns component already registered