Форум программистов, компьютерный форум, киберфорум
Pure Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Ты за кого меня держиш!?
 Аватар для ЦарьКащей
22 / 23 / 7
Регистрация: 26.10.2011
Сообщений: 308
Записей в блоге: 1

Программа для анализа и отбора способа реакции на входные данные

30.10.2012, 19:54. Показов 3254. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
PureBasic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
; Описание:
; программа для анализа и отбора способа реакции на входные данные
 
; Принцип:
; Создаётся файл в который записываются таблицы, состоящие из: 
; 1) Восьми байт кода события, единственное в таблице, а в файле в количестве, ограниченном диапазоном принимаемых значений переменной данного типа. (0 - "+infinity", но лучше ограничить до 1 000 000 000 000 так как счёт пойдёт на терабайты занимаемого дискового пространства.)
; 2) Двух байт индекса выхода, в количестве, ограниченном диапазоном принимаемых значений переменной данного типа. (0 - 65536)
; 3) Одного байта возможного значения выхода, в не ограниченном количестве, с ограниченным диапазоном принимаемых значений.(0 - 255)
; Для каждого кода события создаётся своё количество индексов выходов и для каждого индекса своё количество принимаемых значений до 255.
;Как предполагается будет работать - таблица из файла считывается, входное значение ищется, сравнивается, веса модифицируются, положение дел постоянно анализируется и результат модифицируется.
 
; Процедуры по порядку:
; 1 - Create_table создаёт таблицу расчитывая размер по переданным параметрам диапазонов значений в количестве задаваемом одним из параметров
; 2 - Compare процедура сравнивающая два параметра и возвращающая результат в процентах
; 3 - Save_table_in_file запись таблицы в файл
; 4 - Load_table_from_file чтение таблицы из файла
; 5 - Weight_modification модификация весов, распределяющая веса таким образом чтобы небыло одинаковых, не доработана, требуется исключить модификацию двух самых больших весов
; 6 - Search_the_largest_weight поиск наибольшего веса, индекс веса - значение на выходе
; 7 - Функция обратного вызова в процедуре Search_the_largest_weight, нужна для перерасчёта результата после выдачи каждого значения на выход
; 8 - Heuristic_Search процедура вычисляющая код(сумму) входного массива, проверял около получаса используя список и массив размерностью 300х300, вроде повторов небыло.
;     Процедура ищет еод события в памяти, загружает таблицы из файла и сохраняет в файл, короче перебирает все таблицы на наличе кода, попутно запоминает позицию наиболее похожего кода,
;     решает что делать в случай отсутствия полого совпадения кода.
 
; Указатели на память:
; *mem_buff - таблица таблиц в памяти, загружаются в неё таблицы пачками.
; *stimul - значение, решающее как модифицировать вес, является суммой входных значений, определяющей, негативно действие или позитивно и следовательно влияющей на реакцию программы в именно данном случае
 
; Структура таблиц расчитаывается на количество кодов событий более 100 000 000 000.
 
;++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
; создание таблицы
Procedure Create_table(*mem_buff, number_of_codes, range, number_of_outputs, number_of_inputs) ; не готово
  *mem_buff = ReAllocateMemory(*mem_buff, number_of_codes * 8 + number_of_codes * (range * number_of_outputs + number_of_outputs * 2 + range * number_of_inputs + number_of_inputs * 2))
  ProcedureReturn size
EndProcedure ; 8, 2, 1
 
; сравнение
Procedure Compare(One, Two) ; готово
  Procent = One / 100
  If Procent <> 0
    Shodstvo = Two / Procent
    If Shodstvo > 100 And Shodstvo < 200
      ProcedureReturn Shodstvo - 100   
    ElseIf Shodstvo <= 100 And Shodstvo >= 0
      ProcedureReturn Shodstvo
    EndIf
  EndIf
EndProcedure
 
; работа с файлом
Procedure Save_table_in_file(file_name.s, *mem_buff) ; вроде готово
  OpenFile(0, file_name)
  WriteData(0, *mem_buff, MemorySize(*mem_buff))
  CloseFile(0)
  ProcedureReturn 1
EndProcedure
 
Procedure Load_table_from_file(file_name.s, *mem_buff, number_of_table) ; вроде готово
  ReadFile(0, file_name)
  For n = 0 To number_of_table - 1
    ReadData(0, *mem_buff, MemorySize(*mem_buff))
  Next
  CloseFile(0)
  ProcedureReturn 1
EndProcedure
 
