greggelong commited on
Commit
33f91b5
·
verified ·
1 Parent(s): df6a09f

Create sketch.js

Browse files
Files changed (1) hide show
  1. sketch.js +54 -0
sketch.js ADDED
@@ -0,0 +1,54 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ // Import the pipeline function from the transformers library via CDN link
2
+ //import { pipeline } from 'https://cdn.jsdelivr.net/npm/@xenova/transformers@2.6.0';
3
+
4
+ import { pipeline, env } from "https://cdn.jsdelivr.net/npm/@xenova/transformers@2.6.0";
5
+ // Declare variables to hold the instances of the summarizer, generator, and classifier
6
+ let summarizer, generator, classifier;
7
+ env.allowLocalModels = false;
8
+ // Add an event listener to the window object that will execute the following function once the window is fully loaded
9
+ window.addEventListener('load', () => {
10
+ // Add click event listeners to buttons with specific IDs, binding them to their respective functions
11
+
12
+ document.getElementById('generate').addEventListener('click', generate);
13
+
14
+ });
15
+
16
+ // Grab DOM elements for updating status and output messages to the user
17
+ const statusElement = document.getElementById('status');
18
+ const outputElement = document.getElementById('output');
19
+
20
+ // Define an asynchronous function to generate text
21
+ async function generate() {
22
+ console.log("hello")
23
+ // Retrieve the input text from the DOM
24
+ let text = document.getElementById('inputText').value;
25
+ // If the generator model has not been loaded yet, load it and update the status
26
+ if (!generator) {
27
+ console.log("loading generate")
28
+ updateStatus('Loading generation model...');
29
+ generator = await pipeline(
30
+ 'text2text-generation',
31
+ 'Xenova/LaMini-Flan-T5-783M'
32
+ );
33
+ }
34
+ // Update status and run the generator model on the input text
35
+ updateStatus('Generating...');
36
+ console.log("generate")
37
+ let output = await generator(text, {
38
+ max_new_tokens: 100, // Set the maximum number of new tokens for the generated text
39
+ });
40
+ // Log and display the generation results
41
+ console.log(output);
42
+ updateOutput(output[0]);
43
+ }
44
+
45
+ // Function to update the status text in the DOM
46
+ function updateStatus(message) {
47
+ statusElement.textContent = 'Status: ' + message;
48
+ }
49
+
50
+ // Function to update the output text in the DOM and set the status back to 'Ready' once done
51
+ function updateOutput(message) {
52
+ outputElement.innerHTML = message;
53
+ updateStatus('Ready');
54
+ }