[feat] added ooba
This commit is contained in:
@@ -181,18 +181,76 @@
|
|||||||
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="4000" bind:value={$DataBase.maxContext}>
|
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="4000" bind:value={$DataBase.maxContext}>
|
||||||
{:else if $DataBase.aiModel === 'gpt35_16k' || $DataBase.aiModel === 'gpt35_16k_0613'}
|
{:else if $DataBase.aiModel === 'gpt35_16k' || $DataBase.aiModel === 'gpt35_16k_0613'}
|
||||||
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="16000" bind:value={$DataBase.maxContext}>
|
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="16000" bind:value={$DataBase.maxContext}>
|
||||||
{:else if $DataBase.aiModel === 'gpt4' || $DataBase.aiModel === 'textgen_webui'}
|
{:else if $DataBase.aiModel === 'gpt4'}
|
||||||
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="8000" bind:value={$DataBase.maxContext}>
|
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max="8000" bind:value={$DataBase.maxContext}>
|
||||||
{:else if $DataBase.aiModel === 'custom'}
|
{:else if $DataBase.aiModel === 'custom'}
|
||||||
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max={getCurrentPluginMax($DataBase.currentPluginProvider)} bind:value={$DataBase.maxContext}>
|
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} max={getCurrentPluginMax($DataBase.currentPluginProvider)} bind:value={$DataBase.maxContext}>
|
||||||
{:else}
|
{:else}
|
||||||
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} bind:value={$DataBase.maxContext}>
|
<input class="text-neutral-200 mb-4 text-sm p-2 bg-transparent input-text focus:bg-selected" type="number" min={0} bind:value={$DataBase.maxContext}>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
<span class="text-neutral-200">{language.maxResponseSize}</span>
|
<span class="text-neutral-200">{language.maxResponseSize}</span>
|
||||||
<input class="text-neutral-200 mb-4 p-2 bg-transparent input-text focus:bg-selected text-sm" type="number" min={0} max="2048" bind:value={$DataBase.maxResponse}>
|
<input class="text-neutral-200 mb-4 p-2 bg-transparent input-text focus:bg-selected text-sm" type="number" min={0} max="2048" bind:value={$DataBase.maxResponse}>
|
||||||
<span class="text-neutral-200">{language.temperature} <Help key="tempature"/></span>
|
<span class="text-neutral-200">{language.temperature} <Help key="tempature"/></span>
|
||||||
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="200" bind:value={$DataBase.temperature}>
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="200" bind:value={$DataBase.temperature}>
|
||||||
<span class="text-gray-400 mb-6 text-sm">{($DataBase.temperature / 100).toFixed(2)}</span>
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.temperature / 100).toFixed(2)}</span>
|
||||||
|
{#if $DataBase.aiModel === 'textgen_webui'}
|
||||||
|
<span class="text-neutral-200">Top K</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="2" step="0.01" bind:value={$DataBase.ooba.top_k}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.top_k).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Top P</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="2" step="0.01" bind:value={$DataBase.ooba.top_p}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.top_p).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Typical P</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="1" step="0.01" bind:value={$DataBase.ooba.typical_p}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.typical_p).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Top A</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="1" step="0.01" bind:value={$DataBase.ooba.top_a}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.top_a).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Tail Free Sampling</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="1" step="0.01" bind:value={$DataBase.ooba.tfs}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.tfs).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Epsilon Cutoff</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="9" step="0.01" bind:value={$DataBase.ooba.epsilon_cutoff}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.epsilon_cutoff).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Eta Cutoff</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="20" step="0.01" bind:value={$DataBase.ooba.eta_cutoff}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.eta_cutoff).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Number of Beams</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="1" max="20" step="1" bind:value={$DataBase.ooba.num_beams}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.num_beams).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Length Penalty</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min={-5} max="5" step="0.1" bind:value={$DataBase.ooba.length_penalty}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.length_penalty).toFixed(2)}</span>
|
||||||
|
<span class="text-neutral-200">Penalty Alpha</span>
|
||||||
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min={0} max="5" step="0.05" bind:value={$DataBase.ooba.penalty_alpha}>
|
||||||
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.ooba.penalty_alpha).toFixed(2)}</span>
|
||||||
|
<div class="flex items-center mt-4">
|
||||||
|
<Check bind:check={$DataBase.ooba.do_sample} name={'Do Sample'}/>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center mt-4">
|
||||||
|
<Check bind:check={$DataBase.ooba.add_bos_token} name={'Add BOS Token'}/>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center mt-4">
|
||||||
|
<Check bind:check={$DataBase.ooba.ban_eos_token} name={'Ban EOS Token'}/>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center mt-4">
|
||||||
|
<Check bind:check={$DataBase.ooba.skip_special_tokens} name={'Skip Special Tokens'}/>
|
||||||
|
</div>
|
||||||
|
<div class="flex items-center mt-4">
|
||||||
|
<Check bind:check={$DataBase.ooba.formating.custom} name={'Instruct Format'}/>
|
||||||
|
</div>
|
||||||
|
{#if $DataBase.ooba.formating.custom}
|
||||||
|
<div class="flex flex-col p-3 bg-darkbg mt-4">
|
||||||
|
<span class="text-neutral-200">User Prefix</span>
|
||||||
|
<input class="text-neutral-200 mb-4 p-2 bg-transparent input-text focus:bg-selected" bind:value={$DataBase.ooba.formating.userPrefix}>
|
||||||
|
<span class="text-neutral-200">Assistant Prefix</span>
|
||||||
|
<input class="text-neutral-200 mb-4 p-2 bg-transparent input-text focus:bg-selected" bind:value={$DataBase.ooba.formating.assistantPrefix}>
|
||||||
|
<span class="text-neutral-200">Seperator</span>
|
||||||
|
<input class="text-neutral-200 mb-4 p-2 bg-transparent input-text focus:bg-selected" bind:value={$DataBase.ooba.formating.seperator}>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
{:else}
|
||||||
<span class="text-neutral-200">{language.frequencyPenalty} <Help key="frequencyPenalty"/></span>
|
<span class="text-neutral-200">{language.frequencyPenalty} <Help key="frequencyPenalty"/></span>
|
||||||
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="100" bind:value={$DataBase.frequencyPenalty}>
|
<input class="text-neutral-200 p-2 bg-transparent input-text focus:bg-selected" type="range" min="0" max="100" bind:value={$DataBase.frequencyPenalty}>
|
||||||
<span class="text-gray-400 mb-6 text-sm">{($DataBase.frequencyPenalty / 100).toFixed(2)}</span>
|
<span class="text-gray-400 mb-6 text-sm">{($DataBase.frequencyPenalty / 100).toFixed(2)}</span>
|
||||||
@@ -203,7 +261,7 @@
|
|||||||
<span class="text-neutral-200 mt-2">{language.autoSuggest} <Help key="autoSuggest"/></span>
|
<span class="text-neutral-200 mt-2">{language.autoSuggest} <Help key="autoSuggest"/></span>
|
||||||
<textarea class="bg-transparent input-text mb-2 text-gray-200 resize-none h-20 min-h-20 focus:bg-selected text-xs w-full" autocomplete="off" bind:value={$DataBase.autoSuggestPrompt}></textarea>
|
<textarea class="bg-transparent input-text mb-2 text-gray-200 resize-none h-20 min-h-20 focus:bg-selected text-xs w-full" autocomplete="off" bind:value={$DataBase.autoSuggestPrompt}></textarea>
|
||||||
<span class="text-gray-400 mb-6 text-sm">{tokens.autoSuggest} {language.tokens}</span>
|
<span class="text-gray-400 mb-6 text-sm">{tokens.autoSuggest} {language.tokens}</span>
|
||||||
|
{/if}
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -358,16 +358,16 @@ export async function requestChatDataMain(arg:requestDataArgument, model:'model'
|
|||||||
'max_new_tokens': db.maxResponse,
|
'max_new_tokens': db.maxResponse,
|
||||||
'do_sample': true,
|
'do_sample': true,
|
||||||
'temperature': (db.temperature / 100),
|
'temperature': (db.temperature / 100),
|
||||||
'top_p': 0.9,
|
'top_p': db.ooba.top_p,
|
||||||
'typical_p': 1,
|
'typical_p': db.ooba.typical_p,
|
||||||
'repetition_penalty': db.PresensePenalty,
|
'repetition_penalty': db.ooba.repetition_penalty,
|
||||||
'encoder_repetition_penalty': 1,
|
'encoder_repetition_penalty': db.ooba.encoder_repetition_penalty,
|
||||||
'top_k': 100,
|
'top_k': db.ooba.top_k,
|
||||||
'min_length': 0,
|
'min_length': db.ooba.min_length,
|
||||||
'no_repeat_ngram_size': 0,
|
'no_repeat_ngram_size': db.ooba.no_repeat_ngram_size,
|
||||||
'num_beams': 1,
|
'num_beams': db.ooba.num_beams,
|
||||||
'penalty_alpha': 0,
|
'penalty_alpha': db.ooba.penalty_alpha,
|
||||||
'length_penalty': 1,
|
'length_penalty': db.ooba.length_penalty,
|
||||||
'early_stopping': false,
|
'early_stopping': false,
|
||||||
'truncation_length': maxTokens,
|
'truncation_length': maxTokens,
|
||||||
'ban_eos_token': false,
|
'ban_eos_token': false,
|
||||||
|
|||||||
@@ -24,7 +24,26 @@ export function stringlizeChat(formated:OpenAIChat[], char:string = ''){
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function stringlizeChatOba(formated:OpenAIChat[], char:string = ''){
|
export function stringlizeChatOba(formated:OpenAIChat[], char:string = ''){
|
||||||
|
const db = get(DataBase)
|
||||||
let resultString:string[] = []
|
let resultString:string[] = []
|
||||||
|
if(db.ooba.formating.custom){
|
||||||
|
for(const form of formated){
|
||||||
|
if(form.role === 'system'){
|
||||||
|
resultString.push(form.content)
|
||||||
|
}
|
||||||
|
else if(form.name){
|
||||||
|
resultString.push(db.ooba.formating.userPrefix + form.content + db.ooba.formating.seperator)
|
||||||
|
}
|
||||||
|
else if(form.role === 'assistant' && char){
|
||||||
|
resultString.push(db.ooba.formating.assistantPrefix + form.content + db.ooba.formating.seperator)
|
||||||
|
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
resultString.push(form.content)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return resultString.join('\n\n') + `\n\n${db.ooba.formating.assistantPrefix}:`
|
||||||
|
}
|
||||||
for(const form of formated){
|
for(const form of formated){
|
||||||
if(form.role === 'system'){
|
if(form.role === 'system'){
|
||||||
resultString.push(form.content)
|
resultString.push(form.content)
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { checkNullish, selectSingleFile } from '../util';
|
|||||||
import { changeLanguage, language } from '../../lang';
|
import { changeLanguage, language } from '../../lang';
|
||||||
import type { RisuPlugin } from '../plugins/plugins';
|
import type { RisuPlugin } from '../plugins/plugins';
|
||||||
import { downloadFile, saveAsset as saveImageGlobal } from './globalApi';
|
import { downloadFile, saveAsset as saveImageGlobal } from './globalApi';
|
||||||
import { cloneDeep } from 'lodash';
|
import { clone, cloneDeep } from 'lodash';
|
||||||
import { defaultAutoSuggestPrompt, defaultJailbreak, defaultMainPrompt } from './defaultPrompts';
|
import { defaultAutoSuggestPrompt, defaultJailbreak, defaultMainPrompt } from './defaultPrompts';
|
||||||
import { alertNormal } from '../alert';
|
import { alertNormal } from '../alert';
|
||||||
|
|
||||||
@@ -265,9 +265,8 @@ export function setDatabase(data:Database){
|
|||||||
if(checkNullish(data.imageCompression)){
|
if(checkNullish(data.imageCompression)){
|
||||||
data.imageCompression = true
|
data.imageCompression = true
|
||||||
}
|
}
|
||||||
if(checkNullish(data.classicMaxWidth)){
|
data.classicMaxWidth ??= false
|
||||||
data.classicMaxWidth = false
|
data.ooba ??= cloneDeep(defaultOoba)
|
||||||
}
|
|
||||||
changeLanguage(data.language)
|
changeLanguage(data.language)
|
||||||
DataBase.set(data)
|
DataBase.set(data)
|
||||||
}
|
}
|
||||||
@@ -410,6 +409,7 @@ export interface botPreset{
|
|||||||
bias: [string, number][]
|
bias: [string, number][]
|
||||||
koboldURL?: string
|
koboldURL?: string
|
||||||
proxyKey:string
|
proxyKey:string
|
||||||
|
ooba: OobaSettings
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Database{
|
export interface Database{
|
||||||
@@ -536,6 +536,7 @@ export interface Database{
|
|||||||
usePlainFetch:boolean
|
usePlainFetch:boolean
|
||||||
hypaMemory:boolean
|
hypaMemory:boolean
|
||||||
proxyRequestModel:string
|
proxyRequestModel:string
|
||||||
|
ooba:OobaSettings
|
||||||
}
|
}
|
||||||
|
|
||||||
interface hordeConfig{
|
interface hordeConfig{
|
||||||
@@ -584,9 +585,75 @@ export interface Message{
|
|||||||
chatId?:string
|
chatId?:string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface OobaSettings{
|
||||||
|
max_new_tokens: number,
|
||||||
|
do_sample: boolean,
|
||||||
|
temperature: number,
|
||||||
|
top_p: number,
|
||||||
|
typical_p: number,
|
||||||
|
repetition_penalty: number,
|
||||||
|
encoder_repetition_penalty: number,
|
||||||
|
top_k: number,
|
||||||
|
min_length: number,
|
||||||
|
no_repeat_ngram_size: number,
|
||||||
|
num_beams: number,
|
||||||
|
penalty_alpha: number,
|
||||||
|
length_penalty: number,
|
||||||
|
early_stopping: boolean,
|
||||||
|
seed: number,
|
||||||
|
add_bos_token: boolean,
|
||||||
|
truncation_length: number,
|
||||||
|
ban_eos_token: boolean,
|
||||||
|
skip_special_tokens: boolean,
|
||||||
|
top_a: number,
|
||||||
|
tfs: number,
|
||||||
|
epsilon_cutoff: number,
|
||||||
|
eta_cutoff: number,
|
||||||
|
formating:{
|
||||||
|
custom:boolean,
|
||||||
|
userPrefix:string,
|
||||||
|
assistantPrefix:string
|
||||||
|
seperator:string
|
||||||
|
useName:boolean
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
export const saveImage = saveImageGlobal
|
export const saveImage = saveImageGlobal
|
||||||
|
|
||||||
|
export const defaultOoba:OobaSettings = {
|
||||||
|
max_new_tokens: 180,
|
||||||
|
do_sample: true,
|
||||||
|
temperature: 0.5,
|
||||||
|
top_p: 0.9,
|
||||||
|
typical_p: 1,
|
||||||
|
repetition_penalty: 1.1,
|
||||||
|
encoder_repetition_penalty: 1,
|
||||||
|
top_k: 0,
|
||||||
|
min_length: 0,
|
||||||
|
no_repeat_ngram_size: 0,
|
||||||
|
num_beams: 1,
|
||||||
|
penalty_alpha: 0,
|
||||||
|
length_penalty: 1,
|
||||||
|
early_stopping: false,
|
||||||
|
seed: -1,
|
||||||
|
add_bos_token: true,
|
||||||
|
truncation_length: 2048,
|
||||||
|
ban_eos_token: false,
|
||||||
|
skip_special_tokens: true,
|
||||||
|
top_a: 0,
|
||||||
|
tfs: 1,
|
||||||
|
epsilon_cutoff: 0,
|
||||||
|
eta_cutoff: 0,
|
||||||
|
formating:{
|
||||||
|
custom:false,
|
||||||
|
userPrefix:'user:',
|
||||||
|
assistantPrefix:'assistant:',
|
||||||
|
seperator:'',
|
||||||
|
useName:false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export const presetTemplate:botPreset = {
|
export const presetTemplate:botPreset = {
|
||||||
name: "New Preset",
|
name: "New Preset",
|
||||||
apiType: "gpt35",
|
apiType: "gpt35",
|
||||||
@@ -608,7 +675,8 @@ export const presetTemplate:botPreset = {
|
|||||||
forceReplaceUrl2: '',
|
forceReplaceUrl2: '',
|
||||||
promptPreprocess: false,
|
promptPreprocess: false,
|
||||||
proxyKey: '',
|
proxyKey: '',
|
||||||
bias: []
|
bias: [],
|
||||||
|
ooba: cloneDeep(defaultOoba)
|
||||||
}
|
}
|
||||||
|
|
||||||
const defaultSdData:[string,string][] = [
|
const defaultSdData:[string,string][] = [
|
||||||
@@ -681,7 +749,8 @@ export function saveCurrentPreset(){
|
|||||||
promptPreprocess: db.promptPreprocess,
|
promptPreprocess: db.promptPreprocess,
|
||||||
bias: db.bias,
|
bias: db.bias,
|
||||||
koboldURL: db.koboldURL,
|
koboldURL: db.koboldURL,
|
||||||
proxyKey: db.proxyKey
|
proxyKey: db.proxyKey,
|
||||||
|
ooba: db.ooba
|
||||||
}
|
}
|
||||||
db.botPresets = pres
|
db.botPresets = pres
|
||||||
DataBase.set(db)
|
DataBase.set(db)
|
||||||
@@ -726,6 +795,7 @@ export function changeToPreset(id =0, savecurrent = true){
|
|||||||
db.bias = newPres.bias ?? db.bias
|
db.bias = newPres.bias ?? db.bias
|
||||||
db.koboldURL = newPres.koboldURL ?? db.koboldURL
|
db.koboldURL = newPres.koboldURL ?? db.koboldURL
|
||||||
db.proxyKey = newPres.proxyKey ?? db.proxyKey
|
db.proxyKey = newPres.proxyKey ?? db.proxyKey
|
||||||
|
db.ooba = cloneDeep(newPres.ooba ?? db.ooba)
|
||||||
DataBase.set(db)
|
DataBase.set(db)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user