Проєктування бібліотеки для спрощення умов верифікації програм

Abstract

Анотація програми інваріантами, заданими в певних точках програми, зводить проблему її верифікації до перевірки істинності ряду логічних виразів. Однак, проблема виводимості є алгоритмічно нерозв’язною навіть для достатньо простих предметних областей, таких як елементарна арифметика. Тому важлива розробка комп’ютерних засобів, які можуть спростити задачу верифікації програм. Особливо важлива наявність таких систем для навчання програмуванню. До них відносяться технологія символьного виконання програм та інструменти для еквівалентних перетворень та спрощення символьних виразів. Залишаються актуальними дослідження формальних методів верифікації програм. У статті описана побудована на базі бібліотеки ExprLib технологія автоматичного еквівалентного перетворення арифметичних та логічних виразів до найпростішого стандартизованого вигляду. Досліджено побудовані перетворення. Встановлено, що вони мають властивість ідемпотентності, а еквівалентні вирази мають єдине нормалізоване представлення. Бібліотека написана алгоритмічною мовою Python з використанням рекурсії на структурах даних типу дерево. Бібліотека реалізована класами та функціями мови Python, які представляють деревовидні структури списками, множинами та словниками мови Python. Побудовано класи для представлення дерев, одночленів та поліномів, відношень та їх кон'юнкцій, а також імплікацій. Для спрощення імплікацій застосовується правило редукції кон`юнкцій. Бібліотека застосовується в системі VerPro символьного виконання та верифікації програм на мові Python. Для перевірки тотожної істинності імплікацій, які представляють умови верифікації, використовуються солвери системи доведення теорем Z3. Система VerPro є експериментальною і зараз обмежується програмами цілочисельної арифметики. Наявність власної бібліотеки дозволяє розширювати область застосування системи, яка розвивається в напрямку генерації інваріантів та розширення областей охоплених нею програм.

Description

Вісник Хмельницького національного університету. Серія: Технічні науки. Том 321 № 3 (2023)

Citation

Костирко В.С., Аніловська Г.Я., Плеша В.І. (2023) Проєктування бібліотеки для спрощення умов верифікації програм. Хмельницький: Вісник Хмельницького національного університету. Серія: Технічні науки. Том 321 № 3 (2023). C: 273-279.

Endorsement

Review

Supplemented By

Referenced By