From f7f873f188a9a2ec3a404455622332407d115bb7 Mon Sep 17 00:00:00 2001 From: yiboyasss <143868051+yiboyasss@users.noreply.github.com> Date: Fri, 25 Oct 2024 11:09:40 +0800 Subject: [PATCH] FEAT: [UI] Image model with the lora_config. (#2482) --- .../ui/src/scenes/launch_model/modelCard.js | 424 ++++++++++-------- 1 file changed, 239 insertions(+), 185 deletions(-) diff --git a/xinference/web/ui/src/scenes/launch_model/modelCard.js b/xinference/web/ui/src/scenes/launch_model/modelCard.js index a4391f830a..bcffbace11 100644 --- a/xinference/web/ui/src/scenes/launch_model/modelCard.js +++ b/xinference/web/ui/src/scenes/launch_model/modelCard.js @@ -327,6 +327,9 @@ const ModelCard = ({ modelDataWithID_LLM.n_gpu_layers = nGPULayers } + const modelDataWithID = + modelType === 'LLM' ? modelDataWithID_LLM : modelDataWithID_other + if ( loraListArr.length || imageLoraLoadKwargsArr.length || @@ -354,12 +357,9 @@ const ModelCard = ({ }) peft_model_config['lora_list'] = lora_list } - modelDataWithID_LLM['peft_model_config'] = peft_model_config + modelDataWithID['peft_model_config'] = peft_model_config } - const modelDataWithID = - modelType === 'LLM' ? modelDataWithID_LLM : modelDataWithID_other - if (customParametersArr.length) { customParametersArr.forEach((item) => { modelDataWithID[item.key] = handleValueType(item.value) @@ -376,10 +376,15 @@ const ModelCard = ({ `/running_models/${modelType}` ) let historyArr = JSON.parse(localStorage.getItem('historyArr')) || [] - if (!historyArr.some((item) => deepEqual(item, modelDataWithID))) { - historyArr = historyArr.filter( - (item) => item.model_name !== modelDataWithID.model_name - ) + const historyModelNameArr = historyArr.map((item) => item.model_name) + if (historyModelNameArr.includes(modelDataWithID.model_name)) { + historyArr = historyArr.map((item) => { + if (item.model_name === modelDataWithID.model_name) { + return modelDataWithID + } + return item + }) + } else { historyArr.push(modelDataWithID) } localStorage.setItem('historyArr', JSON.stringify(historyArr)) @@ -600,28 +605,10 @@ const ModelCard = ({ }) setLoraArr(loraData) - let ImageLoraLoadData = [] - for (let key in peft_model_config?.image_lora_load_kwargs) { - ImageLoraLoadData.push({ - key: key, - value: peft_model_config?.image_lora_load_kwargs[key], - }) - } - setImageLoraLoadArr(ImageLoraLoadData) - - let ImageLoraFuseData = [] - for (let key in peft_model_config?.image_lora_fuse_kwargs) { - ImageLoraFuseData.push({ - key: key, - value: peft_model_config?.image_lora_fuse_kwargs[key], - }) - } - setImageLoraFuseArr(ImageLoraFuseData) - let customData = [] for (let key in arr[0]) { !llmAllDataKey.includes(key) && - customData.push({ key: key, value: arr[0][key] }) + customData.push({ key: key, value: arr[0][key] || 'none' }) } setCustomArr(customData) @@ -635,11 +622,7 @@ const ModelCard = ({ ) setIsOther(true) - if ( - loraData.length || - ImageLoraLoadData.length || - ImageLoraFuseData.length - ) { + if (loraData.length) { setIsOther(true) setIsPeftModelConfig(true) } @@ -657,37 +640,54 @@ const ModelCard = ({ setDownloadHub(arr[0].download_hub || '') setModelPath(arr[0].model_path || '') + if (arr[0].model_type === 'image') { + let loraData = [] + arr[0].peft_model_config?.lora_list?.forEach((item) => { + loraData.push({ + lora_name: item.lora_name, + local_path: item.local_path, + }) + }) + setLoraArr(loraData) + + let ImageLoraLoadData = [] + for (let key in arr[0].peft_model_config?.image_lora_load_kwargs) { + ImageLoraLoadData.push({ + key: key, + value: + arr[0].peft_model_config?.image_lora_load_kwargs[key] || 'none', + }) + } + setImageLoraLoadArr(ImageLoraLoadData) + + let ImageLoraFuseData = [] + for (let key in arr[0].peft_model_config?.image_lora_fuse_kwargs) { + ImageLoraFuseData.push({ + key: key, + value: + arr[0].peft_model_config?.image_lora_fuse_kwargs[key] || 'none', + }) + } + setImageLoraFuseArr(ImageLoraFuseData) + + if ( + loraData.length || + ImageLoraLoadData.length || + ImageLoraFuseData.length + ) { + setIsPeftModelConfig(true) + } + } + let customData = [] for (let key in arr[0]) { !llmAllDataKey.includes(key) && - customData.push({ key: key, value: arr[0][key] }) + customData.push({ key: key, value: arr[0][key] || 'none' }) } setCustomArr(customData) } } - const deepEqual = (obj1, obj2) => { - if (obj1 === obj2) return true - if ( - typeof obj1 !== 'object' || - typeof obj2 !== 'object' || - obj1 == null || - obj2 == null - ) { - return false - } - - let keysA = Object.keys(obj1) - let keysB = Object.keys(obj2) - if (keysA.length !== keysB.length) return false - for (let key of keysA) { - if (!keysB.includes(key) || !deepEqual(obj1[key], obj2[key])) { - return false - } - } - return true - } - const handleCollection = (bool) => { setHover(false) @@ -725,8 +725,6 @@ const ModelCard = ({ setDownloadHub('') setModelPath('') setLoraArr([]) - setImageLoraLoadArr([]) - setImageLoraFuseArr([]) setCustomArr([]) setIsOther(false) setIsPeftModelConfig(false) @@ -738,6 +736,11 @@ const ModelCard = ({ setWorkerIp('') setDownloadHub('') setModelPath('') + setLoraArr([]) + setImageLoraLoadArr([]) + setImageLoraFuseArr([]) + setCustomArr([]) + setIsPeftModelConfig(false) } } @@ -991,7 +994,14 @@ const ModelCard = ({ {(() => { if (modelData.language) { return modelData.language.map((v) => { - return + return ( + + ) }) } else if (modelData.model_family) { return ( @@ -1446,30 +1456,6 @@ const ModelCard = ({ onJudgeArr={judgeArr} pairData={loraArr} /> - { - setImageLoraLoadKwargsArr(arr) - }} - onJudgeArr={judgeArr} - pairData={imageLoraLoadArr} - /> - { - setImageLoraFuseKwargsArr(arr) - }} - onJudgeArr={judgeArr} - pairData={imageLoraFuseArr} - /> ) : ( - - setModelUID(e.target.value)} - /> - setReplica(parseInt(e.target.value, 10))} - /> + - Device - - - {nGpu === 'GPU' && ( + setModelUID(e.target.value)} + /> + setReplica(parseInt(e.target.value, 10))} + /> + + Device + + + {nGpu === 'GPU' && ( + + { + setGPUIdxAlert(false) + setGPUIdx(e.target.value) + const regular = /^\d+(?:,\d+)*$/ + if ( + e.target.value !== '' && + !regular.test(e.target.value) + ) { + setGPUIdxAlert(true) + } + }} + /> + {GPUIdxAlert && ( + + Please enter numeric data separated by commas, for + example: 0,1,2 + + )} + + )} setWorkerIp(e.target.value)} + /> + + + + (Optional) Download_hub + + + + + setModelPath(e.target.value)} /> - {GPUIdxAlert && ( - - Please enter numeric data separated by commas, for - example: 0,1,2 - - )} - )} - - setWorkerIp(e.target.value)} - /> - - - - (Optional) Download_hub - - - - - setModelPath(e.target.value)} + onGetArr={(arr) => { + setCustomParametersArr(arr) + }} + onJudgeArr={judgeArr} + pairData={customArr} /> - { - setCustomParametersArr(arr) - }} - onJudgeArr={judgeArr} - pairData={customArr} - /> - + )}