remove freeu support

This commit is contained in:
Qing
2024-04-25 22:21:33 +08:00
parent 911f7224b6
commit 017a3d68fd
10 changed files with 33 additions and 326 deletions

View File

@@ -316,129 +316,6 @@ const DiffusionOptions = () => {
)
}
const renderFreeu = () => {
if (!settings.model.support_freeu) {
return null
}
let toolTip =
"FreeU is a technique for improving image quality. Different models may require different FreeU-specific hyperparameters, which can be viewed in the more info section."
if (settings.enableBrushNet) {
toolTip = "BrushNet is enabled, FreeU is disabled."
}
let disable = settings.enableBrushNet || !settings.enableFreeu
return (
<div className="flex flex-col gap-4">
<RowContainer>
<LabelTitle
text="FreeU"
url="https://huggingface.co/docs/diffusers/main/en/using-diffusers/freeu"
toolTip={toolTip}
disabled={disable}
/>
<Switch
id="freeu"
checked={settings.enableFreeu}
onCheckedChange={(value) => {
updateSettings({ enableFreeu: value })
}}
disabled={settings.enableBrushNet}
/>
</RowContainer>
<div className="flex flex-col gap-4">
<div className="flex justify-center gap-6">
<div className="flex gap-4 items-center justify-center">
<LabelTitle
htmlFor="freeu-s1"
text="s1"
disabled={disable}
className="min-w-0"
/>
<NumberInput
id="freeu-s1"
className="w-14"
disabled={disable}
numberValue={settings.freeuConfig.s1}
allowFloat
onNumberValueChange={(value) => {
updateSettings({
freeuConfig: { ...settings.freeuConfig, s1: value },
})
}}
/>
</div>
<div className="flex gap-2 items-center justify-center">
<LabelTitle
htmlFor="freeu-s2"
text="s2"
disabled={disable}
className="min-w-0"
/>
<NumberInput
id="freeu-s2"
className="w-14"
disabled={disable}
numberValue={settings.freeuConfig.s2}
allowFloat
onNumberValueChange={(value) => {
updateSettings({
freeuConfig: { ...settings.freeuConfig, s2: value },
})
}}
/>
</div>
</div>
<div className="flex justify-center gap-6">
<div className="flex gap-2 items-center justify-center">
<LabelTitle
htmlFor="freeu-b1"
text="b1"
disabled={disable}
className="min-w-0"
/>
<NumberInput
id="freeu-b1"
className="w-14"
disabled={disable}
numberValue={settings.freeuConfig.b1}
allowFloat
onNumberValueChange={(value) => {
updateSettings({
freeuConfig: { ...settings.freeuConfig, b1: value },
})
}}
/>
</div>
<div className="flex gap-2 items-center justify-center">
<LabelTitle
htmlFor="freeu-b2"
text="b2"
disabled={disable}
className="min-w-0"
/>
<NumberInput
id="freeu-b2"
className="w-14"
disabled={disable}
numberValue={settings.freeuConfig.b2}
allowFloat
onNumberValueChange={(value) => {
updateSettings({
freeuConfig: { ...settings.freeuConfig, b2: value },
})
}}
/>
</div>
</div>
</div>
<Separator />
</div>
)
}
const renderNegativePrompt = () => {
if (!settings.model.need_prompt) {
return null
@@ -851,30 +728,33 @@ const DiffusionOptions = () => {
const renderMaskBlur = () => {
return (
<RowContainer>
<LabelTitle
text="Mask blur"
toolTip="How much to blur the mask before processing, in pixels. Make the generated inpainting boundaries appear more natural."
/>
<Slider
className="w-[100px]"
defaultValue={[settings.sdMaskBlur]}
min={0}
max={96}
step={1}
value={[Math.floor(settings.sdMaskBlur)]}
onValueChange={(vals) => updateSettings({ sdMaskBlur: vals[0] })}
/>
<NumberInput
id="mask-blur"
className="w-[60px] rounded-full"
numberValue={settings.sdMaskBlur}
allowFloat={false}
onNumberValueChange={(value) => {
updateSettings({ sdMaskBlur: value })
}}
/>
</RowContainer>
<>
<RowContainer>
<LabelTitle
text="Mask blur"
toolTip="How much to blur the mask before processing, in pixels. Make the generated inpainting boundaries appear more natural."
/>
<Slider
className="w-[100px]"
defaultValue={[settings.sdMaskBlur]}
min={0}
max={96}
step={1}
value={[Math.floor(settings.sdMaskBlur)]}
onValueChange={(vals) => updateSettings({ sdMaskBlur: vals[0] })}
/>
<NumberInput
id="mask-blur"
className="w-[60px] rounded-full"
numberValue={settings.sdMaskBlur}
allowFloat={false}
onNumberValueChange={(value) => {
updateSettings({ sdMaskBlur: value })
}}
/>
</RowContainer>
<Separator />
</>
)
}
@@ -985,7 +865,9 @@ const DiffusionOptions = () => {
<div className="flex flex-col gap-4 mt-4">
{renderCropper()}
{renderExtender()}
{renderMaskBlur()}
{renderMaskAdjuster()}
{renderMatchHistograms()}
{renderPowerPaintTaskType()}
{renderSteps()}
{renderGuidanceScale()}
@@ -998,9 +880,6 @@ const DiffusionOptions = () => {
{renderBrushNetSetting()}
{renderConterNetSetting()}
{renderLCMLora()}
{renderMaskBlur()}
{renderMatchHistograms()}
{renderFreeu()}
{renderPaintByExample()}
</div>
)

View File

@@ -68,8 +68,6 @@ export default async function inpaint(
sd_sampler: settings.sdSampler,
sd_seed: settings.seedFixed ? settings.seed : -1,
sd_match_histograms: settings.sdMatchHistograms,
sd_freeu: settings.enableFreeu,
sd_freeu_config: settings.freeuConfig,
sd_lcm_lora: settings.enableLCMLora,
paint_by_example_example_image: exampleImageBase64,
p2p_image_guidance_scale: settings.p2pImageGuidanceScale,

View File

@@ -7,7 +7,6 @@ import {
AdjustMaskOperate,
CV2Flag,
ExtenderDirection,
FreeuConfig,
LDMSampler,
Line,
LineGroup,
@@ -105,8 +104,6 @@ export type Settings = {
brushnetConditioningScale: number
enableLCMLora: boolean
enableFreeu: boolean
freeuConfig: FreeuConfig
// PowerPaint
powerpaintTask: PowerPaintTask
@@ -316,7 +313,6 @@ const defaultValues: AppState = {
support_outpainting: false,
controlnets: [],
brushnets: [],
support_freeu: false,
support_lcm_lora: false,
is_single_file_diffusers: false,
need_prompt: false,
@@ -352,8 +348,6 @@ const defaultValues: AppState = {
brushnetMethod: "random_mask",
brushnetConditioningScale: 1.0,
enableLCMLora: false,
enableFreeu: false,
freeuConfig: { s1: 0.9, s2: 0.2, b1: 1.2, b2: 1.4 },
powerpaintTask: PowerPaintTask.text_guided,
adjustMaskKernelSize: 12,
},

View File

@@ -51,7 +51,6 @@ export interface ModelInfo {
support_brushnet: boolean
controlnets: string[]
brushnets: string[]
support_freeu: boolean
support_lcm_lora: boolean
need_prompt: boolean
is_single_file_diffusers: boolean
@@ -98,13 +97,6 @@ export interface Rect {
height: number
}
export interface FreeuConfig {
s1: number
s2: number
b1: number
b2: number
}
export interface Point {
x: number
y: number