Click here to Skip to main content
15,886,074 members
Articles / Programming Languages / C#

Universal Framework for Science and Engineering - Part 2: Regression

Rate me:
Please Sign up or sign in to vote.
4.77/5 (19 votes)
11 Jul 20067 min read 51.1K   5K   76  
An article on universal scalable engineering framework applications.
using System;
/*
using System.Drawing;
using System.Windows.Forms;
*/
using System.Collections;
//using CategoryTheory;


namespace FormulaEditor
{
	/// <summary>
	/// Powered indexed symbol
	/// </summary>
    [Serializable()]
	public class PoweredIndexedSymbol : IndexedSymbol
	{
		/// <summary>
		/// Constructor
		/// </summary>
		/// <param name="c">the symbol</param>
		public PoweredIndexedSymbol(char c) : base(c, (byte)FormulaConstants.Powered, true)
		{
			s = "" + c;
		}

		/// <summary>
		/// Constructor
		/// </summary>
		/// <param name="c">the symbol</param>
		/// <param name="type">the type</param>
		/// <param name="italic">the italic flag</param>
		public PoweredIndexedSymbol(char c, byte type, bool italic) : base(c, type, italic)
		{
		}

		/// <summary>
		/// Constructor
		/// </summary>
		/// <param name="c">the symbol</param>
		/// <param name="type">the type</param>
		/// <param name="italic">the italic flag</param>
		/// <param name="s">string representation</param>
		public PoweredIndexedSymbol(char c, byte type, bool italic, String s) : base(c, type, italic, s)
		{
		}

		/// <summary>
		/// Constructor
		/// </summary>
		/// <param name="c">the symbol</param>
		/// <param name="italic">the italic flag</param>
		/// <param name="type">the type</param>
		public PoweredIndexedSymbol(char c,  bool italic, byte type) : base(c, italic, type)
		{
		}




		/// <summary>
		/// Sets this object to formula
		/// </summary>
		/// <param name="formula">the formula to set</param>
		public override void SetToFormula(MathFormula formula)
		{
			base.SetToFormula(formula);
			/*
			if (italic)
			{
				font = fontsItalic[level];
			}
			else
			{
				font = fonts[level];
			}
			widthInsert = (int)graphics.MeasureString("y", font, 100).Width;
			*/
			if (this is BracketsSymbol | this is BinarySymbol | this is BinaryFunctionSymbol)
			{
				return;
			}
			if (level < (sizes.Length - 1))
			{
				MathFormula child = new MathFormula((byte)(level + 1), sizes);
				children.Add(child);
				//childPositions = new Point[]{new Point(), new Point()};
				return;
			}
			children = null;
		}



		/// <summary>
		/// ICloneable interface implementation
		/// </summary>
		/// <returns></returns>
		public override object Clone()
		{
			return new PoweredIndexedSymbol(symbol, type, italic, s);
		}

		/// <summary>
		/// The associated object
		/// </summary>
		/*public object Object
		{
			get
			{
				return obj;
			}
			set
			{
				obj = value;
			}
		}*/

		public override int SubscriptIndex
		{
			get
			{
				MathFormula f = this[1];
				string s = "";
				for (int i = 0; i < f.Count; i++)
				{
					s += f[i].Symbol;
				}
				return Int32.Parse(s);
			}
		}


		public int Deg
		{
			get
			{
				MathFormula f = this[0];
				if (f.Count == 0)
				{
					return 1;
				}
				string s = "";
				for (int i = 0; i < f.Count; i++)
				{
					s += f[i].Symbol;
				}
				return Int32.Parse(s);
			}
		}
		
		
/*
		/// <summary>
		/// Arity of this operation
		/// </summary>
		public int Arity
		{
			get
			{
				return 0;
			}
		}

		/// <summary>
		/// Return type
		/// </summary>
		public object ReturnType
		{
			get
			{
				return obj;
			}
		}
*/
		/// <summary>
		/// The "is powered" sign
		/// </summary>
		public override bool IsPowered
		{
			get
			{
				return false;
			}
		}



		/// <summary>
		/// Calculates result of this operation
		/// </summary>
	/*	public object this[object[] o]
		{
			get
			{
				return obj;
			}
		}*/

	}
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
Architect
Russian Federation Russian Federation
Ph. D. Petr Ivankov worked as scientific researcher at Russian Mission Control Centre since 1978 up to 2000. Now he is engaged by Aviation training simulators http://dinamika-avia.com/ . His additional interests are:

1) Noncommutative geometry

http://front.math.ucdavis.edu/author/P.Ivankov

2) Literary work (Russian only)

http://zhurnal.lib.ru/editors/3/3d_m/

3) Scientific articles
http://arxiv.org/find/all/1/au:+Ivankov_Petr/0/1/0/all/0/1

Comments and Discussions