transformers-js-playground / public /workers /text-classification.js
Vokturz's picture
Update transformers library to latest version across all worker scripts and force fallback to WASM
415aaef
/* eslint-disable no-restricted-globals */
import { pipeline } from 'https://cdn.jsdelivr.net/npm/@huggingface/transformers@latest'
class MyTextClassificationPipeline {
static task = 'text-classification'
static instance = null
static async getInstance(model, dtype = 'fp32', progress_callback = null) {
try {
// Try WebGPU first
this.instance = await pipeline(this.task, model, {
dtype,
device: 'webgpu',
progress_callback
})
return this.instance
} catch (webgpuError) {
// Fallback to WASM if WebGPU fails
if (progress_callback) {
progress_callback({
status: 'fallback',
message: 'WebGPU failed, falling back to WASM'
})
}
try {
this.instance = await pipeline(this.task, model, {
dtype,
device: 'wasm',
progress_callback
})
return this.instance
} catch (wasmError) {
throw new Error(
`Both WebGPU and WASM failed. WebGPU error: ${webgpuError.message}. WASM error: ${wasmError.message}`
)
}
}
}
}
// Listen for messages from the main thread
self.addEventListener('message', async (event) => {
try {
const { type, model, dtype, text, config } = event.data
if (!model) {
self.postMessage({
status: 'error',
output: 'No model provided'
})
return
}
// Retrieve the pipeline. This will download the model if not already cached.
const classifier = await MyTextClassificationPipeline.getInstance(
model,
dtype,
(x) => {
self.postMessage({ status: 'loading', output: x })
}
)
if (type === 'load') {
self.postMessage({
status: 'ready',
output: `Model ${model}, dtype ${dtype} loaded`
})
return
}
if (type === 'classify') {
if (!text) {
self.postMessage({ status: 'ready' }) // Nothing to process
return
}
const split = text.split('\n')
for (const line of split) {
if (line.trim()) {
const output = await classifier(line, config)
self.postMessage({
status: 'output',
output: {
sequence: line,
labels: output.map((item) => item.label),
scores: output.map((item) => item.score)
}
})
}
}
self.postMessage({ status: 'ready' })
}
} catch (error) {
self.postMessage({
status: 'error',
output: error.message || 'An error occurred during processing'
})
}
})