ПРОГРАММНАЯ РЕАЛИЗАЦИЯ
Для написания программы был выбран язык программирования С++. Он является полностью объектно-ориентированным, мощным языком программирования, поддерживающим практически все виды абстракций объектно-ориентированного программирования. Была использована среда программирования Visual C++ 6.0. Эта среда является визуальной средой программирования, позволяющей перетаскивать стандартные компоненты непосредственно в окно будущей программы. Она позволяет автоматизировано создавать различные проекты с использованием «мастеров». Структурно программа представляет собой набор классов, часть из которых была создана разработчиком, а часть – самой средой программирования. Классы созданные средой программирования унаследованы от классов библиотеки MFC. Экземпляры одних классов создаются другими классами, и там происходит работа с ними. Среда программирования сама генерирует код главной функции и программисту он не доступен. Программист может работать только либо со своими классами, либо с классами, описывающими интерфейс программы и ее свойства. Также в исходниках программы присутствуют ресурсы, которые представляют из себя внешния объекты, подключаемые к программе во время связывания. Этими ресурсами являются диалоговые окна, картинки, иконки и специальные таблицы, определяющие системные и интерфейсные свойства программы. Ниже представлено описание классов, созданных разработчиком. Класс CNeuronP. Этот класс определяет нейрон, который является базовым элементом нейронной сети. Его объявление: class CNeuronP: public CNeuron { protected: float axon; //выход std::vector<float> inputs; //входы std::vector<float> synapses; //веса входов int rang; //число входов public: CNeuronP(int rng=2,float por=2.0); virtual void AddInput(void); //добавляет синапс virtual float GetAxon(void); //возвращает выход нейрона virtual void func(void); //просчет нейрона int SetInput(float inp,int number); //устанавливает входы int SetSynaps(float sip, int num); //устанавливает веса float GetInput(int number); //возвращает вход float GetSynaps(int number); //возвращает вес входа int GetRang(void); //возвращает число синапсов float GetPro(void); //возвращает производную от активационной функции }; Как видно из этого объявления все поля-члены данного класса являются закрытыми, а все функции-члены – открытыми. Этот принцип реализован и в остальных классах, созданных разработчиком. Это сделано для обеспечения гибкости работы с экземплярами классов, без доступа к их внутренней структуре. Действия, выполняемые функциями-членами и назначение полей-членов описаны в комментариях к ним. Опишем функцию func. Она выполняет просчет нейрона. Она берет каждый вход нейрона и умножает его на соответствующий вес. Затем это произведение прибавляется к сумме таких же произведений, и так для каждого входа. Затем от полученной суммы вычисляется функция, в данном случае сигмоид, сдвинутый на -1/2 по оси ординат. Результат вычисления этой функции присваивается выходу нейрона. Класс CLayerP. Он представляет собой набор нейронов, входящих в один слой нейронной сети. Его объявление: class CLayerP { protected: std::vector<CNeuronP> neurons; //нейроны слоя int number; //число нейронов в слое public: CLayerP(int num=2); virtual void AddNeuron(CNeuronP neur); //добавляет нейрон в слой virtual int SetNeuron(CNeuronP neur, int num); int GetNumber(void); //возвращает число нейронов в слое CNeuronP& GetNeuron(int num); //возвращает нейрон по его номеру }; Некоторые функции-члены класса сделаны виртуальными для обеспечения полиморфизма в случае расширения системы. Класс CNNetworkP. Этот класс описывает многослойную нейронную сеть, применяемую в программе для распознавания букв. Его объявление: class CNNetworkP:public CNNetwork { protected: CLayerP FirstLayer; //первый слой CLayerP LastLayer; //последний слой std::vector<CLayerP> layers; //скрытые слои int m_number; //число скрытых слоев public: CNNetworkP(int num1=2/*число нейронов во входном слое*/, int num2=2/*число нейронов в выходном слое*/, int num3=2,/*число нейронов в скрытом слое*/ int number=1/*число скрытых слоев*/); virtual void Solve(void); //просчет сети void SetInputs(std::vector<float> inp); //устанавливает входы void SetNumFSynaps(int num); //устанавливает число синапсов в каждом нейроне первого слоя int NumHLayers(void); //число скрытых слоев virtual float GetOut(int number); //возвращает выход virtual void Learn(int number, CString filename, int num);//обучает сеть конкретной паре void before(void); //начальная инициализация весов void SaveToFile(CString filename);//запись обученных весов в файл void LoadFromFile(CString filename);//загрузка обученных весов из файла void SaveOuts(CString filename); //сохранить выходы в файл }; Конструктор данного класса создает экземпляры всех нейронов, входящих в данную сеть, используя их конструкторы с параметрами по умолчанию. Функция-член Solve осуществляет просчет сети. При этом сначала просчитываются все нейроны входного слоя, затем их выходы используются в качестве входов нейронов первого скрытого слоя, для их просчета и так далее вплоть до выходного слоя сети. Выход выходного слоя используется в качестве выхода сети. Функция-член before осуществляет начальную инициализацию весов, проводимую перед обучением сети. Она с помощью генератора произвольных чисел присваивает всем весам сети значения в пределах от -0.5 до 0.5. Функция-член Learn осуществляет обучение нейронной сети, обучающим парам, которые берутся из заданного файла. В ней реализован алгоритм обучения с обратным распространением ошибки. Число итераций этого алгоритма может определяться либо допустимой величиной погрешности, которая задана в виде константы, либо с помощью параметра, определяющего число итераций и передаваемого функции в качестве параметра. На каждой итерации на вход сети подается стандартный входной вектор из обучающей пары, и сеть просчитывается. Затем ее выход сравнивается с эталонным выходом данной обучающей пары и вычисляется ошибка для каждого элемента этого вектора. Веса выходного слоя модифицируются согласно этой ошибке. Затем вычисляется ошибка для каждого выхода последнего скрытого слоя нейронной сети. И его веса изменяются точно так же, как веса выходного слоя. И так далее вплоть до входного слоя. Затем этот процесс повторяется. Программа была обучена буквам из специально подготовленного для программы шрифта и показала высокую степень распознавания, даже при наличии больших помех. Программа будет распознавать рисунок буквы до тех пор, пока он не станет похож на рисунок другой буквы, которому обучена нейронная сеть.
Популярное: Генезис конфликтологии как науки в древней Греции: Для уяснения предыстории конфликтологии существенное значение имеет обращение к античной... Личность ребенка как объект и субъект в образовательной технологии: В настоящее время в России идет становление новой системы образования, ориентированного на вхождение... Как распознать напряжение: Говоря о мышечном напряжении, мы в первую очередь имеем в виду мускулы, прикрепленные к костям ... Как построить свою речь (словесное оформление):
При подготовке публичного выступления перед оратором возникает вопрос, как лучше словесно оформить свою... ©2015-2024 megaobuchalka.ru Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. (204)
|
Почему 1285321 студент выбрали МегаОбучалку... Система поиска информации Мобильная версия сайта Удобная навигация Нет шокирующей рекламы |