This guide is adapted from this original post by Christopher Charles.
- Clone the MLX Swift Examples GitHub repository:
git clone [email protected]:ml-explore/mlx-swift-examples.git
- Open XCode and click "Open Existing Project".
- Navigate to the path that you cloned
mlx-swift-examples
and open the filemlx-swift-examples.xcodeproj
- From XCode, select the
LLMEval
example application (see screenshot)
data:image/s3,"s3://crabby-images/93e68/93e68d8bab620452c1c69ef5f365436b7468b80f" alt="choose llm eval app"
- Click on the
mlx-swift-examples
project in Xcode’s Project Navigator (left sidebar). - Choose the
LLMEval
target under the “Targets” section. - Select the Signing & Capabilities tab (see screenshot).
- Under
Team
choose the Apple Developer account to use for code signing. For this you need an Apple Developer account.
data:image/s3,"s3://crabby-images/d862a/d862ae6d91e9f751ba413e404f08d69e6cddb494" alt="set developer team"
The LLMEval
app uses two extra capabilities. These should already be enabled, but you can verify this in the Signing & Capabilities:
- Outgoing Connections (Client) to allow the app to download models from Hugging Face.
- The Increased Memory Limit entitlement (on supported devices and OS versions) which is useful for larger models.
- Press "⌘+⌥+r" (command + option + r) to edit the build scheme
- Select the "Info" tab
- Select "Release" for the "Build configuration" (see screenshot)
data:image/s3,"s3://crabby-images/408ad/408adb58a75d79ca633d3f7e64b7a4e03d233ab2" alt="select release mode for build"
For example to build on an iPhone:
- Plug your iPhone into your Mac via USB (or be on the same Wi-Fi network with wireless debugging enabled).
- In the Xcode toolbar (top) select your iPhone from the device list (screenshot):
data:image/s3,"s3://crabby-images/2c0ab/2c0abb17b70eabc142a0e827acea6c6256daadd0" alt="select iphone for destination"
-
Press Cmd + R (or click the play button) to build and install
LLMEval
on your device. -
You may be prompted to put your device in developer mode if this is your first time building an App for it. See these instructions.
-
You may be prompted to "Verify that the Developer App certificate for your account is trusted on your device". Follow the instructions in the prompt.
-
Open the App
-
Wait for the model to download. If you haven't used the model yet, then
LLMEval
will download it. This can take a while. -
Enter a prompt to generate text on the device in the app’s UI.
By default, ModelConfiguration.phi4bit
is used (see ContentView.swift
). You can try other models in LLMModelFactory.swift
. Just ensure the chosen model architecture and your device’s memory constraints are compatible.
See the mlx-swift-examples documentation for more information on adding and using models.
Entitlements / Code Signing: If you get build errors about code signing or entitlements, double-check that:
- You’ve selected your Team.
- Outgoing network connections are enabled.
- Increased memory entitlement is enabled, if you need it.
Model Size & Crashes: Large models might cause crashes if your device does not have enough memory. Try a smaller or more quantized model. Visit the MLX Community on Hugging Face to see many more MLX-compatible models.