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: Mon, 13 Oct 2025 10:27:24 UTC
Version: Ark v0.5.3-dev
Go version: 1.25.1
CPU: AMD EPYC 7763 64-Core Processor

Query

Operation Time Remark
Query.Next 0.3 ns
Query.Next + Query.Get 1 1.3 ns
Query.Next + Query.Get 2 1.6 ns
Query.Next + Query.Get 5 3.5 ns
Query.Next + Query.Entity 1.2 ns
Query.Next + Query.Relation 1.6 ns
Filter1.Query + Query1.Close 35.3 ns
Filter1.Query + Query1.Close 37.1 ns registered filter

World access

Operation Time Remark
World.Alive 0.9 ns random, 1000 entities
Map.Get 2.6 ns random, 1000 entities
Map.GetUnchecked 2.1 ns random, 1000 entities
Map.Has 2.1 ns random, 1000 entities
Map.HasUnchecked 1.5 ns random, 1000 entities
Map5.Get 5 10.5 ns random, 1000 entities
Map5.HasAll 5 5.7 ns random, 1000 entities
Map.GetRelation 2.6 ns random, 1000 entities
Map.GetRelationUnchecked 2.1 ns random, 1000 entities

Entities

Operation Time Remark
Entity.IsZero 0.3 ns
World.NewEntity 15.4 ns memory already alloc.
Map1.NewEntityFn w/ 1 Comp 32.9 ns memory already alloc.
Map5.NewEntityFn w/ 5 Comps 48.3 ns memory already alloc.
Map1.NewEntity w/ 1 Comp 40.5 ns memory already alloc.
Map5.NewEntity w/ 5 Comps 61.3 ns memory already alloc.
World.RemoveEntity 28.2 ns
World.RemoveEntity w/ 1 Comp 35.8 ns
World.RemoveEntity w/ 5 Comps 62.8 ns

Entities, batched

Operation Time Remark
World.NewEntities 9.2 ns 1000, memory already alloc.
Map1.NewBatchFn w/ 1 Comp 9.2 ns 1000, memory already alloc.
Map5.NewBatchFn w/ 5 Comps 9.1 ns 1000, memory already alloc.
World.RemoveEntities 5.6 ns 1000
World.RemoveEntities w/ 1 Comp 5.8 ns 1000
World.RemoveEntities w/ 5 Comps 6.9 ns 1000

Components

Operation Time Remark
Map1.AddFn 1 Comp 40.2 ns memory already alloc.
Map5.AddFn 5 Comps 56.0 ns memory already alloc.
Map1.AddFn 1 to 5 Comps 107.7 ns memory already alloc.
Map1.Add 1 Comp 45.6 ns memory already alloc.
Map5.Add 5 Comps 69.6 ns memory already alloc.
Map1.Add 1 to 5 Comps 117.1 ns memory already alloc.
Map1.Remove 1 Comp 44.2 ns memory already alloc.
Map5.Remove 5 Comps 87.3 ns memory already alloc.
Map1.Remove 1 of 5 Comps 97.2 ns memory already alloc.
Exchange1.ExchangeFn 1 Comp 53.8 ns memory already alloc.
Exchange1.ExchangeFn 1 of 5 Comps 109.4 ns memory already alloc.
Exchange1.Exchange 1 Comp 62.1 ns memory already alloc.
Exchange1.Exchange 1 of 5 Comps 118.8 ns memory already alloc.

Components, batched

Operation Time Remark
Map1.AddBatchFn 1 Comp 5.0 ns 1000, memory already alloc.
Map5.AddBatchFn 5 Comps 4.6 ns 1000, memory already alloc.
Map1.AddBatchFn 1 to 5 Comps 7.8 ns 1000, memory already alloc.
Map1.RemoveBatch 1 Comp 5.2 ns 1000, memory already alloc.
Map5.RemoveBatch 5 Comps 6.4 ns 1000, memory already alloc.
Map1.RemoveBatch 1 of 5 Comps 7.6 ns 1000, memory already alloc.
Exchange1.ExchangeBatchFn 1 Comp 5.1 ns 1000, memory already alloc.
Exchange1.ExchangeBatchFn 1 of 5 Comps 7.8 ns 1000, memory already alloc.

Other

Operation Time Remark
ecs.NewWorld 16.6 μs
World.Reset 80.8 ns empty world
ecs.ComponentID 19.1 ns component already registered