let nvmlInterval = null; // eslint-disable-line prefer-const let nvmlEl = null; let nvmlTable = null; const chartData = { mem: [], load: [] }; async function updateNVMLChart(mem, load) { const maxLen = 120; const colorRangeMap = $.range_map({ // eslint-disable-line no-undef '0:5': '#fffafa', '6:10': '#fff7ed', '11:20': '#fed7aa', '21:30': '#fdba74', '31:40': '#fb923c', '41:50': '#f97316', '51:60': '#ea580c', '61:70': '#c2410c', '71:80': '#9a3412', '81:90': '#7c2d12', '91:100': '#6c2e12', }); const sparklineConfigLOAD = { type: 'bar', height: '100px', barWidth: '2px', barSpacing: '1px', chartRangeMin: 0, chartRangeMax: 100, barColor: '#89007D' }; const sparklineConfigMEM = { type: 'bar', height: '100px', barWidth: '2px', barSpacing: '1px', chartRangeMin: 0, chartRangeMax: 100, colorMap: colorRangeMap, composite: true }; if (chartData.load.length > maxLen) chartData.load.shift(); chartData.load.push(load); if (chartData.mem.length > maxLen) chartData.mem.shift(); chartData.mem.push(mem); $('#nvmlChart').sparkline(chartData.load, sparklineConfigLOAD); // eslint-disable-line no-undef $('#nvmlChart').sparkline(chartData.mem, sparklineConfigMEM); // eslint-disable-line no-undef } async function updateNVML() { try { const res = await fetch(`${window.api}/nvml`); if (!res.ok) { clearInterval(nvmlInterval); nvmlEl.style.display = 'none'; return; } const data = await res.json(); if (!data) { clearInterval(nvmlInterval); nvmlEl.style.display = 'none'; return; } const nvmlTbody = nvmlTable.querySelector('tbody'); for (const gpu of data) { const rows = ` GPU${gpu.name} Driver${gpu.version.driver} VBIOS${gpu.version.vbios} ROM${gpu.version.rom} Driver${gpu.version.driver} PCIGen.${gpu.pci.link} x${gpu.pci.width} Memory${gpu.memory.used}Mb / ${gpu.memory.total}Mb Clock${gpu.clock.gpu[0]}Mhz / ${gpu.clock.gpu[1]}Mhz Power${gpu.power[0]}W / ${gpu.power[1]}W Load GPU${gpu.load.gpu}% Load Memory${gpu.load.memory}% Temperature${gpu.load.temp}°C Fans${gpu.load.fan}% State${gpu.state} `; nvmlTbody.innerHTML = rows; updateNVMLChart(gpu.load.memory, gpu.load.gpu); } nvmlEl.style.display = 'block'; } catch (e) { clearInterval(nvmlInterval); nvmlEl.style.display = 'none'; } } async function initNVML() { nvmlEl = document.getElementById('nvml'); if (!nvmlEl) { nvmlEl = document.createElement('div'); nvmlEl.className = 'nvml'; nvmlEl.id = 'nvml'; nvmlTable = document.createElement('table'); nvmlTable.className = 'nvml-table'; nvmlTable.id = 'nvml-table'; nvmlTable.innerHTML = ` `; const nvmlChart = document.createElement('div'); nvmlChart.id = 'nvmlChart'; nvmlEl.appendChild(nvmlTable); nvmlEl.appendChild(nvmlChart); gradioApp().appendChild(nvmlEl); log('initNVML'); } if (nvmlInterval) { clearInterval(nvmlInterval); nvmlInterval = null; nvmlEl.style.display = 'none'; } else { nvmlInterval = setInterval(updateNVML, 1000); } } async function disableNVML() { clearInterval(nvmlInterval); nvmlEl.style.display = 'none'; }