Can CodeGeeX 4 9B run on MacBook Pro M3 Pro 36GB?

YES — Runs Great

A74Great
Estimated from fit model

CodeGeeX 4 9B needs ~10.9 GB VRAM. MacBook Pro M3 Pro 36GB has 25.9 GB. With Q4_K_M quantization, expect ~22 tok/s.

Runtime: llama.cppCapacity: RoomyBandwidth: Very lowStack: StandardBottleneck: Memory bandwidth
Share:

Operating mode

Choose the run profile you care about

Interactive favors responsiveness, while light API and scale-out lean harder on serving readiness. The fit stays the same, but the recommendation lens changes.

Current mode

Balanced

Balanced for general local use. Keeps the ranking neutral across personal and serving workflows.

Capabilities:

Select quantization to explore

Q4_K_M (Medium quality) 10.9 GB, 21.8 tok/s, Runs well
10.9 GB required25.9 GB available
42% VRAM used

Fit status

Runs well

Decode

21.8 tok/s

TTFT

8875 ms

Safe context

131K

Memory

10.9 GB / 25.9 GB

Memory breakdown

Weights5.5 GB
KV Cache0.6 GB
Runtime0.9 GB
Headroom3.9 GB

See how fast it feels

See how fast it feelsCodeGeeX 4 9B on MacBook Pro M3 Pro 36GB
1st promptCold start — includes initialization
>Write a Python function to sort a list
Here's a Python function that sorts a list using quicksort: def quicksort(arr): if len(arr) <= 1: return arr pivot = arr[len(arr) // 2] left = [x for x in arr if x < pivot] middle = [x for x in arr if x == pivot] right = [x for x in arr if x > pivot] return quicksort(left) + middle + quicksort(right) # Example usage numbers = [3, 6, 8, 10, 1, 2, 1] print(quicksort(numbers)) # [1, 1, 2, 3, 6, 8, 10] The algorithm picks a pivot, partitions the list into smaller, equal, and larger elements, then recursively sorts each partition and concatenates the results.
2nd promptWarm — model ready, no init overhead
>Now add type hints and a docstring
def quicksort(arr: list[int]) -> list[int]: """Sort a list using the quicksort algorithm. Args: arr: List of integers to sort. Returns: A new sorted list. """ if len(arr) <= 1: return arr pivot = arr[len(arr) // 2] left = [x for x in arr if x < pivot] middle = [x for x in arr if x == pivot] right = [x for x in arr if x > pivot] return quicksort(left) + middle + quicksort(right) Added type hints for the input and return type, plus a Google-style docstring.
Estimated: 21.8 tok/s decode · 8.9s TTFT (warm) · 55 tok/s prefill

What limits this setup

This setup is broadly balanced for this model.

Shared-memory contention still exists

The OS, browser, and inference runtime all compete for the same physical memory pool, so real-world headroom is less forgiving than raw capacity suggests.

Best improvement path

Performance by workload

WorkloadGradeFitDecodeTTFTContext
ChatARuns well21.8 tok/s4841 ms131K
CodingARuns well21.8 tok/s8875 ms131K
Agentic CodingARuns well21.8 tok/s12908 ms131K
ReasoningARuns well21.8 tok/s10488 ms131K
RAGARuns well21.8 tok/s16136 ms131K

Quantization options

How CodeGeeX 4 9B (9B params) fits at each quantization level on MacBook Pro M3 Pro 36GB (25.9 GB usable).

QuantBitsVRAMQualityFit
Q2_K
2
3.5 GB
LowA72
Q3_K_S
3
4.4 GB
LowA72
NVFP4
4
5.0 GB
MediumA73
Q4_K_M
4
5.5 GB
MediumA73
Q5_K_M
5
6.5 GB
HighA74
Q6_K
6
7.4 GB
HighA74
Q8_0
8
9.6 GB
Very HighA75
F16Best for your GPU
16
18.5 GB
MaximumA77

Get started

Copy-paste commands to run CodeGeeX 4 9B on your machine.

Run

docker run --rm -it ghcr.io/ggerganov/llama.cpp:full \ --hf-repo "THUDM/codegeex4-all-9b" \ --hf-file "codegeex4-all-9b-Q4_K_M.gguf" \ -c 4096 -ngl 99

Your hardware

More models your MacBook Pro M3 Pro 36GB can run

ModelParamsGradeDecodeCapabilities
AlibabaQwen3-Coder 30B A3B Instruct30.5BS16.6 tok/s
AlibabaQwen 3.5 27B27BS7.2 tok/s
AlibabaQwen 3.6 27B27BS5.5 tok/s
AlibabaQwen 3.6 35B A3B35BA12.1 tok/s
AlibabaQwen3-VL 30B A3B Instruct30BS17.1 tok/s

Frequently asked questions

Can MacBook Pro M3 Pro 36GB run CodeGeeX 4 9B?

Yes, MacBook Pro M3 Pro 36GB can run CodeGeeX 4 9B with a A grade (Runs well). Expected decode speed: 21.8 tok/s.

How much VRAM does CodeGeeX 4 9B need?

CodeGeeX 4 9B (9B parameters) requires approximately 10.9 GB of memory with Q4_K_M quantization.

What is the best quantization for CodeGeeX 4 9B?

The recommended quantization for CodeGeeX 4 9B is Q4_K_M, which balances quality and memory efficiency.

What speed will CodeGeeX 4 9B run at on MacBook Pro M3 Pro 36GB?

On MacBook Pro M3 Pro 36GB, CodeGeeX 4 9B achieves approximately 21.8 tokens per second decode speed with a time-to-first-token of 8875ms using Q4_K_M quantization.

Can MacBook Pro M3 Pro 36GB run CodeGeeX 4 9B for coding?

For coding workloads, CodeGeeX 4 9B on MacBook Pro M3 Pro 36GB receives a A grade with 21.8 tok/s and 131K context.

What context window can CodeGeeX 4 9B use on MacBook Pro M3 Pro 36GB?

On MacBook Pro M3 Pro 36GB, CodeGeeX 4 9B can safely use up to 131K tokens of context. The model's official context limit is 131K, but available memory constrains the safe maximum.

Is unified memory on MacBook Pro M3 Pro 36GB as fast as VRAM for CodeGeeX 4 9B?

Not always. MacBook Pro M3 Pro 36GB can often fit larger models thanks to unified memory, but a discrete GPU with dedicated high-bandwidth VRAM may still decode faster once the model fits. For this combination, the important distinction is capacity versus sustained throughput.

See all results for MacBook Pro M3 Pro 36GBSee all hardware for CodeGeeX 4 9B
Embed this result

Paste this snippet into any page to show a live fit card.

<iframe src="https://willitrunai.com/embed/codegeex-4-9b-on-m3-pro-36gb" width="400" height="180" frameborder="0" style="border:none;border-radius:12px;overflow:hidden;" title="Will It Run AI — fit result"></iframe>

Preview: