react-native-executorch
Version:
An easy way to run AI models in react native with ExecuTorch
62 lines (61 loc) • 2.24 kB
JavaScript
"use strict";
import { symbols } from '../constants/ocr/symbols';
import { ETError, getError } from '../Error';
import { OCRNativeModule } from '../native/RnExecutorchModules';
import { ResourceFetcher } from '../utils/ResourceFetcher';
export class OCRController {
isReady = false;
isGenerating = false;
error = null;
constructor({
modelDownloadProgressCallback = _downloadProgress => {},
isReadyCallback = _isReady => {},
isGeneratingCallback = _isGenerating => {},
errorCallback = _error => {}
}) {
this.nativeModule = OCRNativeModule;
this.modelDownloadProgressCallback = modelDownloadProgressCallback;
this.isReadyCallback = isReadyCallback;
this.isGeneratingCallback = isGeneratingCallback;
this.errorCallback = errorCallback;
}
loadModel = async (detectorSource, recognizerSources, language) => {
try {
if (!detectorSource || Object.keys(recognizerSources).length !== 3) return;
if (!symbols[language]) {
throw new Error(getError(ETError.LanguageNotSupported));
}
this.isReady = false;
this.isReadyCallback(false);
const paths = await ResourceFetcher.fetchMultipleResources(this.modelDownloadProgressCallback, detectorSource, recognizerSources.recognizerLarge, recognizerSources.recognizerMedium, recognizerSources.recognizerSmall);
await this.nativeModule.loadModule(paths[0], paths[1], paths[2], paths[3], symbols[language]);
this.isReady = true;
this.isReadyCallback(this.isReady);
} catch (e) {
if (this.errorCallback) {
this.errorCallback(getError(e));
} else {
throw new Error(getError(e));
}
}
};
forward = async input => {
if (!this.isReady) {
throw new Error(getError(ETError.ModuleNotLoaded));
}
if (this.isGenerating) {
throw new Error(getError(ETError.ModelGenerating));
}
try {
this.isGenerating = true;
this.isGeneratingCallback(this.isGenerating);
return await this.nativeModule.forward(input);
} catch (e) {
throw new Error(getError(e));
} finally {
this.isGenerating = false;
this.isGeneratingCallback(this.isGenerating);
}
};
}
//# sourceMappingURL=OCRController.js.map