NLMSvariants/bin/NLMSvariants.cs

351 lines
11 KiB
C#
Raw Normal View History

2018-05-09 12:31:10 +02:00
// Variable mit der anzahl Punkten zwischen 0 - 255
static int NumberOfSamples = 1000;
// Variable zum tracken der Gewichte
const int tracking = 40;
// C# only zum erstellen von Randomzahlen
static Random rnd = new Random();
// Array mit den Testwerten
2018-05-09 13:09:33 +02:00
static double[] _x = new double[NumberOfSamples];
2018-05-09 12:31:10 +02:00
// Array mit den Gewichten
2018-05-09 13:09:33 +02:00
static double[,] w = new double[NumberOfSamples, NumberOfSamples];
2018-05-09 12:31:10 +02:00
// Lernrate
static double learnrate = 1;
// Größe des Fensters
static int windowSize = 5;
/**************************************************************
main() des Programms
***************************************************************/
int main(){
// Initialisierung des Test Array + Gewichte
2018-05-09 13:09:33 +02:00
for (int i = 0; i < NumberOfSamples; i++)
2018-05-09 12:31:10 +02:00
{
2018-05-09 13:09:33 +02:00
_x[i] += ((255.0 / NumberOfSamples) * i);
for (int k = 0; k < windowSize; k++)
2018-05-09 12:31:10 +02:00
{
w[k, i] = rnd.NextDouble();
//Console.WriteLine(String.Format("Weight: {0}", w[k, i]));
}
}
// Zum erstellen eines Files mit den Gewichten vor den Updates
for (int i = 0; i < tracking; i++)
{
2018-05-09 13:09:33 +02:00
for (int k = 0; k < windowSize; k++)
2018-05-09 12:31:10 +02:00
{
File.AppendAllText("weights.txt",
String.Format("[{0}][{1}] {2}\n", k, i, Math.Round(w[k, i], 2).ToString()),
Encoding.UTF8);
}
}
// Variante die Ausgeführt werden soll
lokalerMittelWert();
// Zum erstellen eines Files mit den Gewichten nach den Updates
for (int i = 0; i < tracking; i++)
{
2018-05-09 13:09:33 +02:00
for (int k = 0; k < windowSize; k++)
2018-05-09 12:31:10 +02:00
{
File.AppendAllText("weights_after.txt",
String.Format("[{0}][{1}] {2}\n", k, i, Math.Round(w[k, i], 2).ToString()),
Encoding.UTF8);
}
}
}
/**************************************************************
Errechnet die 1. Variante, mit abziehen des lokalen Mittelwertes
***************************************************************/
void lokalerMittelWert()
{
//Array in dem e(n) gespeichert wird
2018-05-09 13:09:33 +02:00
double[] x_error = new double[NumberOfSamples];
2018-05-09 12:31:10 +02:00
//Laufzeitvariable
int x_count = 0;
// x_count + 1 da x_count > 0 sein muss
2018-05-09 13:09:33 +02:00
while (x_count + 1 < NumberOfSamples)
2018-05-09 12:31:10 +02:00
{
//Erstellt ein neues Array der letzten "windowSize" Werte
double[] x_part_Array = new double[x_count];
2018-05-09 13:09:33 +02:00
2018-05-09 12:31:10 +02:00
//Anfang des Fensters das erstellt wird
int _sourceIndex = (x_count > windowSize) ? x_count - windowSize : 0;
2018-05-09 13:09:33 +02:00
2018-05-09 12:31:10 +02:00
//Länge des Fensters das erstellt wird
int _arrayLength = (x_count > windowSize) ? windowSize : (x_count > 0) ? x_count - 1 : 0;
Array.Copy(_x, _sourceIndex, x_part_Array, 0, _arrayLength);
double x_middle = (x_count > 0) ? (x_part_Array.Sum() / _arrayLength) : 0;
// Variable für die errechnete Zahl
double x_pred = 0.0;
// Variable mit der eigentlichen Zahl
double x_actual = _x[x_count + 1];
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_pred += (w[i, x_count] * (_x[x_count - i] - x_middle));
}
x_pred += x_middle;
//Console.WriteLine(String.Format("X_sum: {0}", x_middle));
//Console.WriteLine(String.Format("X_pred: {0}", x_pred));
//Console.WriteLine(String.Format("X_actual: {0}", x_actual));
x_error[x_count] = x_actual - x_pred;
// Funktion zum berechnen des Quadrates
double x_square = 0;
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_square += Math.Pow(_x[x_count - i], 2);
}
// Funktion zum updaten der Gewichte
for (int i = _sourceIndex; i < _arrayLength; i++)
{
w[i, x_count + 1] = w[i, x_count] + learnrate * x_error[x_count] * (_x[x_count - i] / x_square);
}
// Laufzeitvariable hochzählen
x_count += 1;
}
// Berechenen des mittleren Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double mittel = x_error.Where(d => !double.IsNaN(d)).Sum() / x_error.Length;
// Berechenen der varianz des Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double varianz = 0.0;
foreach (double x_e in x_error)
{
if (!double.IsNaN(x_e))
varianz += Math.Pow(x_e - mittel, 2);
}
varianz /= x_error.Length;
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("ergebnisse.txt",
String.Format("Quadratische Varianz(x_error): {0}\n Mittelwert(x_error): {1}\n\n", varianz, mittel),
Encoding.UTF8);
}
/**************************************************************
Errechnet die 2. Variante, mit abziehen des direkten Vorgängers
***************************************************************/
void direkterVorgaenger()
{
//Array in dem e(n) gespeichert wird
2018-05-09 13:09:33 +02:00
double[] x_error = new double[NumberOfSamples];
2018-05-09 12:31:10 +02:00
//Laufzeitvariable
int x_count = 0;
// x_count + 1 da x_count > 0 sein muss
2018-05-09 13:09:33 +02:00
while (x_count + 1 < NumberOfSamples)
2018-05-09 12:31:10 +02:00
{
// Variable für die errechnete Zahl
double x_pred = 0.0;
//Anfang des Fensters das erstellt wird
int _sourceIndex = (x_count > windowSize) ? x_count - windowSize : 0;
//Länge des Fensters das erstellt wird
int _arrayLength = (x_count > windowSize) ? windowSize : (x_count > 0) ? x_count - 1 : 0;
// Variable mit der eigentlichen Zahl
double x_actual = _x[x_count + 1];
// Funktion fürs berechnen der Vorhersagezahl
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_pred += (w[i, x_count] * (_x[x_count - 1] - _x[x_count - i - 1]));
}
x_pred += _x[x_count - 1];
//Console.WriteLine(String.Format("X_pred: {0}", x_pred));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("direkterVorgaenger.txt",
String.Format("{0}. X_pred {1}\n", x_count, x_pred),
Encoding.UTF8);
//Console.WriteLine(String.Format("X_actual: {0}", x_actual));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("direkterVorgaenger.txt",
String.Format("{0}. X_actual {1}\n", x_count, x_actual),
Encoding.UTF8);
// Berechnung des Fehlers
x_error[x_count] = x_actual - x_pred;
//Console.WriteLine(String.Format("X_error: {0}", x_error));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("direkterVorgaenger.txt",
String.Format("{0}. X_error {1}\n\n", x_count, x_error),
Encoding.UTF8);
// Funktion zum berechnen des Quadrates
double x_square = 0;
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_square += Math.Pow(_x[x_count - 1] - _x[x_count - i - 1], 2);
}
//Console.WriteLine(String.Format("X_square: {0}", x_square));
// Hängt dem Angegebenen File den Vorgegebenen String an
//File.AppendAllText("direkterVorgaenger.txt",
// String.Format("{0}. X_square {1}\n", x_count, x_square),
// Encoding.UTF8);
// Funktion zum updaten der Gewichte
for (int i = _sourceIndex; i < _arrayLength; i++)
{
w[i, x_count + 1] = w[i, x_count] + learnrate * x_error[x_count] * ((_x[x_count - 1] - _x[x_count - i - 1]) / x_square);
}
// Laufzeitvariable hochzählen
x_count += 1;
}
// Berechenen des mittleren Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double mittel = x_error.Where(d => !double.IsNaN(d)).Sum() / x_error.Length;
// Berechenen der varianz des Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double varianz = 0.0;
foreach (double x_e in x_error)
{
if (!double.IsNaN(x_e))
varianz += Math.Pow(x_e - mittel, 2);
}
varianz /= x_error.Length;
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("ergebnisse.txt",
String.Format("Quadratische Varianz(x_error): {0}\n Mittelwert(x_error): {1}\n\n", varianz, mittel),
Encoding.UTF8);
}
/**************************************************************
Errechnet die 3. Variante, mit abziehen des differenziellen Vorgängers
***************************************************************/
void differenziellerVorgaenger()
{
//Array in dem e(n) gespeichert wird
2018-05-09 13:09:33 +02:00
double[] x_error = new double[NumberOfSamples];
2018-05-09 12:31:10 +02:00
//Laufzeitvariable
int x_count = 0;
// x_count + 1 da x_count > 0 sein muss
2018-05-09 13:09:33 +02:00
while (x_count + 1 < NumberOfSamples)
2018-05-09 12:31:10 +02:00
{
// Variable für die errechnete Zahl
double x_pred = 0.0;
// Anfang des Fensters das erstellt wird
int _sourceIndex = (x_count > windowSize) ? x_count - windowSize : 0;
//Länge des Fensters das erstellt wird
int _arrayLength = (x_count > windowSize) ? windowSize : (x_count > 0) ? x_count - 1 : 0;
// Variable mit der eigentlichen Zahl
double x_actual = _x[x_count + 1];
// Funktion fürs berechnen der Vorhersagezahl
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_pred += (w[i, x_count] * (_x[x_count - i] - _x[x_count - i - 1]));
}
x_pred += _x[x_count - 1];
//Console.WriteLine(String.Format("X_pred: {0}", x_pred));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("differenziellerVorgaenger.txt",
String.Format("{0}. X_pred {1}\n", x_count, x_pred),
Encoding.UTF8);
//Console.WriteLine(String.Format("X_actual: {0}", x_actual));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("differenziellerVorgaenger.txt",
String.Format("{0}. X_actual {1}\n", x_count, x_actual),
Encoding.UTF8);
// Berechnung des Fehlers
x_error[x_count] = x_actual - x_pred;
//Console.WriteLine(String.Format("X_error: {0}", x_error));
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("differenziellerVorgaenger.txt",
String.Format("{0}. X_error {1}\n\n", x_count, x_error),
Encoding.UTF8);
// Funktion zum berechnen des Quadrates
double x_square = 0;
for (int i = _sourceIndex; i < _arrayLength; i++)
{
x_square += Math.Pow(_x[x_count - i] - _x[x_count - i - 1], 2);
}
//Console.WriteLine(String.Format("X_square: {0}", x_square));
// Hängt dem Angegebenen File den Vorgegebenen String an
//File.AppendAllText("direkterVorgaenger.txt",
// String.Format("{0}. X_square {1}\n", x_count, x_square),
// Encoding.UTF8);
// Funktion zum updaten der Gewichte
for (int i = _sourceIndex; i < _arrayLength; i++)
{
w[i, x_count + 1] = w[i, x_count] + learnrate * x_error[x_count] * ((_x[x_count - i] - _x[x_count - i - 1]) / x_square);
}
// Laufzeitvariable hochzählen
x_count += 1;
}
// Berechenen des mittleren Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double mittel = x_error.Where(d => !double.IsNaN(d)).Sum() / x_error.Length;
// Berechenen der varianz des Fehlers und aussortieren potenzieller NaN Werte im Fehler Array
double varianz = 0.0;
foreach (double x_e in x_error)
{
if (!double.IsNaN(x_e))
varianz += Math.Pow(x_e - mittel, 2);
}
varianz /= x_error.Length;
// Hängt dem Angegebenen File den Vorgegebenen String an
File.AppendAllText("ergebnisse.txt",
String.Format("Quadratische Varianz(x_error): {0}\n Mittelwert(x_error): {1}\n\n", varianz, mittel),
Encoding.UTF8);
}