Инструмент проверки простых моделей

Есть ли простой инструмент проверки моделей. Я планирую реализовать инструмент проверки моделей, который будет анализировать код некоторых предопределенных свойств.

Думаю, тебе стоит попытаться немного подробнее объяснить, что ты ищешь ...

Torbjørn 20.10.2008 20:02

Думаю, вам стоит пересмотреть свой вопрос, чтобы он был более ясным. Этот вопрос может относиться к десятку различных сценариев проверки модели.

SaaS Developer 20.10.2008 20:04

Инструмент проверки модели, который поддерживает состояние. то есть я планирую реализовать инструмент, который может сказать, завершается ли приложение или нет. (Только статический анализ)

Vinay 20.10.2008 20:16

Ой-ой ... это известно как проблема остановки (en.wikipedia.org/wiki/Halting_problem), и было показано, что ее невозможно решить :-)

Matt J 20.10.2008 20:19

Проблема остановки неразрешима. Это не означает, что анализ не может быть выполнен: en.wikipedia.org/wiki/Termination_analysis

Arlen Cox 06.06.2014 19:43
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
2
5
1 058
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

CBMC - один простой инструмент, о котором я знаю, который на самом деле работает с кодом. Проверка моделей в целом - это хорошо изученная область, но, как люди уже отметили, такая широта затрудняет предложение чего-либо с предоставленной информацией. Существуют тысячи решателей SAT, формальные инструменты для проверки HDL / конечного автомата и множество коммерческих статических анализаторов источников.

В любом случае CBMC - хороший инструмент, но не верьте мне на слово; Эд Кларк, главный преподаватель этой работы, получил в этом году премию Тьюринга ;-)

Инструмент проверки модели, который поддерживает состояния. то есть я планирую реализовать инструмент, который может сказать, завершается ли приложение или нет. (Только статический анализ)

Vinay 20.10.2008 20:19

Действительно? Это кажется немного сложным (en.wikipedia.org/wiki/Halting_problem) ;-)

Matt J 01.03.2009 22:26

@MattJ сложно, но возможно. если CBMC доказывает правильность вашей программы и отсутствие ошибок / исключений во время выполнения, это также доказывает завершение работы. Проблема остановки говорит только о том, что она не решима тривиально для всех программ, AFAIK. Для нескольких классов программ это тривиально разрешимо! +1 за упоминание CBMC, это отличный инструмент.

Morten Jensen 22.04.2015 02:55
Ответ принят как подходящий

Одним из важных инструментов является ВРАЩЕНИЕ с языком Promela. Если вы используете LaTeX, есть еще TLA +.

Они не будут анализировать ваш код, но позволят вам выразить модель для ваших предположений и переходов состояний, а затем проанализировать недопустимые состояния. Другими словами, они обнаружат проблемы в вашей модели, а не в ее реализации.

Я видел демонстрацию Goanna, но не знаю, доступна ли она вообще (коммерческая или нет); это имеет то преимущество, что фактически анализирует ваш исходный код.

Просто глядя на свой вопрос и снова на комментарии к нему, кажется, что вам действительно стоит сначала прочитать некоторую литературу. Возможно, Проверка модели вращения или Определение систем (загружается с Сайт Лесли Лэмпорта). Вам нужно переосмыслить свою проблему, чтобы не пытаться решить проблему остановки.

Другие вопросы по теме