Mercurial > pub > ImplabNet
view Implab/Automaton/IAlphabet.cs @ 262:f1696cdc3d7a v3 v3.0.8
Added IInitializable.Initialize() overload
Added IRunnable.Start(), IRunnable.Start() overloads
Fixed cancellation of the current operation when Stop() is called
More tests
author | cin |
---|---|
date | Mon, 16 Apr 2018 02:12:39 +0300 |
parents | 0f70905b4652 |
children |
line wrap: on
line source
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Implab.Automaton { /// <summary> /// Алфавит. Множество символов, которые разбиты на классы, при этом классы имеют непрерывную нумерацию, /// что позволяет использовать их в качестве индексов массивов. /// </summary> /// <remarks> /// <para>Алфавит является сюрьективным отображением множества символов в множество индексов, это позволяет сократить размер таблицы переходов автомата /// для входных символов, которые для него не различимы.</para> /// </remarks> /// <typeparam name="TSymbol">Тип символов.</typeparam> public interface IAlphabet<TSymbol> { /// <summary> /// Количество классов символов в алфавите. /// </summary> int Count { get; } /// <summary> /// Преобразует входной символ в индекс символа из алфавита. /// </summary> /// <param name="symobl">Исходный символ</param> /// <returns>Индекс в алфавите</returns> int Translate(TSymbol symobl); bool Contains(TSymbol symbol); IEnumerable<TSymbol> GetSymbols(int cls); } }