Giter Site home page Giter Site logo

turing_machine_visualizer's Introduction

Консольный визуализатор машины Тьюринга

Работает на Python 3.

Для работы необходима библиотека colorama. Установить -- pip3 install colorama. А также, библиотека curses. В Unix системах должна быть установлена по-умолчанию. Чтобы установить в Windows -- pip3 install windows-curses.

visualizer.py machine input [delay] [-p]

  • machine -- файл с описанием машины Тьюринга.
  • input -- файл с вводом.
  • delay -- опционально, задержка между тиками в секундах, по-умолчанию -- одна секунда.
  • -p -- опционально, если ключ указан, исполнение изначально будет поставлено на паузу.

Пример запуска:

  • python3 visualizer.py example empty_input
  • python3 visualizer.py zero.out 01 0.5
  • python3 visualizer.py sorting.out 01 -p

Во время работы, символами ^ показывает, где находятся головки на лентах, пишет позиции головок, и пишет текущую вершину в автомате.

Для прерывания исполнения, нужно нажать q. Для паузы/продолжения, нужно нажать пробел. Поддерживает исполнение по шагам. Для этого, нужно поставить на паузу, а затем нажимать стрелку вправо для перехода к следующему шагу. Также, если исполнение не поставлено на паузу, и нажата стрелка вправо, между шагами не будет паузы.

Поддерживает форматы машины Тьюринга из лабы.


gen.py -- вспомогательный скрипт, который по файлу с описанием машины Тьюринга генерирует код на Python 3, который ее выводит. gen.py machine [name]

machine -- файл с описанием машины Тьюринга. name -- опционально, название задачи, если он не указан, за название задачи будет принято название файла с описанием.

Генерирует в той же папке, где находится файл с описанием, программу на Python 3, которая назвается $name.py, которая при запуске выводит в файл $name.out то, что находилось в файле $machine.

Пример запуска: python3 gen.py example helloworld python3 gen.py zero/zero

turing_machine_visualizer's People

Contributors

budalnik avatar ieclipsei avatar wafemand avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.