Beim Erstellen von Anwendungen ist die Auswahl der richtigen Tools von entscheidender Bedeutung. Sie wünschen sich hohe Leistung, einfache Entwicklung und nahtlose plattformübergreifende Bereitstellung. Beliebte Frameworks bieten Kompromisse:
Aber hier ist der Haken: Den meisten Frameworks mangelt es an robuster Unterstützung für natives maschinelles Lernen (ML). Diese Lücke besteht, weil diese Frameworks vor dem KI-Boom entstanden sind. Die Frage lautet:
Wie können wir ML effizient in Anwendungen integrieren?
Gängige Lösungen wie ONNX Runtime ermöglichen den Export von ML-Modellen für die Anwendungsintegration, sind jedoch nicht für CPUs optimiert oder flexibel genug für verallgemeinerte Algorithmen.
Geben Sie JAX ein, eine Python-Bibliothek, die:
In diesem Artikel zeigen wir Ihnen, wie Sie:
JAX ist wie NumPy auf Steroiden. Es handelt sich um eine von Google entwickelte Low-Level-Hochleistungsbibliothek, die ML zugänglich und dennoch leistungsstark macht.
Hier ist ein Beispiel zum Vergleich von NumPy und JAX:
# NumPy version import numpy as np def assign_numpy(): a = np.empty(1000000) a[:] = 1 return a # JAX version import jax.numpy as jnp import jax @jax.jit def assign_jax(): a = jnp.empty(1000000) return a.at[:].set(1)
Benchmarking in Google Colab zeigt den Leistungsvorsprung von JAX:
Diese Flexibilität und Geschwindigkeit machen JAX ideal für Produktionsumgebungen, in denen Leistung entscheidend ist.
JAX übersetzt Python-Code in HLO-Spezifikationen (High-Level Optimizer), die mit C XLA-Bibliotheken kompiliert und ausgeführt werden können. Dies ermöglicht:
Schreiben Sie Ihre JAX-Funktion und exportieren Sie ihre HLO-Darstellung. Zum Beispiel:
# NumPy version import numpy as np def assign_numpy(): a = np.empty(1000000) a[:] = 1 return a # JAX version import jax.numpy as jnp import jax @jax.jit def assign_jax(): a = jnp.empty(1000000) return a.at[:].set(1)
Um das HLO zu generieren, verwenden Sie das Skript jax_to_ir.py aus dem JAX-Repository:
import jax.numpy as jnp def fn(x, y, z): return jnp.dot(x, y) / z
Platzieren Sie die resultierenden Dateien (fn_hlo.txt und fn_hlo.pb) im Assets-Verzeichnis Ihrer App.
Klonen Sie das JAX-Repository und navigieren Sie zu jax/examples/jax_cpp.
python jax_to_ir.py \ --fn jax_example.prog.fn \ --input_shapes '[("x", "f32[2,2]"), ("y", "f32[2,2")]' \ --constants '{"z": 2.0}' \ --ir_format HLO \ --ir_human_dest /tmp/fn_hlo.txt \ --ir_dest /tmp/fn_hlo.pb
#ifndef MAIN_H #define MAIN_H extern "C" { int bar(int foo); } #endif
Mit Bazel kompilieren:
cc_shared_library( name = "jax", deps = [":main"], visibility = ["//visibility:public"], )
Sie finden die kompilierte libjax.dylib im Ausgabeverzeichnis.
Verwenden Sie das FFI-Paket von Dart, um mit der C-Bibliothek zu kommunizieren. Erstellen Sie eine jax.dart-Datei:
bazel build examples/jax_cpp:jax
Fügen Sie die dynamische Bibliothek in Ihr Projektverzeichnis ein. Testen Sie es mit:
import 'dart:ffi'; import 'package:dynamic_library/dynamic_library.dart'; typedef FooCFunc = Int32 Function(Int32 bar); typedef FooDartFunc = int Function(int bar); class JAX { late final DynamicLibrary dylib; JAX() { dylib = loadDynamicLibrary(libraryName: 'jax'); } Function get _bar => dylib.lookupFunction<FooCFunc, FooDartFunc>('bar'); int bar(int foo) { return _bar(foo); } }
Sie sehen die Ausgabe der C-Bibliothek in Ihrer Konsole.
Mit diesem Setup können Sie:
Mögliche Anwendungsfälle sind:
JAX schließt die Lücke zwischen Python-basierter Entwicklung und Leistung auf Produktionsebene und ermöglicht es ML-Ingenieuren, sich auf Algorithmen zu konzentrieren, ohne sich um Low-Level-C-Code kümmern zu müssen.
Wir bauen eine hochmoderne KI-Plattform mit unbegrenzten Chat-Tokens und Langzeitspeicher auf, um nahtlose, kontextbezogene Interaktionen zu gewährleisten, die sich im Laufe der Zeit weiterentwickeln.
Es ist völlig kostenlos und Sie können es auch in Ihrer aktuellen IDE ausprobieren.
Das obige ist der detaillierte Inhalt vonAusführen eines JAX-Programms von Dart mit C FFI. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!