-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathOutputUnit.cpp
More file actions
84 lines (69 loc) · 2.03 KB
/
OutputUnit.cpp
File metadata and controls
84 lines (69 loc) · 2.03 KB
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
/*
Copyright 2012 Eugen Hristev Licensed under the
Educational Community 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.osedu.org/licenses/ECL-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.
*/
#include "OutputUnit.h"
#include "Unit.h"
#include "assert.h"
#include "narx_util.h"
#include "Activation_functions.h"
OutputUnit::OutputUnit(void): Unit()
{
target = 0;
}
OutputUnit::~OutputUnit(void)
{
}
void OutputUnit::setTarget(double target)
{
this->target = target;
}
double OutputUnit::error()
{
return target - get_output();
}
void OutputUnit::adjust_weights()
{
//deltao = activation_func_derv(pre_output()) * error();
for(int i = 0; i < input_count; i ++) {
input_weights[i] += Unit::alfa * deltao * input_area[i]->get_output();
//
}
}
void OutputUnit::compute_delta(double superior_layer_delta)
{
deltao = activation_func_derv(pre_output()) * superior_layer_delta;
}
void OutputUnit::compute_delta()
{
deltao = activation_func_derv(pre_output()) * error();
}
double OutputUnit::get_delta(Unit *u)
{
for (int i = 0; i < input_count; i++)
if (u == input_area[i]) {
return deltao * old_weights[i];
}
assert(false);
return 0;
}
/*double OutputUnit::pre_output()
{
double preoutput = 0;
for (int i=0; i < input_count; i++)
preoutput += input_area[i]->get_output() * input_weights[i];
//if(activation_func == Activation_functions::aslog)
//FLOG(QString("unit preoutput:%1\n").arg(preoutput).toStdString().c_str());
if (activation_func == Activation_functions::identity)
FLOG(QString("output unit preoutput:%1\n").arg(preoutput).toStdString().c_str());
preoutput += bias;
return preoutput;
}*/