Advertisement
Geograph

LinearInterpolation.cs

Feb 10th, 2017
146
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 2.26 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4.  
  5. class LinearInterpolation
  6. {
  7.     static Random random = new Random(Guid.NewGuid().GetHashCode());
  8.  
  9.     // Коэффициент при x
  10.     static double k = random.NextDouble() * (5 - (-5)) + (-5);
  11.  
  12.     // Свободный член уравнения прямой
  13.     static double c = random.NextDouble() * (5 - (-5)) + (-5);
  14.  
  15.     // Набор точек X:Y
  16.     static Dictionary<double, double> data = new Dictionary<double, double>
  17.     {
  18.         { 1, 2 },
  19.         { 2, 4.2 },
  20.         { 2.5, 5 },
  21.         { 3.8, 7.9 },
  22.         { 4, 9 },
  23.         { 6, 10.2 },
  24.         { 6.6, 13 },
  25.         { 7.2, 15.3 },
  26.         { 8, 17.1 },
  27.         { 8.5, 19.5 }
  28.     };
  29.  
  30.     // Скорость обучения
  31.     static double rate = 0.0001;
  32.  
  33.     static void Main()
  34.     {
  35.         // Вывод данных начальной прямой
  36.         Console.WriteLine("Начальная прямая: {0} * X + {1}", k, c);
  37.  
  38.         // Тренировка сети
  39.         for (int i = 0; i < 100000; i++)
  40.         {
  41.             // Получить случайную X координату точки
  42.             var x = data.ElementAt(random.Next(data.Count)).Key;
  43.  
  44.             // Получить соответствующую Y координату точки
  45.             var true_result = data[x];
  46.  
  47.             // Получить ответ сети
  48.             var output = proceed(x);
  49.  
  50.             // Считаем ошибку сети
  51.             var delta = true_result - output;
  52.  
  53.             // Меняем вес при x в соответствии с дельта-правилом
  54.             k += delta * rate * x;
  55.  
  56.             // Меняем вес при постоянном входе в соответствии с дельта-правилом
  57.             c += delta * rate;
  58.         }
  59.  
  60.         // Вывод данных готовой прямой
  61.         Console.WriteLine("Готовая прямая: {0} * X + {1}", k, c);
  62.  
  63.         Console.WriteLine("\r\nНажмите любую кнопку для выхода");
  64.         Console.ReadKey();
  65.     }
  66.  
  67.     // Высчитать y
  68.     static double proceed(double x)
  69.     {
  70.         return x * k + c;
  71.     }
  72. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement