Mercurial > pub > ImplabNet
diff Implab/Automaton/IAlphabet.cs @ 162:0526412bbb26 ref20160224
DFA refactoring
author | cin |
---|---|
date | Wed, 24 Feb 2016 08:39:53 +0300 |
parents | |
children | 0f70905b4652 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Implab/Automaton/IAlphabet.cs Wed Feb 24 08:39:53 2016 +0300 @@ -0,0 +1,48 @@ +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> + /// <returns></returns> + List<TSymbol>[] CreateReverseMap(); + + /// <summary> + /// Создает новый алфавит на основе текущего, горппируя его сиволы в более + /// крупные непересекающиеся классы символов. + /// </summary> + /// <param name="newAlphabet">Новый, пустой алфавит, в котором быдут определены классы.</param> + /// <param name="classes">Множество классов символов текущего алфавита.</param> + /// <returns>Карта для перехода классов текущего + /// алфавита к классам нового.</returns> + /// <remarks>Ползволяет укрупнить алфавит, объединив классы в текущем алфавите. Используется при оптимизации автомата.</remarks> + int[] Reclassify(IAlphabetBuilder<TSymbol> newAlphabet, IEnumerable<IEnumerable<int>> classes); + + /// <summary> + /// Преобразует входной символ в индекс символа из алфавита. + /// </summary> + /// <param name="symobl">Исходный символ</param> + /// <returns>Индекс в алфавите</returns> + int Translate(TSymbol symobl); + } +}