Пред.
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 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 След.
Макеты страниц
Распознанный текст, спецсимволы и формулы могут содержать ошибки, поэтому с корректным вариантом рекомендуем ознакомиться на отсканированных изображениях учебника выше Также, советуем воспользоваться поиском по сайту, мы уверены, что вы сможете найти больше информации по нужной Вам тематике ДЛЯ СТУДЕНТОВ И ШКОЛЬНИКОВ ЕСТЬ
ZADANIA.TO
10.2.4. Сравнительные характеристики символьных и цифровых вычисленийНадеемся, что читатель уже получил общее представление о том, что составляет суть символьных вычислений. Уровень понимания данного вопроса еще более углубится, если провести сравнение возможностей символьных вычислений и более известных цифровых. На рис. 10.9 для удобства в двух колонках приведен перечень их свойств, так что сравнение можно провести достаточно наглядно. Результаты сравнения обсуждаются ниже. Логический вывод является аналогом операции с плавающей запятой. В то время как операция с плавающей запятой является основным видом операций при работе с цифровыми символами, процедуры получения логических выводов применяются при работе с гораздо более широким классом символов, используемых в символьных вычислениях. Логические выводы получают за счет создания определенных комбинаций элементов знаний или группы объектов с целью получения каких-либо заключений. Для логических выводов, которые получают с помощью силлогизмов (двухступенчатых утверждений «если/тогда»), конкретные способы организации графических связей, сравнения фреймов или методов получения логических выводов существенно зависят от представления использованных знаний (системы продукций, семантической сети, фреймов или соответственно исчисления предикатов первого порядка). Комбинирование и обработка структур символьных данных (например, объектов и их признаков) с помощью логических выводов составляют основу для наиболее мощных методик проведения рассуждений в символьных вычислениях. Обладающие выраженной структурой форматы данных, такие как векторы, матрицы и т. д., используемые в цифровых вычислениях, дают возможность создания структур данных, которые могут изменять свой вид при символьной обработке. При выполнении таких заданий, как ориентирование на незнакомой территории, различные игры или ведение диалога перед началом выполнения заданий известен только общий вид данных,
Рис. 10.9. Признаки символьных и цифровых вычислений. используемых для планирования маршрута, выполнения ответных действий на действия противника или соответственно содержащихся в произнесенных фразах. Следовательно, символьные процессоры используют списки объектов, соединенных указателями, аналогичными обсуждавшимся в предыдущих разделах данной главы. В отличие от ситуации в цифровых вычислениях, где структуры данных обычно имеют ограниченные размеры, в символьных вычислениях входные данные, обрабатываемые данные и конечная цель их обработки обычно имеют вид фраз, концепций или других символьных структур с неограниченным размером. Более того, динамические структуры данных позволяют символьной машине работать с неполной информацией или приходить к неопределенным или неоднозначным выводам. Вопрос о возможности использования неточной или неполной информации демонстрирует читателям суть различий между использованием символьных и цифровых данных. Алгоритмы, использовавшиеся в цифровых компьютерах, обладают слабыми возможностями для получения корректных цифровых выходных данных на основе качественных описаний или неполных цифровых входных данных. Выходные данные зависят от точности входных данных, поскольку все наиболее существенные процедуры сводятся к комбинациям цифровых объектов. С другой стороны, характерным свойством большинства символьных представлений данных является то, что заключения могут быть получены чисто качественно, путем получения определенных соотношений, описывающих функциональные свойства. Это возможно даже тогда, когда входная информация является неполной или в некоторых случаях неточной. Следует заметить, что такие методики находятся на переднем крае сегодняшних исследований символьных вычислений и составляют дисциплину, называемую проведением рассуждений по неполным данным [3]. Вполне очевидно, что для реализации всех возможностей символьных вычислений, таких как использование неточных или неполных знаний при проведении рассуждений, требуются специальные языки программирования. Следует заметить, что языки цифрового программирования, такие как Фортран, в руках умелого программиста могли бы использоваться и в символьных вычислениях. Однако они предназначены для определенных применений и сделали бы аналоговое программирование очень трудной задачей. Язык Лисп и его основные версии Интерлисп и Маклисп создают такую среду программирования, которая существенно облегчает обработку символьных выражений, характеризуемых гибкими структурами данных. Семантические значения объектов изменяются непосредственно при расширении или сокращении переменного списка признаков. Другой существенной характеристикой языка Лисп является его рекурсивная природа; любая функция языка Лисп может вызывать саму себя, и любая программа может быть определена содержащимися в ней самой понятиями. Такая способность облегчает поиск списков неопределенной длины в процедуре поиска заданных элементов (свойств), содержащихся в списках. Язык Пролог («программируемая логика») сильно отличается от описанного выше языка Лисп. Язык базируется на правилах системы продукций, и использует методики сравнения образцов, чтобы доказать или опровергнуть какие-либо утверждения программы. В основе языка лежит применение исчисления предикатов для установления соотношений между объектами. Основной операцией в языке Пролог является логическое доказательство некоторых условий или соотношений исходя из набора более простых условий. На рис. 10.9 указано (шестым по порядку) характерное свойство символьных систем, заключающееся в независимости процедуры управления от знаний, имеющихся по конкретной проблеме. При этом в символьных вычислениях понятие управления распространяется на любой процесс, явно или неявно влияющий на порядок выполнения процедур, осуществляемых с целью решения задачи [34]. Указанное важное свойство ярко проявляется в экспертных системах (обсуждаемых в разд. 10.5.3), где фактическая структура стратегии решения может быть рекурсивно изменена на основе поправок, внесенных в процессе совершенствования программы. В этом отношении ситуация сильно отличается от случая цифровых вычислений, где изменения и даже «условные» ветви в программе вводятся в систему заранее. Именно указанная независимость базы знаний от управляющих процедур позволяет экспертной системе «shell» быть достаточно мощным средством, чтобы применяться сразу в нескольких проблемных областях. Примером также служит тот факт, что хотя программа MYCIN была вначале разработана в целях медицинской диагностики бактериальных инфекций, она тем не менее может быть использована для создания базы знаний в области кристаллографии, предназначенной для специалистов по росту кристаллов. Вместо хранения правил, отражающих симптомы болезней, бактерии и лекарственные средства, база знаний должна содержать правила, относящиеся к методикам измерения кристаллографических структур, и рекомендации по методикам роста кристаллов. В области цифровых методов нельзя, например, взять программу, предназначенную для разработки интегральных схем со сверхвысокой степенью интеграции, и приспособить ее для проектирования линз лишь за счет изменения входных данных. Способ внесения изменений в символьные программы также отличается от цифровых методов. Если требуется изменить программу цифрового компьютера, то целая программа или по крайней мере ее часть, куда требуется внести изменения, должна быть выведена из системы, отредактирована и вновь введена в систему; в это же время должен быть перекомпилирован весь (или большая часть) машинный код. При работе с языком Лисп можно модифицировать программу без таких процедур. И программы, и наборы данных в языке Лисп записаны в одном и том же виде, с одним и тем же синтаксисом. В результате этого Лисп-программа может преобразовывать другую программу или базу данных, реализованную на языке Лисп. Она может автоматически исправлять некорректные правила или знания и, кроме того, может выводить вызывающие подозрения правила или знания для контроля оператором, который в свою очередь может вносить изменения в диалоговом режиме без повторной компиляции всей программы. Такие программные средства обладают очень большими возможностями и позволяют оператору организовать специальные «окна» в программе, и таким образом видеть в реальном времени все происходящие изменения в базе знаний или структуре правил. В настоящее время такая форма программного обеспечения не доступна цифровым компьютерам, в которых используются специальные отладочные циклы, требующие существенных затрат времени на поиск ошибок, повторную запись команд, компиляцию, прогоны, поиск новых ошибок, повторную перезапись, компиляцию, прогон и т. д. Поскольку методы внесения изменений в символьных программах отличаются от цифровых программ, то вполне понятно, что мощность символьных вычислений может также быть использована на стадии отладки. Известно, что в цифровой компьютер возможно встроить программу, позволяющую во время выполнения программы печатать сообщения о тех путях, которые были выбраны в ситуациях «если/тогда». В символьном компьютере, однако, машина может не только указать оператору выбранный маршрут достижения цели, но также сообщить, почему она выбрала каждый из путей. Эта особенность является полезной по нескольким причинам; здесь обсуждаются только две из них. Прежде всего она представляет собой ценный диагностический инструмент и фактически является составной частью наиболее развитых программных средств, разработанных для применения в Лисп-машинах. Во-вторых, люди хотят разобраться в причинах получения данного вывода интересующим их конкретным человеком, что позволяет создать определенное мнение о справедливости сделанного заключения. Отнюдь не следует ожидать, что машина полностью заменит человека-эксперта и освободит его от необходимости проверять правильность ее собственных заключений. Однако указанная выше возможность в любом случае создает у пользователя чувство уверенности в своем компьютере. Рассмотрев сходства и различия между символьными и цифровыми вычислениями, читатель может понять некоторые из способов, с помощью которых символьные вычисления могут быть применены к реальным практическим задачам. На основе ранее проведенного обсуждения вопросов представления знаний и стратегий поиска в следующем разделе будет показано, как эти методики приобретают конкретный вид и могут быть трансформированы, а также каким образом они могут привести к затруднениям при работе. Это особенно справедливо по отношению к процессу поиска, который очень часто является причиной возникновения «узких мест» в системах ИИ. Обнаружение путей, по которым оптика может быть применена для выполнения этих операций, может быть ключом к оптическим символьным вычислениям. До обсуждения данного вопроса рассмотрим круг проблем, связанных с использованием символьных вычислений в задачах распознавания речи, системах технического зрения и распознавания образов, обработки естественного языка и экспертных системах.
|
1 |
Оглавление
|