Advertisement
Guest User

Untitled

a guest
Nov 22nd, 2013
105
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 2.53 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4.  
  5. namespace Client.Engine
  6. {
  7.     /// <summary>
  8.     /// Класс описывает модель решения
  9.     /// </summary>
  10.     [Serializable]
  11.     class Combination : IEquatable<Combination>, IComparable
  12.     {
  13.         public SortedSet<Variable> Variables { get; set; }
  14.         public double MeanError { get; private set; }
  15.         public double[] A { get; private set; }
  16.  
  17.         public Combination()
  18.         {
  19.             Variables = new SortedSet<Variable>();
  20.             MeanError = double.NaN;
  21.         }
  22.  
  23.         /// <summary>
  24.         /// Подсчет среднеквадратической ошибки
  25.         /// </summary>
  26.         /// <param name="x">Выборочные значения X</param>
  27.         /// <param name="y">Значения Y</param>
  28.         /// <param name="a">Тестовые значения A, начиная с a0</param>
  29.         /// <returns>Успешность выполнения функции</returns>
  30.         public bool Test(double[][] x, double[] y, double[] a)
  31.         {
  32.             if (a.Length != (Variables.Count + 1) || x.Length != y.Length)
  33.                 return false;
  34.             A = a;
  35.             MeanError = 0;
  36.             for (var k0 = 0; k0 < x.Length; k0++)
  37.             {
  38.                 var ty = a[0];
  39.                 for (var k1 = 1; k1 < a.Length; k1++)
  40.                 {
  41.                     ty += x[k0][k1 - 1]*a[k1];
  42.                 }
  43.                 MeanError += Math.Pow(y[k0] - ty, 2.0);
  44.             }
  45.             return true;
  46.         }
  47.  
  48.         public override bool Equals(object obj)
  49.         {
  50.             return Equals(obj as Combination);
  51.         }
  52.  
  53.         bool IEquatable<Combination>.Equals(Combination other)
  54.         {
  55.             return Equals(other);
  56.         }
  57.  
  58.         public bool Equals(Combination other)
  59.         {
  60.             if (Variables.Count != other.Variables.Count)
  61.                 return false;
  62.             for (var i = 0; i < Variables.Count; i++)
  63.             {
  64.                 if (!Variables.ElementAt(i).Equals(other.Variables.ElementAt(i)))
  65.                     return false;
  66.             }
  67.             return true;
  68.         }
  69.  
  70.         public int CompareTo(object obj)
  71.         {
  72.             return CompareTo(obj as Combination);
  73.         }
  74.  
  75.         public int CompareTo(Combination obj)
  76.         {
  77.             if (Equals(obj))
  78.                 return 0;
  79.             return Variables.Count < obj.Variables.Count ? -1 : 1;
  80.         }
  81.     }
  82. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement