Giter Club home page Giter Club logo

holpy's Introduction

holpy

Implementation of higher-order logic in Python.

Verification of symbolic integration:

See README file in the integral directory.

Installation and usage:

This project requires Python 3.5 and npm:

https://www.python.org/download/releases/3.0/

https://www.npmjs.com/

Required packages are listed in requirements.txt. To install required packages, use (depending on your system, may need to replace python by python3 or python3.x):

python -m pip install -r requirements.txt

The user interface is built using Vue, in the ./app folder. To start, change to ./app and use npm install followed by npm run serve, then start the server (in the root directory) using python app.py, and go to page localhost:8080.

To see statistics for the search functionality on a collection of lemmas, use:

python -m server.collect_stat

Unit tests for the backend are located in files of the form */tests/*_test.py.

Directory structure:

  • kernel: kernel for higher-order logic.

    • type: datatype for HOL types.
    • term: datatype for HOL terms.
    • thm: datatype for HOL theorems, including list of basic derivations.
    • proof: linear representation of a proof, consisting of a list of instructions to the kernel.
    • macro: macros as user-defined proof methods.
    • theory: theory state, containing signature for types and constants, and list of axioms and theorems.
    • extension: types of extensions to a theory.
    • report: statistics and debugging information for checking a theory extension.
  • logic: base logic and standard automation.

    • matcher: matching of terms.
    • proofterm: tree-like representation of a proof. Used for convenient construction of proofs, and can be transformed to the linear representation.
    • conv: conversions.
    • logic: utilities and definition of standard macros for logic.
    • basic: functions for loading theories.
  • data: common data types.

  • syntax: parsing and printing.

    • operator: data for unary and binary operators.
    • infertype: type inference.
    • printer: printing functions.
    • parser: parsing functions, built using Lark parser.
  • server: toplevel functions.

    • server: definition and standard operations for proof states.
    • tactic: definition of tactics.
    • method: definition of methods.
  • app: web application.

  • library: main library of theories.

holpy's People

Contributors

bugxrq avatar bzhan avatar crowod avatar jzmrexu1s avatar monkeyjie1996 avatar runqingxu avatar zhouwenfan 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.