Spaces:
Runtime error
Runtime error
Julien Chaumond
commited on
Commit
·
e246102
1
Parent(s):
1909611
Feedback from @thomwolf , @victorsanh et. al.
Browse files- front/assets/Icon-info.svg +9 -0
- front/assets/thumbnail-large.png +0 -0
- front/favicon.ico +0 -0
- front/index.html +15 -8
- front/js-src/controller.ts +41 -6
- front/less/style.less +31 -2
front/assets/Icon-info.svg
ADDED
|
|
front/assets/thumbnail-large.png
ADDED
|
|
front/favicon.ico
ADDED
|
|
front/index.html
CHANGED
|
@@ -2,10 +2,14 @@
|
|
| 2 |
<html>
|
| 3 |
<head>
|
| 4 |
<meta charset="utf-8">
|
| 5 |
-
<title>Hugging Face –
|
| 6 |
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
|
| 7 |
<link rel="stylesheet" href="/dist/style.css">
|
| 8 |
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono|IBM+Plex+Sans:400,700" rel="stylesheet">
|
|
|
|
|
|
|
|
|
|
|
|
|
| 9 |
</head>
|
| 10 |
<body>
|
| 11 |
<div class="header">
|
|
@@ -14,7 +18,7 @@
|
|
| 14 |
🦄 How to build a State-of-the-Art Conversational AI with Transfer Learning
|
| 15 |
</div>
|
| 16 |
<div class="links">
|
| 17 |
-
<a target="_blank" href="https://medium.com
|
| 18 |
<a target="_blank" href="https://github.com/huggingface/transfer-learning-conv-ai"><img src="/assets/iconmonstr-github-1.svg"></a>
|
| 19 |
</div>
|
| 20 |
</div>
|
|
@@ -34,10 +38,10 @@
|
|
| 34 |
</div>
|
| 35 |
<div class="box box1">
|
| 36 |
<div class="clearfix">
|
| 37 |
-
<div class="title"
|
| 38 |
</div>
|
| 39 |
<div class="description">
|
| 40 |
-
The machine learning model created a
|
| 41 |
these few lines of bio. You can now chat with this persona below.
|
| 42 |
</div>
|
| 43 |
<div class="gauge">
|
|
@@ -76,24 +80,27 @@
|
|
| 76 |
|
| 77 |
|
| 78 |
<div class="decoder-settings">
|
| 79 |
-
<div class="title">
|
|
|
|
|
|
|
|
|
|
| 80 |
<div class="setting">
|
| 81 |
<div class="desc">
|
| 82 |
<span>Top-k</span><span class="js-val"></span>
|
| 83 |
</div>
|
| 84 |
-
<input class="slider" type="range" min="0" max="
|
| 85 |
</div>
|
| 86 |
<div class="setting">
|
| 87 |
<div class="desc">
|
| 88 |
<span>Top-p</span><span class="js-val"></span>
|
| 89 |
</div>
|
| 90 |
-
<input class="slider" type="range" min="0" max="1" step="any" value="0.9">
|
| 91 |
</div>
|
| 92 |
<div class="setting">
|
| 93 |
<div class="desc">
|
| 94 |
<span>Temperature</span><span class="js-val"></span>
|
| 95 |
</div>
|
| 96 |
-
<input class="slider" type="range" min="0" max="
|
| 97 |
</div>
|
| 98 |
</div>
|
| 99 |
|
|
|
|
| 2 |
<html>
|
| 3 |
<head>
|
| 4 |
<meta charset="utf-8">
|
| 5 |
+
<title>Hugging Face – ConvAI</title>
|
| 6 |
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
|
| 7 |
<link rel="stylesheet" href="/dist/style.css">
|
| 8 |
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono|IBM+Plex+Sans:400,700" rel="stylesheet">
|
| 9 |
+
<meta property="og:url" content="https://convai.huggingface.co/">
|
| 10 |
+
<meta property="og:image" content="https://convai.huggingface.co/assets/thumbnail-large.png">
|
| 11 |
+
<meta property="fb:app_id" content="1321688464574422">
|
| 12 |
+
<meta name="description" content="🦄 How to build a State-of-the-Art Conversational AI with Transfer Learning">
|
| 13 |
</head>
|
| 14 |
<body>
|
| 15 |
<div class="header">
|
|
|
|
| 18 |
🦄 How to build a State-of-the-Art Conversational AI with Transfer Learning
|
| 19 |
</div>
|
| 20 |
<div class="links">
|
| 21 |
+
<a target="_blank" href="https://medium.com/huggingface/how-to-build-a-state-of-the-art-conversational-ai-with-transfer-learning-2d818ac26313"><img src="/assets/iconmonstr-medium-1.svg"></a>
|
| 22 |
<a target="_blank" href="https://github.com/huggingface/transfer-learning-conv-ai"><img src="/assets/iconmonstr-github-1.svg"></a>
|
| 23 |
</div>
|
| 24 |
</div>
|
|
|
|
| 38 |
</div>
|
| 39 |
<div class="box box1">
|
| 40 |
<div class="clearfix">
|
| 41 |
+
<div class="title">Start chatting</div>
|
| 42 |
</div>
|
| 43 |
<div class="description">
|
| 44 |
+
The machine learning model created a consistent persona based on
|
| 45 |
these few lines of bio. You can now chat with this persona below.
|
| 46 |
</div>
|
| 47 |
<div class="gauge">
|
|
|
|
| 80 |
|
| 81 |
|
| 82 |
<div class="decoder-settings">
|
| 83 |
+
<div class="title">
|
| 84 |
+
Decoder settings
|
| 85 |
+
<a target="_blank" href="https://medium.com/huggingface/how-to-build-a-state-of-the-art-conversational-ai-with-transfer-learning-2d818ac26313#79c5"><img src="/assets/Icon-info.svg"></a>
|
| 86 |
+
</div>
|
| 87 |
<div class="setting">
|
| 88 |
<div class="desc">
|
| 89 |
<span>Top-k</span><span class="js-val"></span>
|
| 90 |
</div>
|
| 91 |
+
<input class="slider" type="range" min="0" max="200" step="1" value="0">
|
| 92 |
</div>
|
| 93 |
<div class="setting">
|
| 94 |
<div class="desc">
|
| 95 |
<span>Top-p</span><span class="js-val"></span>
|
| 96 |
</div>
|
| 97 |
+
<input class="slider js-inverted" type="range" min="0" max="1" step="any" value="0.9">
|
| 98 |
</div>
|
| 99 |
<div class="setting">
|
| 100 |
<div class="desc">
|
| 101 |
<span>Temperature</span><span class="js-val"></span>
|
| 102 |
</div>
|
| 103 |
+
<input class="slider" type="range" min="0" max="2" step="any" value="0.6">
|
| 104 |
</div>
|
| 105 |
</div>
|
| 106 |
|
front/js-src/controller.ts
CHANGED
|
@@ -4,9 +4,13 @@ const App = {
|
|
| 4 |
text: "",
|
| 5 |
},
|
| 6 |
messages: [] as Message[],
|
|
|
|
| 7 |
messagesRoot: document.querySelector('div.messages') as HTMLDivElement,
|
| 8 |
divPersona: document.querySelector('div.persona') as HTMLDivElement,
|
| 9 |
linkSuggest: document.querySelector('.chat-suggestion .js-suggestion') as HTMLLinkElement,
|
|
|
|
|
|
|
|
|
|
| 10 |
};
|
| 11 |
|
| 12 |
document.addEventListener('DOMContentLoaded', () => {
|
|
@@ -45,7 +49,7 @@ document.addEventListener('DOMContentLoaded', () => {
|
|
| 45 |
App.persona = await Api.shared.getShuffle();
|
| 46 |
tokenizePersona();
|
| 47 |
history.replaceState(null, "", `/persona/${App.persona.slug}`);
|
| 48 |
-
/// Also reset messages.
|
| 49 |
App.messages = [];
|
| 50 |
App.messagesRoot.innerHTML = "";
|
| 51 |
loadSuggestion();
|
|
@@ -77,11 +81,18 @@ document.addEventListener('DOMContentLoaded', () => {
|
|
| 77 |
} else {
|
| 78 |
spanVal.className = "js-val red";
|
| 79 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 80 |
};
|
| 81 |
-
const
|
| 82 |
-
document.querySelectorAll('.decoder-settings input.slider')
|
| 83 |
-
) as HTMLInputElement[];
|
| 84 |
-
for (const slider of sliders) {
|
| 85 |
handleSliderChange(slider);
|
| 86 |
slider.addEventListener('input', () => {
|
| 87 |
handleSliderChange(slider);
|
|
@@ -90,8 +101,32 @@ document.addEventListener('DOMContentLoaded', () => {
|
|
| 90 |
|
| 91 |
const gauge = document.querySelector('div.gauge') as HTMLDivElement;
|
| 92 |
gauge.addEventListener('click', () => {
|
| 93 |
-
gauge.classList.
|
| 94 |
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 95 |
|
| 96 |
/**
|
| 97 |
* Chat input
|
|
|
|
| 4 |
text: "",
|
| 5 |
},
|
| 6 |
messages: [] as Message[],
|
| 7 |
+
/// HTMLElements
|
| 8 |
messagesRoot: document.querySelector('div.messages') as HTMLDivElement,
|
| 9 |
divPersona: document.querySelector('div.persona') as HTMLDivElement,
|
| 10 |
linkSuggest: document.querySelector('.chat-suggestion .js-suggestion') as HTMLLinkElement,
|
| 11 |
+
sliders: Array.from(
|
| 12 |
+
document.querySelectorAll('.decoder-settings input.slider')
|
| 13 |
+
) as HTMLInputElement[],
|
| 14 |
};
|
| 15 |
|
| 16 |
document.addEventListener('DOMContentLoaded', () => {
|
|
|
|
| 49 |
App.persona = await Api.shared.getShuffle();
|
| 50 |
tokenizePersona();
|
| 51 |
history.replaceState(null, "", `/persona/${App.persona.slug}`);
|
| 52 |
+
/// Also reset messages and reload suggestion.
|
| 53 |
App.messages = [];
|
| 54 |
App.messagesRoot.innerHTML = "";
|
| 55 |
loadSuggestion();
|
|
|
|
| 81 |
} else {
|
| 82 |
spanVal.className = "js-val red";
|
| 83 |
}
|
| 84 |
+
const isInverted = slider.classList.contains('js-inverted');
|
| 85 |
+
if (isInverted) {
|
| 86 |
+
if (spanVal.classList.contains('green')) {
|
| 87 |
+
spanVal.classList.remove('green');
|
| 88 |
+
spanVal.classList.add('red');
|
| 89 |
+
} else if (spanVal.classList.contains('red')) {
|
| 90 |
+
spanVal.classList.remove('red');
|
| 91 |
+
spanVal.classList.add('green');
|
| 92 |
+
}
|
| 93 |
+
}
|
| 94 |
};
|
| 95 |
+
for (const slider of App.sliders) {
|
|
|
|
|
|
|
|
|
|
| 96 |
handleSliderChange(slider);
|
| 97 |
slider.addEventListener('input', () => {
|
| 98 |
handleSliderChange(slider);
|
|
|
|
| 101 |
|
| 102 |
const gauge = document.querySelector('div.gauge') as HTMLDivElement;
|
| 103 |
gauge.addEventListener('click', () => {
|
| 104 |
+
gauge.classList.add('active');
|
| 105 |
});
|
| 106 |
+
const gaugeEls = Array.from(
|
| 107 |
+
document.querySelectorAll('.gauge .gauge-el-wrapper')
|
| 108 |
+
);
|
| 109 |
+
for (const gaugeEl of gaugeEls) {
|
| 110 |
+
gaugeEl.addEventListener('click', () => {
|
| 111 |
+
const i = gaugeEls.indexOf(gaugeEl);
|
| 112 |
+
if (i === 0) {
|
| 113 |
+
App.sliders[0].value = `180`;
|
| 114 |
+
App.sliders[1].value = `0.1`;
|
| 115 |
+
App.sliders[2].value = `1.9`;
|
| 116 |
+
} else if (i === 1) {
|
| 117 |
+
App.sliders[0].value = `70`;
|
| 118 |
+
App.sliders[1].value = `0.5`;
|
| 119 |
+
App.sliders[2].value = `1.2`;
|
| 120 |
+
} else {
|
| 121 |
+
App.sliders[0].value = `0`;
|
| 122 |
+
App.sliders[1].value = `0.9`;
|
| 123 |
+
App.sliders[2].value = `0.6`;
|
| 124 |
+
}
|
| 125 |
+
for (const slider of App.sliders) {
|
| 126 |
+
handleSliderChange(slider);
|
| 127 |
+
}
|
| 128 |
+
});
|
| 129 |
+
}
|
| 130 |
|
| 131 |
/**
|
| 132 |
* Chat input
|
front/less/style.less
CHANGED
|
@@ -106,8 +106,8 @@ div.subheader {
|
|
| 106 |
.gauge {
|
| 107 |
.clearfix();
|
| 108 |
padding: 14px 0;
|
| 109 |
-
cursor: pointer;
|
| 110 |
.gauge-el-wrapper {
|
|
|
|
| 111 |
position: relative;
|
| 112 |
box-sizing: border-box;
|
| 113 |
float: left;
|
|
@@ -129,6 +129,7 @@ div.subheader {
|
|
| 129 |
background-color: red;
|
| 130 |
}
|
| 131 |
.legend {
|
|
|
|
| 132 |
font-size: 11px;
|
| 133 |
font-weight: bold;
|
| 134 |
position: absolute;
|
|
@@ -153,6 +154,14 @@ div.decoder-settings {
|
|
| 153 |
padding: 2px 6px;
|
| 154 |
.title {
|
| 155 |
font-size: 11px;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 156 |
}
|
| 157 |
.setting {
|
| 158 |
.desc {
|
|
@@ -183,7 +192,7 @@ div.chat-container {
|
|
| 183 |
}
|
| 184 |
.placeholder-start {
|
| 185 |
position: absolute;
|
| 186 |
-
top:
|
| 187 |
left: 0; right: 0;
|
| 188 |
.inner {
|
| 189 |
width: 260px;
|
|
@@ -269,3 +278,23 @@ span.attention-level {
|
|
| 269 |
&.level3 { background-color: #FFCF00; }
|
| 270 |
&.level4 { background-color: #BEFF00; }
|
| 271 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 106 |
.gauge {
|
| 107 |
.clearfix();
|
| 108 |
padding: 14px 0;
|
|
|
|
| 109 |
.gauge-el-wrapper {
|
| 110 |
+
cursor: pointer;
|
| 111 |
position: relative;
|
| 112 |
box-sizing: border-box;
|
| 113 |
float: left;
|
|
|
|
| 129 |
background-color: red;
|
| 130 |
}
|
| 131 |
.legend {
|
| 132 |
+
.user-select(none);
|
| 133 |
font-size: 11px;
|
| 134 |
font-weight: bold;
|
| 135 |
position: absolute;
|
|
|
|
| 154 |
padding: 2px 6px;
|
| 155 |
.title {
|
| 156 |
font-size: 11px;
|
| 157 |
+
img {
|
| 158 |
+
margin-left: 4px;
|
| 159 |
+
vertical-align: middle;
|
| 160 |
+
opacity: 0.5;
|
| 161 |
+
&:hover {
|
| 162 |
+
opacity: 0.8;
|
| 163 |
+
}
|
| 164 |
+
}
|
| 165 |
}
|
| 166 |
.setting {
|
| 167 |
.desc {
|
|
|
|
| 192 |
}
|
| 193 |
.placeholder-start {
|
| 194 |
position: absolute;
|
| 195 |
+
top: 45%;
|
| 196 |
left: 0; right: 0;
|
| 197 |
.inner {
|
| 198 |
width: 260px;
|
|
|
|
| 278 |
&.level3 { background-color: #FFCF00; }
|
| 279 |
&.level4 { background-color: #BEFF00; }
|
| 280 |
}
|
| 281 |
+
|
| 282 |
+
|
| 283 |
+
/**
|
| 284 |
+
* Media queries
|
| 285 |
+
*/
|
| 286 |
+
|
| 287 |
+
@media (max-width: 630px) {
|
| 288 |
+
div.decoder-settings {
|
| 289 |
+
position: static;
|
| 290 |
+
margin-top: 32px;
|
| 291 |
+
width: initial;
|
| 292 |
+
}
|
| 293 |
+
}
|
| 294 |
+
|
| 295 |
+
@media (min-height: 800px) {
|
| 296 |
+
/// would probably be way better with css variables
|
| 297 |
+
div.chat-container .messages {
|
| 298 |
+
height: 300px;
|
| 299 |
+
}
|
| 300 |
+
}
|