-
Notifications
You must be signed in to change notification settings - Fork 2.3k
/
Copy pathindex.html
241 lines (208 loc) · 7.72 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
<!--
Copyright 2018 Google LLC. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==============================================================================
-->
<!doctype html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="../shared/tfjs-examples.css" />
</head>
<style>
.tfjs-example-container {
width: calc(100vw - 600px);
}
.input-div {
padding: 5px;
font-family: monospace;
}
.predict-div {
padding: 5px;
padding-top: 20px;
}
.predict-table {
table-layout: fixed;
border-collapse: collapse;
border: 1px solid black;
}
.predict-table td {
padding: 5px;
}
td {
padding-left: 5px;
padding-right: 5px;
padding-bottom: 5px;
}
#predict-header {
font-weight: bold;
}
.output-div {
padding: 5px;
padding-top: 20px;
font-weight: bold;
}
#trainProg {
margin-top: 20px;
display: inline-block;
}
#image-input {
font-family: monospace;
position: relative;
width: 100%;
margin-top: 10px;
min-width: 800px;
}
</style>
<body>
<div class="tfjs-example-container">
<section class='title-area'>
<h1>MNIST CNN Transfer Learning</h1>
</section>
<section>
<p class='section-head'>Description</p>
<p>
This example demonstrates 're-training' of a pre-trained model in the browser. The model was initially
training-mode in Python and converted to TensorFlow.js format. The model can then be further trained using data
from the browser. Re-training an already trained network is called transfer learning.
</p>
<p>
In this case the pretrained model has been trained on a subset of the MNIST data: only digits 0 - 4. The
data we'll use for transfer learning in the browser consists of the digits 5 - 9. This example shows that the
first several layers of a pretrained model can be used as feature extractors on new data during transfer
learning
and thus result in faster training on the new data.
</p>
</section>
<section>
<p class='section-head'>Status</p>
<span id="status"></span>
</section>
<section>
<p class='section-head'>Load Model</p>
<div class="create-model">
<button id="load-pretrained-remote" style="display:none">Load hosted pretrained model</button>
<button id="load-pretrained-local" style="display:none">Load local pretrained model</button>
</div>
<p class='section-head'>Retrain Model</p>
<p>
When retraining the model 3 different approaches are available.
<ul>
<li>
<strong>Freeze feature layers:</strong> This is the most typical transfer learning procedure, we
freeze the first seven layers of the base model and only allow the final
5 layers to be trained on the new data.
</li>
<li><strong>Don't freeze feature layers:</strong> Choose this option to compare with the default option. A
few things to pay attention to include longer model convergence time and more larger shifts in weights (and
thus loss values) as the model trains.
</li>
<li><strong>Reinitialize weights:</strong> This will reset all the weights, effectively training the model
from scratch.
</ul>
</p>
<div class="retrain-div">
<div>
<span>Training mode:</span>
<select id="training-mode" class="form-control">
<option value="freeze-feature-layers">Freeze feature layers</option>
<option value="no-freezing">Don't freeze feature layers</option>
<option value="reinitialize-weights">Reinitialize weights</option>
</select>
<br>
<label>Epochs</label>
<input class="input" id="epochs" value="10" style="width:3em">
<br><br>
<button class="btn btn-primary" id="retrain" disabled="true"><span>Retrain</span></button>
</div>
<div>
</div>
<progress id="trainProg" value="0" max="100" style="width:35%"></progress>
</div>
</section>
<section>
<p class="section-head">Test Model</p>
<p>
Below is an "ASCII" bit map of some test examples from the digits in the new data set for transfer learning:
digits 5 through 9. The numbers are the grayscale integer values from the image. You can edit the values below
to see the effect of editing pixel values on the classification probabilities output by the model below.
</p>
<select id="test-image-select" class="form-control" disabled="true">
<option class="head">Select test example</option>
<option value="5_1">5_1</option>
<option value="5_2">5_2</option>
<option value="5_3">5_3</option>
<option value="5_4">5_4</option>
<option value="5_5">5_5</option>
<option value="5_6">5_6</option>
<option value="5_7">5_7</option>
<option value="5_8">5_8</option>
<option value="5_9">5_9</option>
<option value="5_10">5_10</option>
<option value="6_1">6_1</option>
<option value="6_2">6_2</option>
<option value="6_3">6_3</option>
<option value="6_4">6_4</option>
<option value="6_5">6_5</option>
<option value="6_6">6_6</option>
<option value="6_7">6_7</option>
<option value="6_8">6_8</option>
<option value="6_9">6_9</option>
<option value="6_10">6_10</option>
<option value="7_1">7_1</option>
<option value="7_2">7_2</option>
<option value="7_3">7_3</option>
<option value="7_4">7_4</option>
<option value="7_5">7_5</option>
<option value="7_6">7_6</option>
<option value="7_7">7_7</option>
<option value="7_8">7_8</option>
<option value="7_9">7_9</option>
<option value="7_10">7_10</option>
<option value="8_1">8_1</option>
<option value="8_2">8_2</option>
<option value="8_3">8_3</option>
<option value="8_4">8_4</option>
<option value="8_5">8_5</option>
<option value="8_6">8_6</option>
<option value="8_7">8_7</option>
<option value="8_8">8_8</option>
<option value="8_9">8_9</option>
<option value="8_10">8_10</option>
<option value="9_1">9_1</option>
<option value="9_2">9_2</option>
<option value="9_3">9_3</option>
<option value="9_4">9_4</option>
<option value="9_5">9_5</option>
<option value="9_6">9_6</option>
<option value="9_7">9_7</option>
<option value="9_8">9_8</option>
<option value="9_9">9_9</option>
<option value="9_10">9_10</option>
</select>
<textarea id="image-input" rows="28"></textarea>
<p class="section-head">Model Output</p>
<div class="predict-div">
<table class="predict-table">
<tr id="predict-header">
</tr>
<tr id="predict-values">
</tr>
</table>
</div>
<div class="output-div">
<span class="output-label">Output class: </span>
<span id="winner"></input>
</div>
</section>
</div>
<script type="module" src="index.js"></script>
</body>