Files
metabuilder/mojo/samples/examples/life/benchmark.mojo
T
git 83f1533bce feat(mojo): integrate Modular Mojo compiler implementation
Extracted from modular repo and reorganized:

Compiler Implementation:
- 21 compiler source files (frontend, semantic, IR, codegen, runtime)
- 15 comprehensive test files (lexer, parser, type checker, backend, etc.)
- 9 compiler usage example programs

Architecture (5 phases):
- Frontend: Lexer, parser, AST generation (lexer.mojo, parser.mojo, ast.mojo)
- Semantic: Type system, checking, symbol resolution (3 files)
- IR: MLIR code generation (mlir_gen.mojo, mojo_dialect.mojo)
- Codegen: LLVM backend, optimization passes (llvm_backend.mojo, optimizer.mojo)
- Runtime: Memory mgmt, reflection, async support (3 files)

File Organization:
- mojo/compiler/src/: Compiler implementation (21 files, 952K)
- mojo/compiler/tests/: Test suite (15 files)
- mojo/compiler/examples/: Usage examples (9 files)
- mojo/samples/: Mojo language examples (37 files, moved from examples/)

Documentation:
- mojo/CLAUDE.md: Project-level guide
- mojo/compiler/CLAUDE.md: Detailed architecture documentation
- mojo/compiler/README.md: Quick start guide
- mojo/samples/README.md: Example programs guide

Status:
- Compiler architecture complete (Phase 4)
- Full test coverage included
- Ready for continued development and integration

Files tracked:
- 45 new compiler files (21 src + 15 tests + 9 examples)
- 1 moved existing directory (examples → samples)
- 3 documentation files created
- 1 root CLAUDE.md updated

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-01-23 19:05:44 +00:00

81 lines
2.3 KiB
Mojo

# ===----------------------------------------------------------------------=== #
# Copyright (c) 2025, Modular Inc. All rights reserved.
#
# Licensed under the Apache License v2.0 with LLVM Exceptions:
# https://llvm.org/LICENSE.txt
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ===----------------------------------------------------------------------=== #
from time import perf_counter_ns
import gridv1
import gridv2
import gridv3
def main():
comptime warmup_iterations = 10
comptime benchmark_iterations = 1000
comptime rows = 1024
comptime cols = 1024
# Initial state
gridv1 = gridv1.Grid.random(rows, cols, seed=42)
gridv2 = gridv2.Grid[rows, cols].random(seed=42)
gridv3 = gridv3.Grid[rows, cols].random(seed=42)
# Warm up
warmv1 = gridv1.copy()
for _ in range(warmup_iterations):
warmv1 = warmv1.evolve()
warmv2 = gridv2.copy()
for _ in range(warmup_iterations):
warmv2 = warmv2.evolve()
warmv3 = gridv3.copy()
for _ in range(warmup_iterations):
warmv3 = warmv3.evolve()
# Benchmark
start_time = perf_counter_ns()
for _ in range(benchmark_iterations):
gridv1 = gridv1.evolve()
stop_time = perf_counter_ns()
elapsed = round(Float64(stop_time - start_time) / 1e6, 3)
print(
benchmark_iterations,
"evolutions of gridv1.Grid elapsed time: ",
elapsed,
"ms",
)
start_time = perf_counter_ns()
for _ in range(benchmark_iterations):
gridv2 = gridv2.evolve()
stop_time = perf_counter_ns()
elapsed = round(Float64(stop_time - start_time) / 1e6, 3)
print(
benchmark_iterations,
"evolutions of gridv2.Grid elapsed time: ",
elapsed,
"ms",
)
start_time = perf_counter_ns()
for _ in range(benchmark_iterations):
gridv3 = gridv3.evolve()
stop_time = perf_counter_ns()
elapsed = round(Float64(stop_time - start_time) / 1e6, 3)
print(
benchmark_iterations,
"evolutions of gridv3.Grid elapsed time: ",
elapsed,
"ms",
)