Проєктування бібліотеки для спрощення умов верифікації програм
Loading...
Date
Journal Title
Journal ISSN
Volume Title
Publisher
Abstract
Анотація програми інваріантами, заданими в певних точках програми, зводить проблему її верифікації до
перевірки істинності ряду логічних виразів. Однак, проблема виводимості є алгоритмічно нерозв’язною навіть для
достатньо простих предметних областей, таких як елементарна арифметика. Тому важлива розробка
комп’ютерних засобів, які можуть спростити задачу верифікації програм. Особливо важлива наявність таких
систем для навчання програмуванню. До них відносяться технологія символьного виконання програм та
інструменти для еквівалентних перетворень та спрощення символьних виразів. Залишаються актуальними
дослідження формальних методів верифікації програм. У статті описана побудована на базі бібліотеки ExprLib
технологія автоматичного еквівалентного перетворення арифметичних та логічних виразів до найпростішого
стандартизованого вигляду. Досліджено побудовані перетворення. Встановлено, що вони мають властивість
ідемпотентності, а еквівалентні вирази мають єдине нормалізоване представлення. Бібліотека написана
алгоритмічною мовою Python з використанням рекурсії на структурах даних типу дерево. Бібліотека реалізована
класами та функціями мови Python, які представляють деревовидні структури списками, множинами та
словниками мови Python. Побудовано класи для представлення дерев, одночленів та поліномів, відношень та їх
кон'юнкцій, а також імплікацій. Для спрощення імплікацій застосовується правило редукції кон`юнкцій. Бібліотека
застосовується в системі VerPro символьного виконання та верифікації програм на мові Python. Для перевірки
тотожної істинності імплікацій, які представляють умови верифікації, використовуються солвери системи
доведення теорем Z3. Система VerPro є експериментальною і зараз обмежується програмами цілочисельної
арифметики. Наявність власної бібліотеки дозволяє розширювати область застосування системи, яка
розвивається в напрямку генерації інваріантів та розширення областей охоплених нею програм.
Description
Вісник Хмельницького національного університету. Серія: Технічні науки. Том 321 № 3 (2023)
Citation
Костирко В.С., Аніловська Г.Я., Плеша В.І. (2023) Проєктування бібліотеки для спрощення умов верифікації програм. Хмельницький: Вісник Хмельницького національного університету. Серія: Технічні науки. Том 321 № 3 (2023). C: 273-279.