inference-playground / src /lib /components /InferencePlayground /InferencePlaygroundGenerationConfig.svelte
mishig's picture
mishig HF staff
order imports
4b8b411
raw
history blame
3.37 kB
<script lang="ts">
import type { Conversation } from "$lib/types";
import {
GENERATION_CONFIG_KEYS,
GENERATION_CONFIG_KEYS_ADVANCED,
GENERATION_CONFIG_SETTINGS,
} from "./generationConfigSettings";
export let conversation: Conversation;
export let classNames = "";
$: modelMaxLength = conversation.model.tokenizerConfig.model_max_length;
$: maxTokens = Math.min(modelMaxLength ?? GENERATION_CONFIG_SETTINGS["max_tokens"].max, 64_000);
</script>
<div class="flex flex-col gap-y-7 {classNames}">
{#each GENERATION_CONFIG_KEYS as key}
{@const { label, min, step } = GENERATION_CONFIG_SETTINGS[key]}
{@const max = key === "max_tokens" ? maxTokens : GENERATION_CONFIG_SETTINGS[key].max}
<div>
<div class="flex items-center justify-between">
<label for="temperature-range" class="mb-2 block text-sm font-medium text-gray-900 dark:text-white"
>{label}</label
>
<input
type="number"
class="w-18 rounded border bg-transparent px-1 py-0.5 text-right text-sm dark:border-gray-700"
{min}
{max}
{step}
bind:value={conversation.config[key]}
/>
</div>
<input
id="temperature-range"
type="range"
{min}
{max}
{step}
bind:value={conversation.config[key]}
class="h-2 w-full cursor-pointer appearance-none rounded-lg bg-gray-200 accent-black dark:bg-gray-700 dark:accent-blue-500"
/>
</div>
{/each}
<details>
<summary>Advanced Options</summary>
<div class="mt-4 flex flex-col gap-y-5">
{#each GENERATION_CONFIG_KEYS_ADVANCED as key}
{@const settings = GENERATION_CONFIG_SETTINGS[key]}
<div>
<div class="flex items-center justify-between">
<label for="temperature-range" class="mb-2 block text-sm font-medium text-gray-900 dark:text-white"
>{settings.label}</label
>
<input
type="number"
class="w-18 rounded border bg-transparent px-1 py-0.5 text-right text-sm dark:border-gray-700"
min={settings.min}
max={settings.max}
step={settings.step}
value={conversation.config[key] ?? settings.default}
on:input={e => (conversation.config[key] = Number(e.currentTarget.value))}
/>
</div>
<input
id="temperature-range"
type="range"
min={settings.min}
max={settings.max}
step={settings.step}
value={conversation.config[key] ?? settings.default}
on:input={e => (conversation.config[key] = Number(e.currentTarget.value))}
class="h-2 w-full cursor-pointer appearance-none rounded-lg bg-gray-200 accent-black dark:bg-gray-700 dark:accent-blue-500"
/>
</div>
{/each}
</div>
</details>
<div class="mt-2">
<label class="flex cursor-pointer items-center justify-between">
<input type="checkbox" bind:checked={conversation.streaming} class="peer sr-only" />
<span class="text-sm font-medium text-gray-900 dark:text-gray-300">Streaming</span>
<div
class="peer relative h-5 w-9 rounded-full bg-gray-200 after:absolute after:start-[2px] after:top-[2px] after:h-4 after:w-4 after:rounded-full after:border after:border-gray-300 after:bg-white after:transition-all after:content-[''] peer-checked:bg-black peer-checked:after:translate-x-full peer-checked:after:border-white peer-focus:outline-none dark:border-gray-600 dark:bg-gray-700 dark:peer-checked:bg-blue-600"
></div>
</label>
</div>
</div>