parent
55142065eb
commit
dbc70dc13c
@ -0,0 +1,120 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<title>llama-cli</title> |
||||
<meta charset="UTF-8"> |
||||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css" crossorigin="anonymous" referrerpolicy="no-referrer" /> |
||||
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"> |
||||
</head> |
||||
<style> |
||||
@keyframes rotating { |
||||
from { |
||||
transform: rotate(0deg); |
||||
} |
||||
to { |
||||
transform: rotate(360deg); |
||||
} |
||||
} |
||||
|
||||
.waiting { |
||||
animation: rotating 1s linear infinite; |
||||
} |
||||
|
||||
</style> |
||||
<body> |
||||
|
||||
<div class="container mt-5" x-data="{ templates:[ |
||||
{ |
||||
name: 'Alpaca: Instruction without input', |
||||
text: `Below is an instruction that describes a task. Write a response that appropriately completes the request. |
||||
|
||||
### Instruction: |
||||
{{.Instruction}} |
||||
|
||||
### Response:`, |
||||
}, |
||||
{ |
||||
name: 'Alpaca: Instruction with input', |
||||
text: `Below is an instruction that describes a task, paired with an input that provides further context. Write a response that appropriately completes the request. |
||||
|
||||
### Instruction: |
||||
{{.Instruction}} |
||||
|
||||
### Input: |
||||
{{.Input}} |
||||
|
||||
### Response:`, |
||||
} |
||||
], selectedTemplate: '', selectedTemplateText: '' }"> |
||||
<h1>llama-cli API</h1> |
||||
<div class="form-group"> |
||||
<label for="inputText">Input Text:</label> |
||||
<textarea class="form-control" id="inputText" rows="6" placeholder="Your text input here..." x-text="selectedTemplateText"></textarea> |
||||
</div> |
||||
<div class="form-group"> |
||||
<label for="templateSelect">Select Template:</label> |
||||
<select class="form-control" id="templateSelect" x-model="selectedTemplateText"> |
||||
<option value="">None</option> |
||||
<template x-for="(template, index) in templates" :key="index"> |
||||
<option :value="template.text" x-text="template.name"></option> |
||||
</template> |
||||
</select> |
||||
</div> |
||||
<div class="form-group"> |
||||
<label for="topP">Top P:</label> |
||||
<input type="range" step="0.01" min="0" max="1" class="form-control" id="topP" value="0.20" name="topP" onchange="this.nextElementSibling.value = this.value" required> |
||||
<output>0.20</output> |
||||
</div> |
||||
<div class="form-group"> |
||||
<label for="topK">Top K:</label> |
||||
<input type="number" class="form-control" id="topK" value="10000" name="topK" required> |
||||
</div> |
||||
<div class="form-group"> |
||||
<label for="temperature">Temperature:</label> |
||||
<input type="range" step="0.01" min="0" max="1" value="0.9" class="form-control" id="temperature" name="temperature" onchange="this.nextElementSibling.value = this.value" required> |
||||
<output>0.9</output> |
||||
</div> |
||||
<div class="form-group"> |
||||
<label for="tokens">Tokens:</label> |
||||
<input type="number" class="form-control" id="tokens" name="tokens" value="128" required> |
||||
</div> |
||||
<button class="btn btn-primary" x-on:click="submitRequest()">Submit <i class="fas fa-paper-plane"></i></button> |
||||
<hr> |
||||
<div class="form-group"> |
||||
<label for="outputText">Output Text:</label> |
||||
<textarea class="form-control" id="outputText" rows="5" readonly></textarea> |
||||
</div> |
||||
</div> |
||||
|
||||
<script defer src="https://cdn.jsdelivr.net/npm/alpinejs@3.x.x/dist/cdn.min.js"></script> |
||||
<script> |
||||
function submitRequest() { |
||||
var button = document.querySelector("i.fa-paper-plane"); |
||||
button.classList.add("waiting"); |
||||
var text = document.getElementById("inputText").value; |
||||
var url = "/predict"; |
||||
var data = { |
||||
"text": text, |
||||
"topP": document.getElementById("topP").value, |
||||
"topK": document.getElementById("topK").value, |
||||
"temperature": document.getElementById("temperature").value, |
||||
"tokens": document.getElementById("tokens").value |
||||
}; |
||||
fetch(url, { |
||||
method: "POST", |
||||
headers: { |
||||
"Content-Type": "application/json" |
||||
}, |
||||
body: JSON.stringify(data) |
||||
}) |
||||
.then(response => response.json()) |
||||
.then(data => { |
||||
document.getElementById("outputText").value = data.prediction; |
||||
button.classList.remove("waiting"); |
||||
}) |
||||
.catch(error => { console.error(error); button.classList.remove("waiting"); }); |
||||
} |
||||
</script> |
||||
</body> |
||||
</html> |
Loading…
Reference in new issue