mirror of https://github.com/vladmandic/human
58 lines
6.6 KiB
HTML
58 lines
6.6 KiB
HTML
![]() |
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<title>FaceRes Tests</title>
|
||
|
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
||
|
<meta name="viewport" content="width=device-width, shrink-to-fit=yes">
|
||
|
</head>
|
||
|
<body style="font-size: 12px; margin: 0; background: black; color: white; width: 100vw; line-height: 200%">
|
||
|
<pre id="log"></pre>
|
||
|
<script type="module">
|
||
|
import 'https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@3.20.0/dist/tf.es2017.js'
|
||
|
|
||
|
async function log(msg) {
|
||
|
document.getElementById('log').innerHTML += (typeof msg === 'object' ? JSON.stringify(msg, null, 0) : msg) + '<br>';
|
||
|
console.log(msg);
|
||
|
}
|
||
|
|
||
|
async function image2tensor(url) {
|
||
|
const img = document.createElement('img');
|
||
|
const loaded = new Promise((resolve) => { img.onload = () => resolve(true); });
|
||
|
img.src = url;
|
||
|
await loaded;
|
||
|
const tensor = tf.browser.fromPixels(img, 3).expandDims(0).cast('float32');
|
||
|
return tensor;
|
||
|
}
|
||
|
|
||
|
|
||
|
async function main() {
|
||
|
log({ version: tf.version });
|
||
|
tf.enableDebugMode();
|
||
|
tf.setBackend('webgl');
|
||
|
const params = new URLSearchParams(window.location.search);
|
||
|
if (params.has('uniforms')) tf.env().set('WEBGL_USE_SHAPES_UNIFORMS', true);
|
||
|
await tf.ready();
|
||
|
log({ backend: tf.getBackend() });
|
||
|
log({ flags: tf.env().flags });
|
||
|
log({ uniforms: tf.env().flags['WEBGL_USE_SHAPES_UNIFORMS'] ? true : false })
|
||
|
const model = await tf.loadGraphModel('https://vladmandic.github.io/human/models/faceres.json');
|
||
|
log({ model: model.modelUrl });
|
||
|
// const input = tf.randomUniform([1, 224, 224, 3], 0, 1, 'float32');
|
||
|
const input = await image2tensor(imgDataUrl);
|
||
|
log({ input: input.shape });
|
||
|
const res = model.execute(input);
|
||
|
const data = res.map((t) => Array.from(t.dataSync()));
|
||
|
for (let i = 0; i < res.length; i++) {
|
||
|
log({ result: i, tensor: res[i] })
|
||
|
log({ result: i, data: data[i] })
|
||
|
log({ result: i, status: (data[i][0] && data[i].reduce((prev, curr) => (prev && (curr >= 0)), true)) ? 'pass' : 'fail' })
|
||
|
}
|
||
|
}
|
||
|
|
||
|
const imgDataUrl = '
|
||
|
|
||
|
window.onload = main;
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|