mirror of
https://github.com/w-okada/voice-changer.git
synced 2025-02-09 03:37:51 +03:00
imprpve gui: remove onnxprovider, model samplerate, half-precision, reload without initialize
This commit is contained in:
parent
807e88b93b
commit
50ff96b3c5
10
client/demo/dist/assets/gui_settings/RVC.json
vendored
10
client/demo/dist/assets/gui_settings/RVC.json
vendored
@ -36,14 +36,6 @@
|
|||||||
{
|
{
|
||||||
"name": "onnxExport",
|
"name": "onnxExport",
|
||||||
"options": {}
|
"options": {}
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "onnxExecutor",
|
|
||||||
"options": {}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "modelSamplingRate",
|
|
||||||
"options": {}
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"modelSetting": [
|
"modelSetting": [
|
||||||
@ -61,7 +53,7 @@
|
|||||||
|
|
||||||
"showFeature": true,
|
"showFeature": true,
|
||||||
"showIndex": true,
|
"showIndex": true,
|
||||||
"showHalfPrecision": true,
|
"showHalfPrecision": false,
|
||||||
"showPyTorchEnableCheckBox": false,
|
"showPyTorchEnableCheckBox": false,
|
||||||
"defaultEnablePyTorch": true,
|
"defaultEnablePyTorch": true,
|
||||||
"onlySelectedFramework": true,
|
"onlySelectedFramework": true,
|
||||||
|
11
client/demo/dist/index.html
vendored
11
client/demo/dist/index.html
vendored
@ -1 +1,10 @@
|
|||||||
<!doctype html><html style="width:100%;height:100%;overflow:hidden"><head><meta charset="utf-8"/><title>Voice Changer Client Demo</title><script defer="defer" src="index.js"></script></head><body style="width:100%;height:100%;margin:0"><div id="app" style="width:100%;height:100%"></div></body></html>
|
<!DOCTYPE html>
|
||||||
|
<html style="width: 100%; height: 100%; overflow: hidden">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<title>Voice Changer Client Demo</title>
|
||||||
|
<script defer src="index.js"></script></head>
|
||||||
|
<body style="width: 100%; height: 100%; margin: 0px">
|
||||||
|
<div id="app" style="width: 100%; height: 100%"></div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
1706
client/demo/dist/index.js
vendored
1706
client/demo/dist/index.js
vendored
File diff suppressed because one or more lines are too long
31
client/demo/dist/index.js.LICENSE.txt
vendored
31
client/demo/dist/index.js.LICENSE.txt
vendored
@ -1,31 +0,0 @@
|
|||||||
/*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @license React
|
|
||||||
* react-dom.production.min.js
|
|
||||||
*
|
|
||||||
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
||||||
*
|
|
||||||
* This source code is licensed under the MIT license found in the
|
|
||||||
* LICENSE file in the root directory of this source tree.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @license React
|
|
||||||
* react.production.min.js
|
|
||||||
*
|
|
||||||
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
||||||
*
|
|
||||||
* This source code is licensed under the MIT license found in the
|
|
||||||
* LICENSE file in the root directory of this source tree.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @license React
|
|
||||||
* scheduler.production.min.js
|
|
||||||
*
|
|
||||||
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
||||||
*
|
|
||||||
* This source code is licensed under the MIT license found in the
|
|
||||||
* LICENSE file in the root directory of this source tree.
|
|
||||||
*/
|
|
@ -36,14 +36,6 @@
|
|||||||
{
|
{
|
||||||
"name": "onnxExport",
|
"name": "onnxExport",
|
||||||
"options": {}
|
"options": {}
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "onnxExecutor",
|
|
||||||
"options": {}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "modelSamplingRate",
|
|
||||||
"options": {}
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"modelSetting": [
|
"modelSetting": [
|
||||||
@ -61,7 +53,7 @@
|
|||||||
|
|
||||||
"showFeature": true,
|
"showFeature": true,
|
||||||
"showIndex": true,
|
"showIndex": true,
|
||||||
"showHalfPrecision": true,
|
"showHalfPrecision": false,
|
||||||
"showPyTorchEnableCheckBox": false,
|
"showPyTorchEnableCheckBox": false,
|
||||||
"defaultEnablePyTorch": true,
|
"defaultEnablePyTorch": true,
|
||||||
"onlySelectedFramework": true,
|
"onlySelectedFramework": true,
|
||||||
|
@ -68,8 +68,9 @@ const AppStateWrapper = () => {
|
|||||||
// const modleKey = `${INDEXEDDB_KEY_MODEL_DATA}_${i}`
|
// const modleKey = `${INDEXEDDB_KEY_MODEL_DATA}_${i}`
|
||||||
// await removeItem(modleKey)
|
// await removeItem(modleKey)
|
||||||
// }
|
// }
|
||||||
|
}
|
||||||
|
const onReloadClicked = () => {
|
||||||
|
location.reload();
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
<div className="error-container">
|
<div className="error-container">
|
||||||
@ -80,6 +81,7 @@ const AppStateWrapper = () => {
|
|||||||
<p>このアプリで管理している情報をクリアすると回復する場合があります。</p>
|
<p>このアプリで管理している情報をクリアすると回復する場合があります。</p>
|
||||||
<p>下記のボタンを押して情報をクリアします。</p>
|
<p>下記のボタンを押して情報をクリアします。</p>
|
||||||
<p><button onClick={onClearCacheClicked}>アプリを初期化</button></p>
|
<p><button onClick={onClearCacheClicked}>アプリを初期化</button></p>
|
||||||
|
<p><button onClick={onReloadClicked}>初期化せずリロード</button></p>
|
||||||
</div>
|
</div>
|
||||||
<div className="error-detail">
|
<div className="error-detail">
|
||||||
<div className="error-name">
|
<div className="error-name">
|
||||||
|
@ -40,10 +40,11 @@ import { ModelSamplingRateRow, ModelSamplingRateRowProps } from "./components/30
|
|||||||
import { EnableEnhancerRow, EnableEnhancerRowProps } from "./components/610_EnableEnhancerRow"
|
import { EnableEnhancerRow, EnableEnhancerRowProps } from "./components/610_EnableEnhancerRow"
|
||||||
import { DstIdRow2, DstIdRow2Props } from "./components/602v2_DstIdRow2"
|
import { DstIdRow2, DstIdRow2Props } from "./components/602v2_DstIdRow2"
|
||||||
import { SilenceFrontRow, SilenceFrontRowProps } from "./components/812_SilenceFrontRow"
|
import { SilenceFrontRow, SilenceFrontRowProps } from "./components/812_SilenceFrontRow"
|
||||||
import { ModelSwitchRow, ModelSwitchRowProps } from "./components/204_ModelSwitchRow"
|
// import { ModelSwitchRow, ModelSwitchRowProps } from "./components/204_ModelSwitchRow"
|
||||||
import { ONNXExportRow, ONNXExportRowProps } from "./components/205_ONNXExportRow"
|
import { ONNXExportRow, ONNXExportRowProps } from "./components/205_ONNXExportRow"
|
||||||
import { ONNXExecutorRow, ONNXExecutorRowProps } from "./components/206_ONNXExecutorRow"
|
import { ONNXExecutorRow, ONNXExecutorRowProps } from "./components/206_ONNXExecutorRow"
|
||||||
import { MergeLabRow, MergeLabRowProps } from "./components/a01_MergeLab.Row"
|
import { MergeLabRow, MergeLabRowProps } from "./components/a01_MergeLab.Row"
|
||||||
|
import { ModelSwitchRow, ModelSwitchRowProps } from "./components/204v2_ModelSwitchRow"
|
||||||
|
|
||||||
export const catalog: { [key: string]: (props: any) => JSX.Element } = {}
|
export const catalog: { [key: string]: (props: any) => JSX.Element } = {}
|
||||||
|
|
||||||
|
@ -0,0 +1,75 @@
|
|||||||
|
import { Framework } from "@dannadori/voice-changer-client-js"
|
||||||
|
import React, { useMemo } from "react"
|
||||||
|
import { useAppState } from "../../../001_provider/001_AppStateProvider"
|
||||||
|
|
||||||
|
|
||||||
|
export type ModelSwitchRowProps = {
|
||||||
|
}
|
||||||
|
|
||||||
|
export const ModelSwitchRow = (_props: ModelSwitchRowProps) => {
|
||||||
|
const appState = useAppState()
|
||||||
|
|
||||||
|
const modelSwitchRow = useMemo(() => {
|
||||||
|
const slot = appState.serverSetting.serverSetting.modelSlotIndex
|
||||||
|
|
||||||
|
const onSwitchModelClicked = async (slot: number) => {
|
||||||
|
const modelSlot = appState.serverSetting.serverSetting.modelSlots[slot]
|
||||||
|
let filename = ""
|
||||||
|
if (modelSlot.pyTorchModelFile && modelSlot.pyTorchModelFile.length > 0) {
|
||||||
|
filename = modelSlot.pyTorchModelFile.replace(/^.*[\\\/]/, '')
|
||||||
|
} else {
|
||||||
|
filename = modelSlot.onnxModelFile.replace(/^.*[\\\/]/, '')
|
||||||
|
}
|
||||||
|
const framework: Framework = filename.endsWith(".onnx") ? "ONNX" : "PyTorch"
|
||||||
|
|
||||||
|
// Quick hack for same slot is selected. 下3桁が実際のSlotID
|
||||||
|
const dummyModelSlotIndex = (Math.floor(Date.now() / 1000)) * 1000 + slot
|
||||||
|
await appState.serverSetting.updateServerSettings({ ...appState.serverSetting.serverSetting, modelSlotIndex: dummyModelSlotIndex, framework: framework })
|
||||||
|
setTimeout(() => { // quick hack
|
||||||
|
appState.getInfo()
|
||||||
|
}, 1000 * 2)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const options = appState.serverSetting.serverSetting.modelSlots.map((x, index) => {
|
||||||
|
let filename = ""
|
||||||
|
if (x.pyTorchModelFile && x.pyTorchModelFile.length > 0) {
|
||||||
|
filename = x.pyTorchModelFile.replace(/^.*[\\\/]/, '')
|
||||||
|
} else if (x.onnxModelFile && x.onnxModelFile.length > 0) {
|
||||||
|
filename = x.onnxModelFile.replace(/^.*[\\\/]/, '')
|
||||||
|
} else {
|
||||||
|
return <div key={index} ></div>
|
||||||
|
}
|
||||||
|
const f0str = x.f0 == true ? "f0" : "nof0"
|
||||||
|
const srstr = Math.floor(x.samplingRate / 1000) + "K"
|
||||||
|
const embedstr = x.embChannels
|
||||||
|
const typestr = x.modelType == 0 ? "org" : "webui"
|
||||||
|
const metadata = x.deprecated ? "[deprecated version]" : `[${f0str},${srstr},${embedstr},${typestr}]`
|
||||||
|
const displayName = `[${metadata}] ${filename}`
|
||||||
|
|
||||||
|
|
||||||
|
return (
|
||||||
|
<option key={index} value={index}>{displayName}</option>
|
||||||
|
)
|
||||||
|
|
||||||
|
})
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div className="body-row split-3-7 left-padding-1 guided">
|
||||||
|
<div className="body-item-title left-padding-1">Swicth Model</div>
|
||||||
|
<div className="body-input-container">
|
||||||
|
<select className="body-select" value={slot} onChange={(e) => {
|
||||||
|
onSwitchModelClicked(Number(e.target.value))
|
||||||
|
appState.serverSetting.updateServerSettings({ ...appState.serverSetting.serverSetting, extraConvertSize: Number(e.target.value) })
|
||||||
|
}}>
|
||||||
|
{options}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
)
|
||||||
|
}, [appState.getInfo, appState.serverSetting.serverSetting])
|
||||||
|
|
||||||
|
return modelSwitchRow
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user