Skip to content

Latest commit

 

History

History
77 lines (56 loc) · 4.39 KB

README.md

File metadata and controls

77 lines (56 loc) · 4.39 KB

Introduction to MLX for Swift developers

This introduction was created for my talk at the NSBarcelona meetup at Glovo on 5 November 2024.

Advantages of MLX

  • Optimized for unified memory on Apple silicon
  • Closely follows NumPy and PyTorch APIs
  • Has a Swift API, allowing apps using MLX to be compiled for macOS, iOS, and visionOS
  • Easier to work with the latest open-source models compared to Core ML
    • Core ML uses the Neural Engine in addition to the GPU and CPU. MLX doesn't use the Neural Engine due to its constraints.
  • Open source and evolving quickly with the field

General introductions to deep learning

  • The fast.ai course is a great introduction to deep learning that starts from a high level and progressively delves into lower-level concepts.
  • I also highly recommend François Chollet's Deep Learning with Python (second edition currently available, third edition forthcoming in spring 2025).

Converting and quantizing models

New models generally get converted to MLX and quantized within hours of their release. You can find them in the MLX Community on Hugging Face. If you need to convert and/or quantize a model, I've included an example notebook in this repository.

Porting MLX implementations from Python to Swift

New models are generally first implemented in MLX in the Python repositories listed below. The MLX maintainers and the community then port these models to Swift. You can follow the progress and contribute to these efforts on GitHub.

Claude 3.5 Sonnet has knowledge about MLX and generally does a good job of porting Python MLX code to Swift when provided with existing examples in both languages. Minor corrections may be necessary, since there are some small differences between the Python and Swift MLX APIs.

Tools and examples

Projects using MLX

People to follow on 𝕏

Call to action for Swift developers

Contribute to mlx-swift-examples and swift-transformers to help bring these tools and examples up to par with their Python equivalents.