Семантика (программирование)
Сема́нтика в программировании — дисциплина, изучающая формализации значений конструкций языков программирования посредством построения их формальных математических моделей. В качестве инструментов построения таких моделей могут использоваться различные средства, например, математическая логика, λ-исчисление, теория множеств, теория категорий, теория моделей, универсальная алгебра. Формализация семантики языка программирования может использоваться как для описания языка, определения свойств языка, так и для целей формальной верификации программ на этом языке программирования.
Подходы
Операционная семантика (англ. operational semantics ) используется для синтаксических понятий языка. В ней функции рассматриваются как текстуальные правильно построенные определения, обеспечивающие применение к аргументу, а не как функции в математическом понимании этого термина.
Существует классификация различных видов операционной семантики:
Интерпретационная семантика — описание операционной семантики конструкций в терминах языков программирования низкого уровня (язык ассемблера, машинный код). Этот способ позволяет выявлять медленно выполняемые участки программы, и зачастую используется в соответствующих фрагментах систем программирования в целях оптимизации кода программ.
Трансляционная семантика — описание операционной семантики конструкций в терминах языков программирования высокого уровня. С помощью этого способа можно изучать язык, схожий с уже известным программисту.
Трансформационная семантика — описание операционной семантики конструкций языка в терминах этого же языка. Трансформационная семантика является основой метапрограммирования.
Пожалуйста, оформите её согласно правилам оформления статей.
Согласно замыслу одного из участников Википедии, на этом месте должен располагаться раздел, посвящённый денотационной, операционной, аксиоматической семантике.
Вы можете помочь проекту, написав этот раздел.
См. также
- Семантическая паутина
- Семантика вычислений
- Онтология (информатика)
Литература
Согласно замыслу одного из участников Википедии, на этом месте должен располагаться раздел, посвящённый фундаментальной литературе по теме.
Вы можете помочь проекту, написав этот раздел.
- Найти и оформить в виде сносок ссылки на авторитетные источники, подтверждающие написанное.
- Формальные методы
- Семантика языков программирования
Wikimedia Foundation . 2010 .
- Семантика (лингвистика)
- Семафорин
Полезное
Смотреть что такое «Семантика (программирование)» в других словарях:
- Семантика вычислений — Семантика вычислений это определение процесса вычисления в виде последовательности правил перезаписи, которое вместе с представлением о сходимости впервые были использованы в контексте исчисления. Сходимость важна также в системах… … Википедия
- Семантика (значения) — Семантика (от др. греч. σημαντικός обозначающий): В Викисловаре есть статья « … Википедия
- ПРОГРАММИРОВАНИЕ ТЕОРЕТИЧЕСКОЕ — математическая дисциплина, изучающая математич. абстракции программ, трактуемых как объекты, выраженные на формальном языке, обладающие определенной информационной и логич. структурой и подлежащие исполнению на автоматич. устройствах. П. т.… … Математическая энциклопедия
- Нейро-лингвистическое программирование — Нейролингвистическое программирование (НЛП) (англ. Neuro linguistic programming) (также встречается вариант «нейро лингвистическое программирование») комплекс моделей, техник и операционных принципов (контекстуально зависимых убеждений),… … Википедия
- Доказательное программирование — использовавшаяся в 1980 х годах в академических кругах технология разработки программ для ЭВМ с доказательствами правильности доказательствами отсутствия ошибок в программах (понимая, в рамках данной теории, ошибки как несоответствия между… … Википедия
- Нейролингвистическое программирование — Запрос «НЛП» перенаправляется сюда; см. также другие значения. Не следует путать с нейролингвистикой. Возможно, эта статья содержит оригинальное исследование. Добавьте ссылки … Википедия
- Общая семантика — Для термина «Семантика» см. другие значения. Общая семантика (англ. General Semantics, фр. sémantique от греч. σημαντικός обозначающий) эмпирическая дисциплина, представляющая собой систематическую методологию по… … Википедия
- Присваивание (программирование) — Содержание 1 Определение присваивания 1.1 Алгоритм работы оператора присваивания … Википедия
- Присвоение (программирование) — Содержание 1 Определение присваивания 1.1 Алгоритм работы оператора присваивания … Википедия
- Нейролингвистическое программирование: Библиография — Одна из статей на тему Нейролингвистическое программирование (НЛП) Основные статьи НЛП · Принципы · НЛП психотерапия · История Новый код · НЛП и наука · Библиография · Словарь Принципы и методы Моделирование · Метамодель · Милтон модель Позиции… … Википедия
- Обратная связь: Техподдержка, Реклама на сайте
- Путешествия
Экспорт словарей на сайты, сделанные на PHP,
WordPress, MODx.
- Пометить текст и поделитьсяИскать в этом же словареИскать синонимы
- Искать во всех словарях
- Искать в переводах
- Искать в ИнтернетеИскать в этой же категории
Семантика (программирование)
Сема́нтика в программировании — дисциплина, изучающая формализации значений конструкций языков программирования посредством построения их формальных математических моделей. В качестве инструментов построения таких моделей могут использоваться различные средства, например, математическая логика, λ-исчисление, теория множеств, теория категорий, теория моделей, универсальная алгебра. Формализация семантики языка программирования может использоваться как для описания языка, определения свойств языка, так и для целей формальной верификации программ на этом языке программирования.
Связанные понятия
Формальная верификация или формальное доказательство — формальное доказательство соответствия или несоответствия формального предмета верификации его формальному описанию. Предметом выступают алгоритмы, программы и другие доказательства.
Мона́да — это абстракция линейной цепочки связанных вычислений. Монады позволяют организовывать последовательные вычисления.
Объектами первого класса (англ. first-class object, first-class entity, first-class citizen) в контексте конкретного языка программирования называются элементы, которые могут быть переданы как параметр, возвращены из функции, присвоены переменной.
Логи́ческое программи́рование — парадигма программирования, основанная на автоматическом доказательстве теорем, а также раздел дискретной математики, изучающий принципы логического вывода информации на основе заданных фактов и правил вывода. Логическое программирование основано на теории и аппарате математической логики с использованием математических принципов резолюций.
Декларати́вное программи́рование — это парадигма программирования, в которой задаётся спецификация решения задачи, то есть описывается, что представляет собой проблема и ожидаемый результат. Противоположностью декларативного является императивное программирование, описывающее на том или ином уровне детализации, как решить задачу и представить результат. В общем и целом, декларативное программирование идёт от человека к машине, тогда как императивное — от машины к человеку. Как следствие, декларативные.
Упоминания в литературе
Фреге очень необычный мыслитель, поскольку его творческий поиск осуществлялся на стыке философии и математики. Свою главную задачу он видел в том, чтобы подвести под арифметику надежное логическое основание, продемонстрировав возможность определения ее основных понятий и аксиом в терминах чистой логики. Таким образом, Фреге первым выдвинул программу обоснования арифметики путем сведения ее к логике, которая получила название «логицизм». Для выполнения этой программы он создал совершенно новую логику, осуществив первое аксиоматическое построение пропозиционального исчисления и построив теорию квантификации и исчисление предикатов, которые образуют ядро современной математической логики. Эта новая логическая система была сформулирована Фреге на специально разработанном им формально-логическом языке. Задавая интерпретацию этого искусственного языка, Фреге заложил основы логической семантики, однако если в дальнейшем при создании логических языков стали четко отделять их синтаксис (задание словаря исходных символов, формулировка правил образования и преобразования выражений языка и т. п.) от семантики (сопоставление категориям языковых выражений различных типов внеязыковых сущностей), то Фреге выстраивает синтаксис и семантику своей системы одновременно по мере введения новых знаков и выражений. Более того, семантика языка формулируется им с учетом уже имеющейся онтологии внеязыкового мира, для представления которой и создается язык. Однако следует отметить, что Фреге не просто взял стандартную онтологию для арифметики, которая включает теорию чисел и математический анализ, но внес в нее существенные дополнения и изменения, по-новому осмыслив многие математические понятия, прежде всего понятия функции, класса и числа.
Мы поддерживаем следующие рассуждения Дж. Люгера: «…понимание естественного языка включает куда больше, чем разбор предложений на индивидуальные части речи и поиск значений слов в словаре. Оно базируется на обширном фоновом знании о предмете беседы и идиомах, используемых в этой области, так же, как и на способности применять общее контекстуальное знание для понимания недомолвок и неясностей, присущих человеческой речи. Задача сбора и организации этого фонового знания, чтобы его можно было применить к осмысливанию языка, составляет значительную проблему в автоматизации понимания естественного языка. Разработано множество методов структурирования семантических значений. Но, из-за огромных объемов знаний, требуемых для понимания естественного языка, большая часть работы ведется в хорошо понимаемых специализированных проблемных областях. Методики представления известных специализированных программ слишком просты, чтобы передать семантическую организацию более богатых и сложных предметных областей. Основная часть текущих работ в этой области направлена на поиск формализмов представления, которые должны быть достаточно общими, чтобы применяться в широком круге приложений и уметь адаптироваться к специфичной структуре заданной области. Множество разнообразных методик, большинство из которых являются развитием или модификацией семантических сетей, исследуются с этой целью и используются при разработке программ, способных понимать естественный язык в ограниченных, но достаточно интересных предметных областях. Есть стохастические модели, описывающие совместное использование слов в языке, которые применяются для характеристики как синтаксиса, так и семантики. Далее следует принципиально важный вывод: полное понимание языка на вычислительной основе все же остается далеко за пределами современных возможностей» [264, стр. 47].
В области методологии и философии науки семантика чаще всего понимается как выполняющая задачу приписывания «интерпретации» «бессмысленным» выражениям некоторого данного языка. Эта интерпретация в свою очередь рассматривается как приписывание некоторых подходящих референтов, или объектов (индивидов, множеств индивидов и т. д.), разного рода символам, которые, как предполагается, таким образом получают значение (meaning) и становятся осмысленными (meaningful). Этот подход стал стандартным для семантики формальных систем и составляет основную точку зрения, на которой в математической логике основывается теория моделей; на этом подходе основываются также практически все современные работы по семантике эмпирических теорий[164].
6. Среди проблем, решения которых ожидают от семантики, назовем, прежде всего, проблему производства сем (от греч. sema – знак). Теоретически можно себе представить, что около двух десятков бинарных категорий сем, рассматриваемых как таксономическая основа некоторой комбинаторики, способны произвести несколько миллионов сочетаний семем, количество, на первый взгляд, вполне достаточное, чтобы покрыть семантический универсум, соотносительный (ко-экстенсивный) с тем или иным естественным человеческим языком. Не говоря о практической трудности установления подобной основы семантических универсалий, возникает другая, не менее сложная проблема, касающаяся уточнения правил семантической совместимости и несовместимости, которые управляют построением не только семем, но также и более крупных синтагматических единиц (высказывание, дискурс). Мы видим, что семный (или компонентный) анализ дает удовлетворительные результаты только при проведении ограниченных таксономических описаний (которые можно распространить на структурацию более открытых семантических полей), поэтому следует оставить мысль о возможности создать для семантического анализа матрицы, подобные тем, которые фонология может создавать для своих задач. В конце концов, лингвистическая семантика (генеративная или логическая, в духе О. Дюкро) тем самым сводится только к установлению возможных универсалий. Таким образом, в 60-х гг. пришлось отказаться от иллюзорной веры в возможность разработки необходимых средств для исчерпывающего анализа плана содержания естественных языков. В то время лингвистика, как теперь стало ясно, ставила перед собой неразрешимую задачу: осуществить полное описание всей совокупности культур человечества.
Возможна ли такая смысловая переработка, трансформация текста, позволяющая исследовать процесс формирования рецептивного грамматического навыка в условиях омонимичности/частичной омонимичности грамматических структур текста? Структуры не заданы текстом изначально, а конструируются в нём извне: в одном случае это отдельные предложения, в другом, группа предложений. Для понимания процесса структурирования текста важно выделение не только лингвистического значения (языкового плана выражения), но и функционального значения, приобретаемого в данном контексте каждой группой предложений или отдельными предложениями. «Переход от одного функционального значения к другому возможен лишь потому, что обеспечивается лингвистическим значением, семантика которого богаче семантики любого функционального значения» [Смирнов, 1983, с. 111].
Связанные понятия (продолжение)
Синтаксис языка программирования — набор правил, описывающий комбинации символов алфавита, считающиеся правильно структурированной программой (документом) или её фрагментом. Синтаксису языка противопоставляется его семантика. Синтаксис языка описывает «чистый» язык, в то же время семантика приписывает значения (действия) различным синтаксическим конструкциям.
Абстра́ктный тип да́нных (АТД) — это математическая модель для типов данных, где тип данных определяется поведением (семантикой) с точки зрения пользователя данных, а именно в терминах возможных значений, возможных операций над данными этого типа и поведения этих операций.
Ленивые вычисления (англ. lazy evaluation, также отложенные вычисления) — применяемая в некоторых языках программирования стратегия вычисления, согласно которой вычисления следует откладывать до тех пор, пока не понадобится их результат. Ленивые вычисления относятся к нестрогим вычислениям. Усовершенствованная модель ленивых вычислений — оптимистичные вычисления — переходит в разряд недетерминированных стратегий вычисления.
Примитивный (встроенный, базовый) тип — тип данных, предоставляемый языком программирования как базовая встроенная единица языка.
Процеду́рное программи́рование — программирование на императивном языке, при котором последовательно выполняемые операторы можно собрать в подпрограммы, то есть более крупные целостные единицы кода, с помощью механизмов самого языка.
Паради́гма программи́рования — это совокупность идей и понятий, определяющих стиль написания компьютерных программ (подход к программированию). Это способ концептуализации, определяющий организацию вычислений и структурирование работы, выполняемой компьютером.
Императи́вное программи́рование — это парадигма программирования (стиль написания исходного кода компьютерной программы), для которой характерно следующее.
Абстракция данных — популярная и в общем неверно определяемая техника программирования. Фундаментальная идея состоит в разделении несущественных деталей реализации подпрограммы и характеристик, существенных для корректного её использования. Такое разделение может быть выражено через специальный «интерфейс», сосредотачивающий описание всех возможных применений программы.
По одной из классификаций, языки программирования неформально делятся на сильно и слабо типизированные (англ. strongly and weakly typed), то есть обладающие сильной или слабой системой типов. Эти термины не являются однозначно трактуемыми, и чаще всего используются для указания на достоинства и недостатки конкретного языка. Существуют более конкретные понятия, которые и приводят к называнию тех или иных систем типов «сильными» или «слабыми».
Исчисление процессов или алгебра процессов — семейство связанных подходов к формальному моделированию параллельных систем.
Сопоставление с образцом (англ. Pattern matching) — метод анализа и обработки структур данных в языках программирования, основанный на выполнении определённых инструкций в зависимости от совпадения исследуемого значения с тем или иным образцом, в качестве которого может использоваться константа, предикат, тип данных или иная поддерживаемая языком конструкция.
Метапрограммирование — вид программирования, связанный с созданием программ, которые порождают другие программы как результат своей работы (в частности, на стадии компиляции их исходного кода), либо программ, которые меняют себя во время выполнения (самомодифицирующийся код). Первое позволяет получать программы при меньших затратах времени и усилий на кодирование, чем если бы программист писал их вручную целиком, второе позволяет улучшить свойства кода (размер и быстродействие).
Фу́нкция вы́сшего поря́дка — в программировании функция, принимающая в качестве аргументов другие функции или возвращающая другую функцию в качестве результата. Основная идея состоит в том, что функции имеют тот же статус, что и другие объекты данных. Использование функций высшего порядка приводит к абстрактным и компактным программам, принимая во внимание сложность производимых ими вычислений.
Идиома программирования — устойчивый способ выражения некоторой составной конструкции в одном или нескольких языках программирования. Идиома является шаблоном решения задачи, записи алгоритма или структуры данных путём комбинирования встроенных элементов языка.
Запись — агрегатный тип данных, инкапсулирующий без сокрытия набор значений различных типов.
Обобщённое программирование (англ. generic programming) — парадигма программирования, заключающаяся в таком описании данных и алгоритмов, которое можно применять к различным типам данных, не меняя само это описание. В том или ином виде поддерживается разными языками программирования. Возможности обобщённого программирования впервые появились в виде дженериков (обобщённых функций) в 1970-х годах в языках Клу и Ада, затем в виде параметрического полиморфизма в ML и его потомках, а затем во многих объектно-ориентированных.
Алгебраи́ческий тип да́нных — в информатике наиболее общий составной тип, представляющий собой тип-сумму из типов-произведений. Алгебраический тип имеет набор конструкторов, каждый из которых принимает на вход значения определённых типов и возвращает значение конструируемого типа. Конструктор представляет собой функцию, которая строит значение своего типа на основе входных значений. Для последующего извлечения этих значений из алгебраического типа используется сопоставление с образцом.
Блок (также говорят блок кода, блок команд, блок инструкций) в программировании — это логически сгруппированный набор идущих подряд инструкций в исходном коде программы, является основой парадигмы структурного программирования.
В информатике параллели́зм — это свойство систем, при котором несколько вычислений выполняются одновременно, и при этом, возможно, взаимодействуют друг с другом. Вычисления могут выполняться на нескольких ядрах одного чипа с вытесняющим разделением времени потоков на одном процессоре, либо выполняться на физически отдельных процессорах. Для выполнения параллельных вычислений разработаны ряд математических моделей, в том числе сети Петри, исчисление процессов, модели параллельных случайных доступов.
Пролог (англ. Prolog) — язык и система логического программирования, основанные на языке предикатов математической логики дизъюнктов Хорна, представляющей собой подмножество логики предикатов первого порядка.
Предметно-ориентированный язык (англ. domain-specific language, DSL — «язык, специфический для предметной области») — язык программирования, специализированный для конкретной области применения (в противоположность языку общего назначения, применимому к широкому спектру областей и не учитывающему особенности конкретных сфер знаний). Построение такого языка и/или его структура данных отражают специфику решаемых с его помощью задач. Является ключевым понятием языково-ориентированного программирования.
Вывод типов (англ. type inference) — в программировании возможность компилятора самому логически вывести тип значения у выражения. Впервые механизм вывода типов был представлен в языке ML, где компилятор всегда выводит наиболее общий полиморфный тип для всякого выражения. Это не только сокращает размер исходного кода и повышает его лаконичность, но и нередко повышает повторное использование кода.
Ме́тод в объектно-ориентированном программировании — это функция или процедура, принадлежащая какому-то классу или объекту.
Аспе́ктно-ориенти́рованное программи́рование (АОП) — парадигма программирования, основанная на идее разделения функциональности для улучшения разбиения программы на модули.
Динами́ческая типиза́ция — приём, широко используемый в языках программирования и языках спецификации, при котором переменная связывается с типом в момент присваивания значения, а не в момент объявления переменной. Таким образом, в различных участках программы одна и та же переменная может принимать значения разных типов. Примеры языков с динамической типизацией — Smalltalk, Python, Objective-C, Ruby, PHP, Perl, JavaScript, Lisp, xBase, Erlang, Visual Basic.
Каламбур типизации является прямым нарушением типобезопасности. Традиционно возможность построить каламбур типизации связывается со слабой типизацией, но и некоторые сильно типизированные языки или их реализации предоставляют такие возможности (как правило, используя в связанных с ними идентификаторах слова unsafe или unchecked). Сторонники типобезопасности утверждают, что «необходимость» каламбуров типизации является мифом.
Система типов — совокупность правил в языках программирования, назначающих свойства, именуемые типами, различным конструкциям, составляющим программу — таким как переменные, выражения, функции или модули. Основная роль системы типов заключается в уменьшении числа багов в программах посредством определения интерфейсов между различными частями программы и последующей проверки согласованности взаимодействия этих частей. Эта проверка может происходить статически (на стадии компиляции) или динамически.
Реляционная модель данных (РМД) — логическая модель данных, прикладная теория построения баз данных, которая является приложением к задачам обработки данных таких разделов математики, как теория множеств и логика первого порядка.
Тип-сумма (англ. sum type; также Σ-тип, меченое объединение) — конструкция в языках программирования и интуиционистской теории типов, тип данных, построенный как дизъюнктное объединение исходных типов.
Область видимости (англ. scope) в программировании — часть программы, в пределах которой идентификатор, объявленный как имя некоторой программной сущности (обычно — переменной, типа данных или функции), остаётся связанным с этой сущностью, то есть позволяет посредством себя обратиться к ней. Говорят, что идентификатор объекта «виден» в определённом месте программы, если в данном месте по нему можно обратиться к данному объекту. За пределами области видимости тот же самый идентификатор может быть.
Объектно-ориентированный язык программирования (ОО-язык) — язык, построенный на принципах объектно-ориентированного программирования.
Контрактное программирование (design by contract (DbC), programming by contract, contract-based programming) — это метод проектирования программного обеспечения. Он предполагает, что проектировщик должен определить формальные, точные и верифицируемые спецификации интерфейсов для компонентов системы. При этом, кроме обычного определения абстрактных типов данных, также используются предусловия, постусловия и инварианты. Данные спецификации называются «контрактами» в соответствии с концептуальной метафорой.
Сопрограммы (англ. coroutines) — методика связи программных модулей друг с другом по принципу кооперативной многозадачности: модуль приостанавливается в определённой точке, сохраняя полное состояние (включая стек вызовов и счётчик команд), и передаёт управление другому. Тот, в свою очередь, выполняет задачу и передаёт управление обратно, сохраняя свои стек и счётчик.
Мо́дульное программи́рование — это организация программы как совокупности небольших независимых блоков, называемых модулями, структура и поведение которых подчиняются определённым правилам. Использование модульного программирования позволяет упростить тестирование программы и обнаружение ошибок. Аппаратно-зависимые подзадачи могут быть строго отделены от других подзадач, что улучшает мобильность создаваемых программ.
Наследование (англ. inheritance) — концепция объектно-ориентированного программирования, согласно которой абстрактный тип данных может наследовать данные и функциональность некоторого существующего типа, способствуя повторному использованию компонентов программного обеспечения.
Компонентно-ориентированное программирование (англ. component-oriented programming, COP) — парадигма программирования, существенным образом опирающаяся на понятие компонента — независимого модуля исходного кода программы, предназначенного для повторного использования и развёртывания и реализующегося в виде множества языковых конструкций (например, «классов» в объектно-ориентированных языках программирования), объединённых по общему признаку и организованных в соответствии с определёнными правилами.
Инкапсуляция (англ. encapsulation, от лат. in capsula) — в информатике упаковка данных и функций в единый компонент.
Из-за путаницы с терминологией словом «оператор» в программировании нередко обозначают операцию (англ. operator), см. Операция (программирование).Инстру́кция или опера́тор (англ. statement) — наименьшая автономная часть языка программирования; команда или набор команд. Программа обычно представляет собой последовательность инструкций.
Функциона́льное программи́рование — раздел дискретной математики и парадигма программирования, в которой процесс вычисления трактуется как вычисление значений функций в математическом понимании последних (в отличие от функций как подпрограмм в процедурном программировании).
Побо́чные эффе́кты (англ. side effects) — любые действия работающей программы, изменяющие среду выполнения (англ. execution environment). Например, к побочным эффектам относятся.
Замыкание (англ. closure) в программировании — функция первого класса, в теле которой присутствуют ссылки на переменные, объявленные вне тела этой функции в окружающем коде и не являющиеся её параметрами. Говоря другим языком, замыкание — функция, которая ссылается на свободные переменные в своей области видимости.
Теория языков программирования (англ. programming language theory, PLT) — раздел информатики, посвящённый вопросам проектирования, анализа, определения характеристик и классификации языков программирования и изучением их индивидуальных особенностей. Тесно связана с другими ветвями информатики, результаты теории используются в математике, в программной инженерии и лингвистике.
Синтакси́ческий ана́лиз (или разбор, жарг. па́рсинг ← англ. parsing) в лингвистике и информатике — процесс сопоставления линейной последовательности лексем (слов, токенов) естественного или формального языка с его формальной грамматикой. Результатом обычно является дерево разбора (синтаксическое дерево). Обычно применяется совместно с лексическим анализом.
Языково-ориентированное программирование (ЯОП) (англ. Language Oriented Programming), также Расходящаяся разработка (англ. middle out development), также метаязыковая абстракция, также Разработка, опирающаяся на предметно-специфичный язык (англ. DSL-Based Development) — парадигма программирования, заключающаяся в разбиении процесса разработки программного обеспечения на стадии разработки предметно-ориентированных языков (DSL) и описания собственно решения задачи с их использованием. Стадии могут.
Абстрактное синтаксическое дерево (АСД) — в информатике конечное помеченное ориентированное дерево, в котором внутренние вершины сопоставлены (помечены) с операторами языка программирования, а листья — с соответствующими операндами. Таким образом, листья являются пустыми операторами и представляют только переменные и константы.
Упоминания в литературе (продолжение)
Но, как правило, под информацией понимают ее абстрактное значение – семантику. Если мы хотим обмениваться информацией, нам необходимы согласованные представления, чтобы не нарушалась правильность интерпретации. Для этого интерпретацию представления информации отождествляют с некоторыми математическими структурами. В этом случае обработка информации может быть выполнена строгими математическими методами.
Вопрос изучения и классификации элементов, служащих показателями семантико-синтаксических отношений в спектре синтаксических конструкций от минимального ССЦ до связного текста издавна вызывает большой интерес у исследователей. Эти элементы имеют различную природу. Роль средств связи в организации связного текста (СТ) могут выполнять морфологические элементы – союзы, их аналоги и союзные сочетания; соотношение видовременных форм сказуемых, связь тематических слов и их местоименных анафоризаторов, порядок слов и соотношение моделей порядка слов, различного характера лексические средства, разнообразные синтаксические способы организации целостности СТ – детерминация одного компонента высказывания другим, параллелизм и иные виды закономерной соотнесенности членов частей СТ, семантика компонентов СТ, реализующая гипонимические и гиперонимические отношения, функциональные и коммуникативные факторы – актуальное членение и фокусировка и др. Нам кажется, особое внимание следует уделить грамматическим феноменам, обнаруживающим известное союзоподобие, которые являются формальными средствами организации синтаксических связей между компонентами СТ – межфразовым скрепам (в дальнейшем – МФС) различной сложности и оформленности. Выбор и использование МФС определяется многими факторами, которые обусловлены спецификой синтаксического уровня, на котором они функционируют – уровня СТ.
B. Мыслительные операции человека, в вашем представлении, строятся по принципу символического представления (репрезентации – поэтому вычислительный подход нередко называют также репрезентатистским), который лежит в основе работы компьютера; входные данные переводятся на особый символический язык, посредством которого они обрабатываются. Это означает, что если процесс «вне» головы, вызвавший когнитивный акт, можно объяснить как физический динамический процесс, то процесс «в» голове следует объяснять по законам семантики, т. е. смыслового отношения одной системы символов с другой системой символов. Тем самым процесс познания, а с ним и мир в целом, оказывается удвоенным, разорванным, по меньшей мере, на две несводимые реальности – физическую и семантическую.
Еще один важный признак грамматикализации – однонаправленное изменение от меньшей к большей грамматичности – отмечается на наших примерах в полной мере: например, лексически прозрачный условно-следственный двухместный союз если… так, потеряв первый компонент, становится в конструкции Гулять так гулять! по существу чисто грамматическим маркером конструкции, сохраняя лишь «этимологическую» связь с исходным союзом, союзные функции и его условно-следственную семантику.
Анализ документов может быть качественным (проблемный поиск, тематические обобщения) и количественным (контент-анализ, количественная семантика, основанные на идентификации «поисковых образцов» и их подсчете, так, например, могут исследоваться лексика документов, частота использования определенных идей, выражений, высказываний). Для аналитической количественной работы необходимо разработать систему категорий классификации изучаемого материала.
Если искать отличия между двуголосием и одноголосыми дискурсами, также основанными на семантической связи, то прежде всего очевидно, что условно само введенное нами основание их внешнего сходства – категория семантики, поскольку последняя в ее обычном понимании для бахтинской концепции «тело инородное». У Бахтина эта сфера покрывается теорией интенционального расслоения языка, основанной на персоналистическом (а не аналитическом или синтетическом) критерии разделения, сопоставления или объединения смысловых компонентов, вбирающем в себя в том числе и отсутствующие в чистой семантике тональные компоненты смысла. Поскольку бахтинский интенционально-персоналистский подход к области смысла есть отражение его общей установки на диалог, постольку этот подход используется им и применительно к диалогической по своей природе вторичной предикации ДС. Можно и обобщить: бахтинская теория интенциональности персоналистически и диалогически переосмысливает все те семантические связи, которые обычно рассматриваются как участвующие в формировании одноголосых предикативных актов с семантически непроизвольной природой (то есть дискурсов логического, диалектического или символического типа).
Мы полагаем, что дисфункциональность исходной репрезентации, а также существенные сложности, которые испытывает решатель, пытаясь перейти к новой репрезентации, задается противоречием/ями в ее структуре. Противоречие может корениться в несочетаемых интерпретациях семантики и/или синтаксиса отдельных утверждений задачи, во взаимоисключающих функциональных требованиях к одним и тем же (материальным) объектам, составляющим проблемную ситуацию, а также в несовместимости (несоответствии друг другу) различных частей репрезентации задачи, включающих различные форматы кодирования. Это приводит к тому, что одни части (варианты) репрезентации задачи, возникшие у испытуемого на основе прошлых знаний или перцептивно выделенных условий, ограничивают появление новых частей (вариантов) репрезентации и тем самым усложняют и замедляют обнаружение правильного ответа.
Важной особенностью психолингвистического исследования является его обращение к значению слова, т. е. к его семантике (И. А. Зимняя, 2001; D. D. Steinberg, N. Hiroshi, Р. A. David, 2001[3]). В лингвистике анализ семантики языкового знака связан, прежде всего, с изучением лексического значения слов и выражений, процесса изменения значений языковых единиц, с исследованием оборотов речи или грамматических форм. В то же время психолингвистика различает объективную и субъективную семантику. Первая представляет собой семантическую систему значений знаков данного языка (главным образом слов); вторая выступает как ассоциативная система значений, существующая в сознании индивидуума. В связи с этим семантические признаки языковых знаков подразделяются на: 1) относящиеся к области представлений-ассоциаций (субъективные) и 2) принадлежащие семантическим компонентам лексики, рассматриваемой в абстрактно-логическом (объективном) плане. При этом в психолингвистическом понимании понятие «семантическое поле» означает совокупность слов (связанных по смыслу с данной лексемой) вместе с их ассоциациями (А. Р. Лурия, 1998; А. Р. Лурия, О. С. Виноградова, 1974 и др.).
На уровне семантики (семантический аспект информации) информация рассматривается как отношение между знаками и обозначаемыми ими объектами. Семантику рассматривают иногда как «теорию значения», поскольку информация в данном случае считается неким замещением отражаемого объекта. Теоретические основы семантики базируются на взглядах Р. Карнапа, высказанных им в 1946 г.
Собственно термин «фрактал», предложенный Б. Мандельбротом в середине 1970-х гг. для обозначения нерегулярных геометрических форм, обладающих самоподобием во всех масштабах, образован, как объясняет сам ученый, от латинского причастия «fractus» и в соответствии с семантикой исходного глагола «frangere» имеет значение «фрагментированный», «изломанный» и «неправильный по форме»[24]. Удивительно, но точного непротиворечивого математического определения фракталов не выработано до сих пор. В самом общем виде, за рамками специальных математических дефиниций, фрактал был определен Б. Мандельбротом как «структура, состоящая из частей, которые в некотором смысле подобны целому»[25]. Степень сложности, «изломанности» фрактального объекта определяет его фрактальную размерность, которая чаще всего превышает его топологическую размерность, то есть линия благодаря многочисленным изгибам как бы стремится превратиться в плоскость, а «складчатая» плоскость – в объемную фигуру.
Учитывая такую научно-практическую направленность анализа, термин «когнитивный опыт» мы используем в операциональном смысле как знания, накопленные человеком в его практической деятельности и определяющие ее специфику. Иными словами, речь идет о выявлении опыта в его классическом определении (совокупность знаний, умений, навыков, отношений…), но применительно к практике его использования человеком. Нас интересует, прежде всего, возможность доступа к содержанию опыта в конкретных условиях человеческой деятельности и методы анализа, которые могут оказаться продуктивными для его последующего воспроизведения. Поэтому мы не дифференцируем различные встречающиеся в литературе понятия опыта, а рассматриваем их в ракурсе тех составляющих содержания опыта, которые они позволяют раскрыть. Так, например, понятие «ментальный опыт» выступает в качестве психического носителя свойств интеллектуальной деятельности в онтологическом подходе к изучению интеллекта (Холодная, 2011, 2012). Понятие «субъективный опыт» широко применяется в психологии субъективной семантики при моделировании опыта человека структурами значений (Артемьева, 1980, 1999), а в психофизиологических исследованиях используется для обозначения целостной индивидуально-специфичной структуры субъективных моделей адаптивного взаимодействия индивида с миром (Александров, Александрова, 2009; Александров и др., 2015). Особое внимание будет уделяться исследованиям, в которых рассматривается инструментальная составляющая когнитивного опыта. Здесь имеются в виду работы Ю. К. Корнилова (2000, 2014), посвященные «инструментальному опыту», и инструментальный подход П. Рабарделя (Рабардель, 1999; Rabardel, 1995). Для более детального анализа применения понятий опыта в психологии можно обратиться, например, к работе К. С. Семенцовой (2012).
Развитие ОГК ведет к созданию специфического языка образно-географической карты. Семантика образно-географических карт опирается на возможности морфологической трансформации ГО по отношению к соответствующему географическому объекту и к самому себе. С одной стороны, один и тот же географический объект может выступать как источник, порождающий несколько различных ГО и, соответственно, несколько возможных образно-географических карт с разным составом элементов, а также с различными значениями совпадающих во всех картах элементов. С другой стороны, возможно создание нескольких образно-географических карт одного и того же ГО, с различной интерпретацией составляющих его архетипов, знаков и символов – в зависимости от целей и задач создающего ту или иную карту. Следовательно,
Динамический подход к языку лег в основу такого направления в современном языкознании, как дериватология, предметом научного исследования которой стали процессы образования языковых единиц. Понятие производности распространено в рамках дериватологии на такие языковые области, как лексика, синтаксис, семантика. Результатом деривационных процессов (хотя, безусловно, не только их) оказывается и текст, который в то же время является источником всех возможных деривационных инноваций – от лексических до семантических.
С точки зрения диалектической логики на определенном этапе изучения объекта, а именно, когда выделены и зафиксированы его всеобщие свойства и отношения, правильным в научном отношении методом дальнейшего его изучения будет диалектико-материалистический метод восхождения от абстрактного к конкретному [183, c. 16]. Но этот всеобщий научный метод является в лингвистике наименее разработанным. Обсуждение проблем гносеологии в языкознании характерно для его логического направления, которое по своей теоретической основе ориентировано на те или другие школы в логике и философии – неопозитивизма и эмпиризма, философии анализа, диалектического материализма и др. Тенденция укрупнения знания вначале реализуется методом «уплотнения» и уточнения знания. Укрупнение в области грамматики осуществляется главным образом на семантической основе. Учеными вводятся в научный оборот такие концентрированные образования, как «понятийные категории» (И. И. Мещанинов), «скрытые категории» или «криптотипы» (Б. Л. Уорф), «категория аспектуальности» (Е. В. Гулыга, Е. И. Шендельс, Б. М. Балин), «функциональносемантические категории» (А. В. Бондарко). Укрупнение лексики и семантики позволяет выявить более глубокие парадигматические группировки слов, смысловых образований (А. А. Уфимцева, И. М. Кобозева, М. А. Кронгауз).
Психолингвистика Н.Хомского весьма уязвима и в других отношениях. Она ограничивается проблемами восприятия и порождения предложения – лингвистической единицы, определяемой через грамматику, семантику и сегментную фонетику и принципиально изолируемой от целостного осмысленного текста. Она рассматривает именно предложение (sentence), а не высказывание (utterance), т.е. игнорируется реальное соотношение различных языковых уровней (и невербальных средств) в формировании и восприятии той или иной коммуникативной единицы. Априорно предполагается, что основой порождения и восприятия высказывания всегда является его морфосинтаксическая структура. Далее, предложение рассматривается вне реальной ситуации общения. Игнорируется место речи, а также ее восприятия, в системе психической деятельности человека – речь и ее восприятие рассматриваются как автономные, самоценные процессы. Игнорируются индивидуальные, в частности личностно обусловленные, особенности восприятия и производства речи: сама идея индивидуальных стратегий оперирования с языком отвергается с порога.
Речь построена из элементов языка, подчинена его законам, но она не равна, не тождественна языку. В живом процессе речи языковые единицы получают «чрезвычайную прибавку», а именно выбор, размещение, комбинирование, повторение и трансформирование. «Используясь в речи (как процессе речевого общения), знаки языка могут получать семантические наслоения, в их семантике (значении) могут происходить значительные сдвиги, т. е. они могут в той или иной степени трансформироваться. Ярким примером этого могут служить образные значения слов и словосочетаний, возникающие в речи писателей и поэтов, – метафорические, метонимические и иные» [22, с. 43].
В философии нередко встречается понятие «неформальная логика» (сходные смыслы несут в себе такие аспекты исследования сущности мышления, как «логический анализ языка», «логическая семантика» и некоторые другие). Ее цель – анализ разнообразных смысловых систем, выявление логических ошибок и их причин.
Применение лингвистических методов исследования семантики речи сделало возможным с новой стороны подойти к анализу речевой продукции субъектов патологии, абстрагироваться от ряда индивидуальных языковых факторов (лексикон, социальный статус, образование, сфера занятий, IQ и др.), затрудняющих клиническую трактовку высказываний. Методика КА позволила дополнить клинико-психопатологический метод исследованием патологического смыслообразования.
Традиционно деятельность переводчика рассматривается как мыслительная деятельность, которая направлена на восприятие на иностранном языке и передачу на языке перевода смысла высказывания. Поэтому основными направлениями исследований в области перевода являются предметно-фактологическая основа текста, мысль и семантика [32, с. 17]. Такой подход находит отражение и в учебных пособиях, и в самом процессе обучения, когда внимание преподавателя направлено в основном на результат процесса перевода.
В данной главе рассматриваются вопросы синтаксической организации глагольных фразеологизмов с конструктивно обусловленным значением и структурно-семантических конструкций, восполняющих семантику этих фразеологизмов. В § 1 данной главы мы предполагаем систематизировать все структурные модели интересующих нас фразеологических единиц, имея в виду здесь под структурной моделью фразеологизма только конкретный грамматический тип его организации без связи с теми свободными компонентами текста, которые, обладая определённой структурой, необходимы для реализации самого фразеологизма в речи.
Специальный вопрос, много изучавшийся в СССР, – вопрос о психологической сущности речевых стереотипов. Он был поставлен еще в 20-х годах крупнейшим советским языковедом Л.П. Якубинским, собравшим и проанализировавшим с лингвистической точки зрения высказывания В.И. Ленина о так называемой «фразе» (Якубинский, 1926). Сейчас проблема стереотипа исследуется в СССР как в теоретическом плане (Артемов, 1970; Костомаров, 1971), так и в плане экспериментальном (Дридзе, 1969). Необходимо отметить, что в осмыслении этой проблемы есть существенное различие между американскими исследователями, как правило, опирающимися на «теорию стереотипизации» У. Липпмана, идеи «политической семантики» Г. Лассуэлла и аналогичные им концепции бихевиористского характера, и советскими исследователями, стоящими на совершенно иной общепсихологической и методологической платформе.
Что касается постулата анализа и синтеза, то «единство анализа и синтеза представляет собой важный методологический принцип, требующий реализации при конструировании изучаемого предмета, так же как и при проектировании реальной будущей деятельности» [там же, с. 25-26]. В поле исследовательского интереса Г.В. Суходольского находится изучение базовых принципов теории деятельности, а также рассмотрение семантики, морфологии, аксиологии и праксиологии деятельности.
Диалогическая речь, являясь основной формой организации разговорной речи, протекает в конкретной ситуации, эмоциональна, сопровождается паралингвистическими средствами общения[1]. Характерной особенностью речевой деятельности в форме диалога является высокая частотность изменения программы высказывания по ходу ее внешнего оформления. Эти особенности сказываются на языковом оформлении диалога. Речь в нем может быть неполной, сокращенной, для диалога характерны краткость, недоговоренность, известная фрагментарность семантики; кратковременное предварительное обдумывание; использование разговорной лексики и фразеологии, употребление частиц, междометий, местоимений, наличие семантически незначимых слов – заменителей паузы, добавлений, шаблонов.
– наречия образа действия, меры и степени, а также предложно-падежные словоформы с аналогичной семантикой;
Предметная область культурологии также широка. Ее составляют онтология культуры (многообразие ракурсов познания); гносеология культуры (основания культурологического знания, его структура и методология); морфология культуры; культурная семантика (представления о символах, знаках, языках культуры); антропология культуры (представления о личностных параметрах культуры); социология культуры; социальная и историческая динамика культуры; прикладные аспекты культурологии.
Семантика языков программирования
В теоретической информатике , формальная семантика (из языков программирования ) является изучением смысла компьютерных программ рассматриваются как математические объекты .
Резюме
- 1 Связь с лингвистикой
- 2 Общая семантика языка программирования
- 2.1 Операционная семантика
- 2.2 Денотационная семантика
- 2.3 Аксиоматическая семантика
- 4.1 Связанные статьи
Связь с лингвистикой
Как и в лингвистике , семантика , применяемая к языкам программирования , обозначает связь между означающим , программой и означаемым, математическим объектом. Математический объект зависит от свойств, которые необходимо знать программе.
Семантика также является связующим звеном между:
- означающий язык: язык программирования
- означаемый язык: логика Хоара , автоматы .
Общая семантика языка программирования
Наиболее распространенная семантика, используемая для понимания языка программирования:
- операционная семантика
- денотационная семантика
- аксиоматическая семантика .
Операционная семантика
В операционной семантике значение программы — это последовательность состояний машины, выполняющей программу. Другими словами, программа считается описанием системы перехода между состояниями .
В этой семантике программы:
a=1; b=0
a=1; b=0
эквивалентны, потому что имеют одинаковое значение.
С другой стороны, программа:
b=0; a=1
не эквивалентен им. В самом деле, даже если конечный результат один и тот же, действия по присвоению значений переменным a и b не происходят в одном и том же порядке.
Можно абстрагироваться от этой семантики, наблюдая только за частью памяти машины, например:
- взаимодействие программы с внешним миром
- след программы.
Денотационная семантика
Денотационная семантика, инициированная Кристофером Стрейчи и Даной Скотт , представляет собой подход, в котором математическая функция, называемая денотацией , связана с каждой программой и определенным образом представляет ее эффект, ее значение. Эта функция принимает, например, состояние памяти до выполнения и возвращает состояние после выполнения.
В этой семантике все приведенные выше примеры операционной семантики эквивалентны, но программа:
a=1; b=1;
не эквивалентен им.
Существует несколько вариантов денотационной семантики, одним из самых известных является денотационная семантика продолжением, которая вместо того, чтобы связывать программу с функцией, которая преобразует память, связывает ее с функцией, которая преобразует продолжение (будущее) машины после выполнение программы и продолжение перед выполнением программы. Другими словами, денотационная семантика продолжения работает в обратном порядке по отношению к программе, она учитывает, что происходит после инструкции, чтобы вывести из нее, что должно произойти до этой инструкции.
Одним из важных аспектов денотационной семантики является свойство композиционности : обозначение программы получается путем комбинирования обозначений ее составляющих.
Аксиоматическая семантика
В аксиоматической семантике программа является не более чем преобразователем логических свойств состояния памяти: если у нас p истинно до выполнения, то у нас есть q истинно после. Нас больше не интересует точное состояние памяти, пока мы знаем, сохраняется ли это свойство.
Если интересующее нас свойство — знать , положительны ли значения a и b после выполнения программы, то все предыдущие примеры эквивалентны в том смысле, что независимо от состояния машины перед выполнением программы выполняется en exit. Что мы отмечаем в логике Хоара :
Связь между различной семантикой
Эти три семантики, как показывают примеры, действительно не являются полностью независимыми друг от друга:
- две синтаксически эквивалентные программы функционально эквивалентны;
- две операционально эквивалентные программы денотационно эквивалентны;
- и две денотационно эквивалентные программы аксиоматически эквивалентны.
Но обратное неверно.
Таким образом, мы можем иерархизировать семантику, говоря, что одна семантика является абстракцией другой тогда и только тогда, когда две эквивалентные программы в последней эквивалентны и в первой. Эти отношения были формализованы теорией абстрактной интерпретации .
Мы можем завершить эту иерархию ( частичный порядок ) семантических эквивалентностей, поместив идентичность вверху (две программы идентичны, если и только если они представляют собой одну и ту же последовательность символов), а внизу — самую грубую, которая называется хаос , где любая программа эквивалентна любой другой программе.
Приложения
Статьи по Теме
- Кривинская машина
- Машина SECD
Рекомендации
- ↑ ROGERAPERY, « Природа математических объектов » , на /www.numdam.org , 1985 г.
- ↑ (in) Питер Ландин, « Следующие 700 языков программирования » , CACM , n o Vol 9, Number 3 1966 г. , с. 157 — 166 .
- ↑ (in) Джозеф Э. Стой, « денотационная семантика: подход Скотта-Стрейчи к теории языка программирования. » , MIT Press. , 1977 г. ( ISBN0-262-19147-4 ) .
- ↑ Эту идею обратной семантики также рассматривал Дейкстра в своих преобразователях предикатов.
- ↑ (in) Тони Хоар, « Основа математической теории вычислений » , Компьютерное программирование и формальные системы, Северная Голландия , 1963 г. .
- Кодирование информации
- Сжатие данных
- Шифрование
- Криптоанализ
- Криптография
- Теория информации
- Вычислимость
- Разрешимость и неразрешимость
- Рекурсивный набор
- Остановить проблему
- Рекурсивно перечислимый набор
- Машина Тьюринга
- Церковный тезис
- Клеточный автомат
- Искусственная нейронная сеть
- Полиномиальная редукция
- NP-полная задача
- Принцип Чёрча-Тьюринга-Дойча
- Алгоритмический
- Жадный алгоритм
- Вероятностный алгоритм
- Генетический алгоритм
- Алгоритмическая сложность
- Алгоритм анализа
- Разделяй и властвуй
- Эвристический
- Динамическое программирование
- Алгоритмическая геометрия
- Алгоритмы сортировки
- Текстовый алгоритм
- Сбор данных
- Наука о данных
- Глубокое обучение
- Тест на первичность
- Структура данных
- Укоренившееся дерево
- Соревнование
- Параллелизм
- Переписать
- Компиляция
- Регулярное выражение
- Формальная грамматика
- Рациональный язык
- Рациональный набор
- Теория языка
- Теория автоматов
- Готовый автомат
- Автомат на бесконечных словах
- Дерево-автомат
- Автомат с батарейным питанием
- Иерархия Хомского
- Компьютерная лингвистика
- Абстрактная интерпретация
- Формальные методы
- Проверка моделей
- Семантика языков программирования
- Денотационная семантика
- Аксиоматическая семантика
- Операционная семантика
- Помощник доказательства
- Вычисление предикатов
- Переписка Карри-Ховарда
- Рекурсивная функция
- Лямбда-исчисление
- Теоремы Гёделя о неполноте
- Теория типов
- Комбинаторный
- Симплексный алгоритм
- Комбинаторная оптимизация
- Теория графов
- Алгоритмы теории графов
- Исследование операций
- Теория принятия решений
- Численный анализ
Семантика (программирование)
Сема́нтика в программировании — дисциплина, изучающая формализации значений конструкций языков программирования посредством построения их формальных математических моделей. В качестве инструментов построения таких моделей могут использоваться различные средства, например, математическая логика, λ-исчисление, теория множеств, теория категорий, теория моделей, универсальная алгебра. Формализация семантики языка программирования может использоваться как для описания языка, определения свойств языка, так и для целей формальной верификации программ на этом языке программирования.
Общий смысл [ править ]
Семантика языка — это смысловое значение слов. В программировании — начальное смысловое значение операторов, основных конструкций языка и т. п.
Первый код: i=0; while(i <5)Второй код: i=0; dowhile(i<4);
Логически эти два фрагмента кода выполняют одно и то же, результаты их работы идентичны. В то же время семантически это два разных цикла. Так же теги:
будут выглядеть на странице совершенно одинаково, то есть представлять фактически будут одно и то же, а семантически первый тег — это начертание курсивом, а второй — логическое выделение (браузеры выводят курсивом).
Подходы [ править ]
Операционная семантика (англ. operational semantics ) используется для синтаксических понятий языка. В ней функции рассматриваются как текстуальные правильно построенные определения, обеспечивающие применение к аргументу, а не как функции в математическом понимании этого термина.
Существует классификация различных видов операционной семантики:Аксиоматическая семантика — семантику каждой синтаксической конструкции языка можно определить как некий набор аксиом или правил вывода, который можно использовать для вывода результатов выполнения этой конструкции. Чтобы понять смысл всей программы, эти аксиомы и правила вывода следует использовать так же, как при доказательстве обычных математических теорем. В предположении, что значения входных переменных удовлетворяют некоторым ограничениям, аксиомы и правила вывода могут быть использованы для получения ограничений на значения других переменных после выполнения каждого оператора программы. Когда программа выполнена, получаем доказательство того, что вычисленные результаты удовлетворяют необходимым ограничениям на их значения относительно входных значений. То есть, доказано, что выходные данные представляют значения соответствующей функции, вычисленной по значениям входных данных.
Денотационная семантика (англ. denotational semantics ) выражениям в программе ставит в соответствие настоящие математические объекты, то есть, выражения обозначают (англ. to denote — откуда «денотационная») их величины [1] . Важнейшие, в том числе пионерские, результаты построения денотационных семантик получены в работах Д. Скотта (Dana Scott) и К. Страчей (Christopher Strachey) в конце 1960-х — начале 1970-х в Оксфордском университете [2] . Скотт первым построил модель -исчисления, основанную на представлении о полном частично упорядоченном множестве. Для этого им были использованы функции, непрерывные на таком множестве.
Интерпретационная семантика — описание операционной семантики конструкций в терминах языков программирования низкого уровня (язык ассемблера, машинный код). Этот способ позволяет выявлять медленно выполняемые участки программы, и зачастую используется в соответствующих фрагментах систем программирования в целях оптимизации кода программ.
Трансляционная семантика — описание операционной семантики конструкций в терминах языков программирования высокого уровня. С помощью этого способа можно изучать язык, схожий с уже известным программисту.
Трансформационная семантика — описание операционной семантики конструкций языка в терминах этого же языка. Трансформационная семантика является основой метапрограммирования.
Предметом постоянного интереса и исследования является построение систем доказательства корректности, или правильности программ. Наиболее разработанными оказались системы доказательства для случая корректности функциональных программ, которые восходят к системе LCF Робина Милнера и системе Р. Бойера (R. Boyer) и Дж. Мура (J. Moore).
Проводимые в настоящее время исследования сосредоточены на построении систем, основанных на конструктивной логике и установлении аналогии между программами и доказательствами. Существенно, что как программы, так и доказательства рассматриваются погруженными в -исчисление с типами, которое является формальной системой высших порядков. Тем самым обеспечивается возможность строить только такие программы, которые завершаются. Одной из подобных систем является система Coq.
См. также [ править ]
- Семантическая паутина
- Онтология (информатика)
Примечания [ править ]
- ↑Филд А., Харрисон П. Функциональное программирование = Functional Programming. — М .: Мир, 1993. — С. 593-594. — 637 с. — ISBN 5-03-001870-0.
- ↑Mitchell, 2002
Литература [ править ]
- Калайда В. Т. Теория вычислительных процессов. — Томск: ТУСУР, 2012. — 153 с.