|
@@ -42,21 +42,26 @@ VisualizerModel::VisualizerModel(std::shared_ptr<RemoteControlClient> &client, Q
|
|
|
m_networkConfig = reply->read<Configuration>();
|
|
|
for(int i = 0; i < m_networkConfig.sizes().size(); i++) {
|
|
|
m_layers.append(new NetworkLayerState);
|
|
|
- m_layers.last()->m_activations.setDimentions(m_networkConfig.sizes()[i], 1);
|
|
|
+ auto layerState = m_layers.last();
|
|
|
+ auto currenSize = m_networkConfig.sizes()[i];
|
|
|
+ auto &activations = layerState->m_activations;
|
|
|
+ auto &weights = layerState->m_weights;
|
|
|
+ activations.setDimentions(currenSize, 1);
|
|
|
QList<ValueIndicator*> data;
|
|
|
- for (int k = 0; k < m_networkConfig.sizes()[i]; k++) {
|
|
|
- data.append(new ValueIndicator);
|
|
|
+ for (int k = 0; k < currenSize; k++) {
|
|
|
+ data.append(new ValueIndicator(&activations));
|
|
|
}
|
|
|
- m_layers.last()->m_activations.setData(data);
|
|
|
+ activations.setData(data);
|
|
|
|
|
|
if (i != 0) {
|
|
|
- int tolalItems = m_networkConfig.sizes()[i]*m_networkConfig.sizes()[i - 1];
|
|
|
- m_layers.last()->m_weights.setDimentions(m_networkConfig.sizes()[i], m_networkConfig.sizes()[i - 1]);
|
|
|
+ auto previousSize = m_networkConfig.sizes()[i - 1];
|
|
|
+ int tolalItems = currenSize * previousSize;
|
|
|
+ weights.setDimentions(currenSize,previousSize);
|
|
|
data.clear();
|
|
|
for (int k = 0; k < tolalItems; k++) {
|
|
|
- data.append(new ValueIndicator);
|
|
|
+ data.append(new ValueIndicator(&weights));
|
|
|
}
|
|
|
- m_layers.last()->m_weights.setData(data);
|
|
|
+ weights.setData(data);
|
|
|
}
|
|
|
}
|
|
|
sizesChanged();
|
|
@@ -66,25 +71,19 @@ VisualizerModel::VisualizerModel(std::shared_ptr<RemoteControlClient> &client, Q
|
|
|
if (m_layers.isEmpty()) {
|
|
|
return;
|
|
|
}
|
|
|
- Dense dense(activations.matrix().matrix());
|
|
|
- m_layers[activations.layer()]->m_activations.updateValues(Dense(activations.matrix().matrix()));
|
|
|
-// qDebug() << "ActivationsUpdated:" << dense.rows() << dense.columns() << activations.layer();
|
|
|
- });
|
|
|
- QObject::connect(client.get(), &remotecontrol::RemoteControlClient::BiasesUpdated, [this](const remotecontrol::LayerMatrix &biases) {
|
|
|
- if (m_layers.isEmpty()) {
|
|
|
- return;
|
|
|
- }
|
|
|
- Dense dense(biases.matrix().matrix());
|
|
|
-// qDebug() << "BiasesUpdated:" << dense.rows() << dense.columns();
|
|
|
+ auto layer = m_layers[activations.layer()];
|
|
|
+ layer->m_activations.updateValues(Dense(activations.matrix().matrix()));
|
|
|
+ layer->m_actiovationTrigger.updateLayer();
|
|
|
});
|
|
|
QObject::connect(client.get(), &remotecontrol::RemoteControlClient::WeightsUpdated, [this](const remotecontrol::LayerMatrix &weights) {
|
|
|
if (m_layers.isEmpty()) {
|
|
|
return;
|
|
|
}
|
|
|
- m_layers[weights.layer()]->m_weights.updateValues(Dense(weights.matrix().matrix()));
|
|
|
+ auto layer = m_layers[weights.layer()];
|
|
|
+ layer->m_weights.updateValues(Dense(weights.matrix().matrix()));
|
|
|
+ layer->m_weightTrigger.updateLayer();
|
|
|
});
|
|
|
client->subscribeActivationsUpdates({});
|
|
|
- client->subscribeBiasesUpdates({});
|
|
|
client->subscribeWeightsUpdates({});
|
|
|
}
|
|
|
|
|
@@ -101,3 +100,17 @@ ValueIndicator *VisualizerModel::weight(int layer, int row, int column)
|
|
|
QQmlEngine::setObjectOwnership(indicator, QQmlEngine::CppOwnership);
|
|
|
return indicator;
|
|
|
}
|
|
|
+
|
|
|
+LayerTrigger *VisualizerModel::activationTrigger(int layer)
|
|
|
+{
|
|
|
+ LayerTrigger* trigger = &m_layers[layer]->m_actiovationTrigger;
|
|
|
+ QQmlEngine::setObjectOwnership(trigger, QQmlEngine::CppOwnership);
|
|
|
+ return trigger;
|
|
|
+}
|
|
|
+
|
|
|
+LayerTrigger *VisualizerModel::weightTrigger(int layer)
|
|
|
+{
|
|
|
+ LayerTrigger* trigger = &m_layers[layer]->m_weightTrigger;
|
|
|
+ QQmlEngine::setObjectOwnership(trigger, QQmlEngine::CppOwnership);
|
|
|
+ return trigger;
|
|
|
+}
|