; модификация весов
Procedure Weight_modification(*mem_buff, *stimul, outcome_output, start_position, stop_position) ; не готово
  If PeekL(*stimul) > 0 And PeekA(*mem_buff + start_position + outcome_output) < 255
    PokeA(*mem_buff + start_position + outcome_output, PeekA(*mem_buff + start_position + outcome_output) + 1)
  EndIf
  
  If PeekL(*stimul) < 0 And PeekA(*mem_buff + start_position + outcome_output) > 0
    PokeA(*mem_buff + start_position + outcome_output, PeekA(*mem_buff + start_position + outcome_output) - 1)
  EndIf
  
  If PeekL(*stimul) > 0
    For n = start_position To stop_position
      If PeekA(*mem_buff + n) < wei And n <> outcome_output + start_position And PeekA(*mem_buff + n) > 0
        wei = PeekA(*mem_buff + n)
        position = n
      EndIf
    Next
    PokeA(*mem_buff + position, PeekA(*mem_buff + position) - 1)
    
  ElseIf PeekL(*stimul) < 0
    For n = start_position To stop_position
      If PeekA(*mem_buff + n) > wei And n <> outcome_output + start_position And PeekA(*mem_buff + n) < 255
        wei = PeekA(*mem_buff + n)
        position = n
      EndIf
    Next
    PokeA(*mem_buff + position, PeekA(*mem_buff + position) + 1) 
  EndIf
  ProcedureReturn 1
EndProcedure
 
; поиск лучшего веса
Procedure Search_the_largest_weight(*mem_buff, *callback_function, position, range, number_of_outputs, number_of_inputs) ; вроде готово
  For a = 0 To number_of_outputs - 1  
    For n = position + 8 + range * a + 2 * (a + 1) To position + 8 + range * a + 2 * (a + 1) + range + 1
      If PeekA(*mem_buff + n) > Wei
        outcome_output = n - position - 8 - 2 * (a + 1) : Wei = PeekA(*mem_buff + n)
      EndIf
    Next
    outcome_callback = CallCFunctionFast(*callback_function, outcome_output)
    outcome_modification = Weight_modification(*mem_buff, *stimul, outcome_output, position + 8 + range * a + 2 * (a + 1), position + 8 + range * a + 2 * (a + 1) + range + 1)
  Next
  ProcedureReturn 1
EndProcedure
 
; вычисление суммы и поиск кода события
Procedure Heuristic_Search(*callback_function, *mem_buff, *stimul, number_of_codes, number_of_outputs, range, number_of_inputs) ; не готово *callback_function=@Procedure()
  code.d = 0
  For n = 0 To MemorySize(*mem_buff) - 1
    code = code + PeekA(*mem_buff + n) * (n + 1)  
  Next
  
  position = -1
  For n = 0 To MemorySize(*mem_buff) / number_of_codes - 1
    st = n * (number_of_outputs * range + n * number_of_outputs * 2)
    If PeekU(*mem_buff + st) = code
      outcome_output = Search_the_largest_weight(*mem_buff, *callback_function, st, range, number_of_outputs, number_of_inputs)
    Else
      outcome_cmp = Compare(PeekL(*mem_buff + st), code)
      If outcome_cmp > outcome_cmp_Old
        outcome_cmp_Old = outcome_cmp : position = st
      EndIf    
    EndIf    
  Next
  
  outcome_output = Search_the_largest_weight(*mem_buff, *callback_function, position, range, number_of_outputs, number_of_inputs)
  
  *new_table = AllocateMemory(size_of_outputs)
  PokeL(*new_table, code)
  outcome_modification = Weight_modification(*mem_buff, *stimul, outcome_output, start_position, stop_position)
  ProcedureReturn 1
EndProcedure
 
Procedure Core() ; наверное вообще не понадобится
  
EndProcedure
Устал думать, боюсь брошу.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.10.2012, 19:54
Ответы с готовыми решениями:

Что делает эта программа, и какие у нее входные данные?
Ребят, кто разбирается в Prolog, можете, пожалуйста объяснить что делает эта программа и рассказать о ее входных данных. Спасибо! DOMAINS...

Входные данные для БПФ
Всем Здравствуйте! Помогите пожалуйста разобраться! Что поступает на вход функции БПФ? Вот у меня есть сигнал в wav формате, какие данные...

Программа получает входные данные из файла input.txt. Файл содержит строки, содержащие математические действия
Помогите написать программу Программа получает входные данные из файла input.txt. Файл содержит строки, содержащие математические...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.10.2012, 19:54
Помогаю со студенческими работами здесь

Массив: Использование алгоритмов сортировки для массивов, входные данные и результаты в файлах
Здравствуйте! помогите пожалуйста с задачей: Использование алгоритмов сортировки для массивов. Для входных и выходных параметров...

Ввести данные для анализа производства продукции
Помогите!!! Создать программу языком VBA, с помошью которой можно ввести данные для анализа производства продукции: объем производства в...

Программа для анализа видео
Всем здрасте! Подскажите,пожалуйста,кто какой программой пользуется для анализа видеопотока? Заранее спасибо!

Программа для анализа логов
Всем привет! Понимаю, что тему не там разместил, но тут народу больше, чем где-то бы ни было :) Подскажите пожалуйста программу,...

Где взять данные для регрессионного и кластерного анализа?
Подскажите пожалуйста.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru