react-native-transformers 的安装和配置教程
项目基础介绍
react-native-transformers 是一个开源项目,它允许开发者直接在 React Native 和 Expo 应用程序中运行 Hugging Face 的变压器模型,实现设备端推理。这意味着应用程序可以在不发送数据到外部服务器的情况下生成文本、回答问题以及处理语言,从而提高隐私保护、减少延迟,并支持离线功能。
该项目主要使用 JavaScript 编程语言,并依赖于 React Native 和 ONNX Runtime。
项目使用的关键技术和框架
- React Native:一个用于构建原生移动应用的 JavaScript 框架。
- ONNX Runtime:一个高性能的跨平台机器学习推理引擎,用于在移动设备上执行模型。
- Hugging Face Transformers:一个提供预训练变压器模型和模型托管的平台。
安装和配置准备工作
在开始安装 react-native-transformers 之前,请确保您已经准备好了以下环境:
- Node.js 和 npm:用于安装项目依赖。
- React Native 开发环境:包括 React Native CLI 或 Expo。
- 对于 React Native CLI 项目,确保您已经链接了必要的原生模块。
安装步骤
1. 安装依赖
首先,您需要安装 onnxruntime-react-native 的 peer dependencies:
npm install onnxruntime-react-native
然后,安装 react-native-transformers:
对于 React Native 项目:
npm install react-native-transformers
对于 Expo 项目:
npx expo install react-native-transformers
2. 平台配置
对于 React Native CLI 项目,您需要链接 onnxruntime-react-native 库:
npx react-native link onnxruntime-react-native
对于 Expo 项目,您需要在 app.json 或 app.config.js 中添加 Expo 插件配置:
{
"expo": {
"plugins": [
"onnxruntime-react-native"
]
}
}
3. Babel 配置
添加 babel-plugin-transform-import-meta 插件到您的 Babel 配置中:
// babel.config.js
module.exports = {
// ...您现有的配置
plugins: [
// ...您现有的插件
"babel-plugin-transform-import-meta"
]
};
之后,运行以下命令来清除 Metro bundler 缓存:
npx expo start --clear
4. 开发环境设置
由于 ONNX Runtime 和 react-native-transformers 包含原生代码,开发测试时需要使用开发客户端而不是 Expo Go。
您可以使用以下方法之一设置开发客户端:
- EAS Development Build:使用 EAS Build 创建自定义开发客户端。
- Expo Prebuild:弹出为裸机工作流以访问原生代码。
按照这些步骤操作后,您就可以开始使用 react-native-transformers 在您的 React Native 或 Expo 应用程序中运行变压器模型了。
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0227- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01- IinulaInula(发音为:[ˈɪnjʊlə])意为旋覆花,有生命力旺盛和根系深厚两大特点,寓意着为前端生态提供稳固的基石。openInula 是一款用于构建用户界面的 JavaScript 库,提供响应式 API 帮助开发者简单高效构建 web 页面,比传统虚拟 DOM 方式渲染效率提升30%以上,同时 openInula 提供与 React 保持一致的 API,并且提供5大常用功能丰富的核心组件。TypeScript05