src/HOL/Tools/Sledgehammer/MaSh/src/mash.py
author blanchet
Fri, 11 Jan 2013 16:30:56 +0100
changeset 50827 aba769dc82e9
parent 50619 b958a94cf811
child 50840 a5cc092156da
permissions -rwxr-xr-x
updated MaSh Python component
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
     1
#!/usr/bin/python
50222
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     2
#     Title:      HOL/Tools/Sledgehammer/MaSh/src/mash.py
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     3
#     Author:     Daniel Kuehlwein, ICIS, Radboud University Nijmegen
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     4
#     Copyright   2012
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     5
#
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     6
# Entry point for MaSh (Machine Learning for Sledgehammer).
40e3c3be6bca added file headers
blanchet
parents: 50220
diff changeset
     7
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
     8
'''
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
     9
MaSh - Machine Learning for Sledgehammer
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    10
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    11
MaSh allows to use different machine learning algorithms to predict relevant fact for Sledgehammer.
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    12
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    13
Created on July 12, 2012
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    14
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    15
@author: Daniel Kuehlwein
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    16
'''
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    17
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    18
import logging,datetime,string,os,sys
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    19
from argparse import ArgumentParser,RawDescriptionHelpFormatter
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    20
from time import time
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    21
from stats import Statistics
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
    22
from theoryStats import TheoryStatistics
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
    23
from theoryModels import TheoryModels
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    24
from dictionaries import Dictionaries
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
    25
#from fullNaiveBayes import NBClassifier
50482
d7be7ccf428b updated version of MaSh learner engine
blanchet
parents: 50441
diff changeset
    26
from sparseNaiveBayes import sparseNBClassifier
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    27
from snow import SNoW
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    28
from predefined import Predefined
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    29
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    30
# Set up command-line parser
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    31
parser = ArgumentParser(description='MaSh - Machine Learning for Sledgehammer.  \n\n\
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    32
MaSh allows to use different machine learning algorithms to predict relevant facts for Sledgehammer.\n\n\
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    33
--------------- Example Usage ---------------\n\
50434
960a3429615c more MaSh tweaking -- in particular, export the same facts in "MaSh_Export" as are later tried in "MaSh_Eval"
blanchet
parents: 50399
diff changeset
    34
First initialize:\n./mash.py -l test.log -o ../tmp/ --init --inputDir ../data/Jinja/ \n\
960a3429615c more MaSh tweaking -- in particular, export the same facts in "MaSh_Export" as are later tried in "MaSh_Eval"
blanchet
parents: 50399
diff changeset
    35
Then create predictions:\n./mash.py -i ../data/Jinja/mash_commands -p ../data/Jinja/mash_suggestions -l test.log -o ../tmp/ --statistics\n\
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    36
\n\n\
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    37
Author: Daniel Kuehlwein, July 2012',formatter_class=RawDescriptionHelpFormatter)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    38
parser.add_argument('-i','--inputFile',help='File containing all problems to be solved.')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    39
parser.add_argument('-o','--outputDir', default='../tmp/',help='Directory where all created files are stored. Default=../tmp/.')
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
    40
parser.add_argument('-p','--predictions',default='../tmp/%s.predictions' % datetime.datetime.now(),
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    41
                    help='File where the predictions stored. Default=../tmp/dateTime.predictions.')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    42
parser.add_argument('--numberOfPredictions',default=200,help="Number of premises to write in the output. Default=200.",type=int)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    43
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    44
parser.add_argument('--init',default=False,action='store_true',help="Initialize Mash. Requires --inputDir to be defined. Default=False.")
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
    45
parser.add_argument('--inputDir',default='../data/20121212/Jinja/',\
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    46
                    help='Directory containing all the input data. MaSh expects the following files: mash_features,mash_dependencies,mash_accessibility')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    47
parser.add_argument('--depFile', default='mash_dependencies',
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    48
                    help='Name of the file with the premise dependencies. The file must be in inputDir. Default = mash_dependencies')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    49
parser.add_argument('--saveModel',default=False,action='store_true',help="Stores the learned Model at the end of a prediction run. Default=False.")
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
    50
parser.add_argument('--learnTheories',default=False,action='store_true',help="Uses a two-lvl prediction mode. First the theories, then the premises. Default=False.")
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
    51
#DEBUG: Change sineprioir default to false
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
    52
parser.add_argument('--sinePrior',default=True,action='store_true',help="Uses a SInE like prior for premise lvl predictions. Default=False.")
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
    53
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    54
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    55
parser.add_argument('--nb',default=False,action='store_true',help="Use Naive Bayes for learning. This is the default learning method.")
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    56
parser.add_argument('--snow',default=False,action='store_true',help="Use SNoW's naive bayes instead of Naive Bayes for learning.")
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    57
parser.add_argument('--predef',default=False,action='store_true',\
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
    58
                    help="Use predefined predictions. Used only for comparison with the actual learning. Expects mash_mepo_suggestions in inputDir.")
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    59
parser.add_argument('--statistics',default=False,action='store_true',help="Create and show statistics for the top CUTOFF predictions.\
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    60
                    WARNING: This will make the program a lot slower! Default=False.")
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    61
parser.add_argument('--saveStats',default=None,help="If defined, stores the statistics in the filename provided.")
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    62
parser.add_argument('--cutOff',default=500,help="Option for statistics. Only consider the first cutOff predictions. Default=500.",type=int)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    63
parser.add_argument('-l','--log', default='../tmp/%s.log' % datetime.datetime.now(), help='Log file name. Default=../tmp/dateTime.log')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    64
parser.add_argument('-q','--quiet',default=False,action='store_true',help="If enabled, only print warnings. Default=False.")
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    65
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
    66
def main(argv = sys.argv[1:]):
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    67
    # Initializing command-line arguments
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    68
    args = parser.parse_args(argv)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    69
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
    70
    # Set up logging
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    71
    logging.basicConfig(level=logging.DEBUG,
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    72
                        format='%(asctime)s %(name)-12s %(levelname)-8s %(message)s',
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    73
                        datefmt='%d-%m %H:%M:%S',
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    74
                        filename=args.log,
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    75
                        filemode='w')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    76
    console = logging.StreamHandler(sys.stdout)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    77
    console.setLevel(logging.INFO)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    78
    formatter = logging.Formatter('# %(message)s')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    79
    console.setFormatter(formatter)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    80
    logging.getLogger('').addHandler(console)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    81
    logger = logging.getLogger('main.py')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    82
    if args.quiet:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    83
        logger.setLevel(logging.WARNING)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    84
        console.setLevel(logging.WARNING)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    85
    if not os.path.exists(args.outputDir):
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    86
        os.makedirs(args.outputDir)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    87
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    88
    logger.info('Using the following settings: %s',args)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    89
    # Pick algorithm
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    90
    if args.nb:
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
    91
        logger.info('Using sparse Naive Bayes for learning.')
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
    92
        model = sparseNBClassifier(args.sinePrior)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    93
        modelFile = os.path.join(args.outputDir,'NB.pickle')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    94
    elif args.snow:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    95
        logger.info('Using naive bayes (SNoW) for learning.')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    96
        model = SNoW()
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    97
        modelFile = os.path.join(args.outputDir,'SNoW.pickle')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    98
    elif args.predef:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
    99
        logger.info('Using predefined predictions.')
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   100
        #predictionFile = os.path.join(args.inputDir,'mash_meng_paulson_suggestions') 
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   101
        predictionFile = os.path.join(args.inputDir,'mash_mepo_suggestions')
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   102
        model = Predefined(predictionFile)
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   103
        modelFile = os.path.join(args.outputDir,'mepo.pickle')        
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   104
    else:
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   105
        logger.info('No algorithm specified. Using sparse Naive Bayes.')
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   106
        model = sparseNBClassifier(args.sinePrior)
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   107
        modelFile = os.path.join(args.outputDir,'NB.pickle')
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   108
    dictsFile = os.path.join(args.outputDir,'dicts.pickle')
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   109
    theoryFile = os.path.join(args.outputDir,'theory.pickle')
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   110
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   111
    # Initializing model
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   112
    if args.init:
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   113
        logger.info('Initializing Model.')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   114
        startTime = time()
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   115
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   116
        # Load all data
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   117
        dicts = Dictionaries()
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   118
        dicts.init_all(args.inputDir,depFileName=args.depFile)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   119
        
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   120
        # Create Model
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   121
        trainData = dicts.featureDict.keys()
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   122
        model.initializeModel(trainData,dicts)
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   123
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   124
        if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   125
            depFile = os.path.join(args.inputDir,args.depFile)
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   126
            theoryModels = TheoryModels()
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   127
            theoryModels.init(depFile,dicts)
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   128
            theoryModels.save(theoryFile)
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   129
            
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   130
        model.save(modelFile)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   131
        dicts.save(dictsFile)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   132
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   133
        logger.info('All Done. %s seconds needed.',round(time()-startTime,2))
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   134
        return 0
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   135
    # Create predictions and/or update model
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   136
    else:
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   137
        lineCounter = 1
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   138
        statementCounter = 1
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   139
        computeStats = False
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   140
        dicts = Dictionaries()
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   141
        theoryModels = TheoryModels()
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   142
        # Load Files
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   143
        if os.path.isfile(dictsFile):
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   144
            dicts.load(dictsFile)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   145
        if os.path.isfile(modelFile):
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   146
            model.load(modelFile)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   147
        if os.path.isfile(theoryFile) and args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   148
            theoryModels.load(theoryFile)
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   149
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   150
        # IO Streams
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   151
        OS = open(args.predictions,'w')
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   152
        IS = open(args.inputFile,'r')
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   153
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   154
        # Statistics
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   155
        if args.statistics:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   156
            stats = Statistics(args.cutOff)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   157
            if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   158
                theoryStats = TheoryStatistics()
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   159
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   160
        predictions = None
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   161
        predictedTheories = None
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   162
        #Reading Input File
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   163
        for line in IS:
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   164
#           try:
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   165
            if True:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   166
                if line.startswith('!'):
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   167
                    problemId = dicts.parse_fact(line)                        
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   168
                    # Statistics
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   169
                    if args.statistics and computeStats:
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   170
                        computeStats = False
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   171
                        # Assume '!' comes after '?'
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   172
                        if args.predef:
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   173
                            predictions = model.predict(problemId)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   174
                        if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   175
                            tmp = [dicts.idNameDict[x] for x in dicts.dependenciesDict[problemId]]
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   176
                            usedTheories = set([x.split('.')[0] for x in tmp]) 
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   177
                            theoryStats.update((dicts.idNameDict[problemId]).split('.')[0],predictedTheories,usedTheories)                        
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   178
                        stats.update(predictions,dicts.dependenciesDict[problemId],statementCounter)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   179
                        if not stats.badPreds == []:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   180
                            bp = string.join([str(dicts.idNameDict[x]) for x in stats.badPreds], ',')
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   181
                            logger.debug('Bad predictions: %s',bp)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   182
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   183
                    statementCounter += 1
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   184
                    # Update Dependencies, p proves p
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   185
                    dicts.dependenciesDict[problemId] = [problemId]+dicts.dependenciesDict[problemId]
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   186
                    if args.learnTheories:
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   187
                        theoryModels.update(problemId,dicts.featureDict[problemId],dicts.dependenciesDict[problemId],dicts)
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   188
                    if args.snow:
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   189
                        model.update(problemId,dicts.featureDict[problemId],dicts.dependenciesDict[problemId],dicts)
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   190
                    else:
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   191
                        model.update(problemId,dicts.featureDict[problemId],dicts.dependenciesDict[problemId])
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   192
                elif line.startswith('p'):
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   193
                    # Overwrite old proof.
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   194
                    problemId,newDependencies = dicts.parse_overwrite(line)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   195
                    newDependencies = [problemId]+newDependencies
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   196
                    model.overwrite(problemId,newDependencies,dicts)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   197
                    if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   198
                        theoryModels.overwrite(problemId,newDependencies,dicts)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   199
                    dicts.dependenciesDict[problemId] = newDependencies
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   200
                elif line.startswith('?'):               
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   201
                    startTime = time()
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   202
                    computeStats = True
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   203
                    if args.predef:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   204
                        continue
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   205
                    name,features,accessibles,hints = dicts.parse_problem(line)    
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   206
                    # Create predictions
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   207
                    logger.info('Starting computation for problem on line %s',lineCounter)
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   208
                    # Update Models with hints
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   209
                    if not hints == []:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   210
                        if args.learnTheories:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   211
                            accessibleTheories = set([(dicts.idNameDict[x]).split('.')[0] for x in accessibles])
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   212
                            theoryModels.update_with_acc('hints',features,hints,dicts,accessibleTheories)
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   213
                        if args.snow:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   214
                            pass
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   215
                        else:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   216
                            model.update('hints',features,hints)
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   217
                    
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   218
                    # Predict premises
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   219
                    if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   220
                        predictedTheories,accessibles = theoryModels.predict(features,accessibles,dicts)
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   221
                    predictions,predictionValues = model.predict(features,accessibles,dicts)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   222
                    assert len(predictions) == len(predictionValues)
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   223
                    
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   224
                    # Delete hints
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   225
                    if not hints == []:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   226
                        if args.learnTheories:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   227
                            theoryModels.delete('hints',features,hints,dicts)
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   228
                        if args.snow:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   229
                            pass
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   230
                        else:
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   231
                            model.delete('hints',features,hints)
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   232
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   233
                    logger.info('Done. %s seconds needed.',round(time()-startTime,2))
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   234
                    # Output        
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   235
                    predictionNames = [str(dicts.idNameDict[p]) for p in predictions[:args.numberOfPredictions]]
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   236
                    predictionValues = [str(x) for x in predictionValues[:args.numberOfPredictions]]
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   237
                    predictionsStringList = ['%s=%s' % (predictionNames[i],predictionValues[i]) for i in range(len(predictionNames))]
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   238
                    predictionsString = string.join(predictionsStringList,' ')
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   239
                    outString = '%s: %s' % (name,predictionsString)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   240
                    OS.write('%s\n' % outString)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   241
                else:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   242
                    logger.warning('Unspecified input format: \n%s',line)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   243
                    sys.exit(-1)
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   244
                lineCounter += 1
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   245
            """
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   246
            except:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   247
                logger.warning('An error occurred on line %s .',line)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   248
                lineCounter += 1
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   249
                continue
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   250
            """
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   251
        OS.close()
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   252
        IS.close()
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   253
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   254
        # Statistics
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   255
        if args.statistics:
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   256
            if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   257
                theoryStats.printAvg()
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   258
            stats.printAvg()
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   259
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   260
        # Save
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   261
        if args.saveModel:
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   262
            model.save(modelFile)
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   263
            if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   264
                theoryModels.save(theoryFile)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   265
        dicts.save(dictsFile)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   266
        if not args.saveStats == None:
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   267
            if args.learnTheories:
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   268
                theoryStatsFile = os.path.join(args.outputDir,'theoryStats')
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   269
                theoryStats.save(theoryStatsFile)
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   270
            statsFile = os.path.join(args.outputDir,args.saveStats)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   271
            stats.save(statsFile)
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   272
    return 0
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   273
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   274
if __name__ == '__main__':
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   275
    # Example:
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   276
    # Auth
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   277
    # ISAR Theories
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   278
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121227b/Auth/','--learnTheories']    
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   279
    #args = ['-i', '../data/20121227b/Auth/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--learnTheories']
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   280
    # ISAR MePo 
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   281
    #args = ['-l','testIsabelle.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121227b/Auth/','--predef']
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   282
    #args = ['-i', '../data/20121227b/Auth/mash_commands','-p','../tmp/JinjaMePo.pred','-l','testIsabelle.log','--predef','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaMePo.stats']
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   283
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   284
    
50434
960a3429615c more MaSh tweaking -- in particular, export the same facts in "MaSh_Export" as are later tried in "MaSh_Eval"
blanchet
parents: 50399
diff changeset
   285
    # Jinja
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   286
    # ISAR Theories
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   287
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121227b/Jinja/','--learnTheories']    
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   288
    #args = ['-i', '../data/20121227b/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--learnTheories']
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   289
    # ISAR NB
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   290
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121221/Jinja/']    
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   291
    #args = ['-i', '../data/20121221/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   292
    # ISAR MePo
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   293
    #args = ['-l','testIsabelle.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121212/Jinja/','--predef']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   294
    #args = ['-i', '../data/20121212/Jinja/mash_commands','-p','../tmp/JinjaMePo.pred','-l','testIsabelle.log','--predef','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaMePo.stats']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   295
    # ISAR NB ATP
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   296
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121212/Jinja/','--depFile','mash_atp_dependencies']    
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   297
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--depFile','mash_atp_dependencies']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   298
    #args = ['-l','testIsabelle.log','-o','../tmp/','--statistics','--init','--inputDir','../data/Jinja/','--predef','--depFile','mash_atp_dependencies']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   299
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/JinjaMePo.pred','-l','testIsabelle.log','--predef','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaMePo.stats','--depFile','mash_atp_dependencies']
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   300
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/Jinja/','--depFile','mash_atp_dependencies','--snow']    
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   301
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--snow','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--depFile','mash_atp_dependencies']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   302
    # ISAR Snow
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   303
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121212/Jinja/','--snow']    
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   304
    #args = ['-i', '../data/20121212/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--snow','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   305
 
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   306
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   307
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   308
    # Probability
50827
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   309
    # ISAR Theories
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   310
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121213/Probability/','--learnTheories']    
aba769dc82e9 updated MaSh Python component
blanchet
parents: 50619
diff changeset
   311
    #args = ['-i', '../data/20121213/Probability/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--learnTheories']
50619
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   312
    # ISAR NB
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   313
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121213/Probability/']    
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   314
    #args = ['-i', '../data/20121213/Probability/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/ProbIsarNB.stats','--cutOff','500']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   315
    # ISAR MePo
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   316
    #args = ['-l','testIsabelle.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121213/Probability/','--predef']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   317
    #args = ['-i', '../data/20121213/Probability/mash_commands','-p','../tmp/JinjaMePo.pred','-l','testIsabelle.log','--predef','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaMePo.stats']
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   318
    # ISAR NB ATP
b958a94cf811 new version of MaSh, with theory-level reasoning
blanchet
parents: 50482
diff changeset
   319
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/20121212/Jinja/','--depFile','mash_atp_dependencies']    
50441
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   320
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--nb','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--depFile','mash_atp_dependencies']
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   321
    #args = ['-l','testIsabelle.log','-o','../tmp/','--statistics','--init','--inputDir','../data/Jinja/','--predef','--depFile','mash_atp_dependencies']
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   322
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/JinjaMePo.pred','-l','testIsabelle.log','--predef','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaMePo.stats','--depFile','mash_atp_dependencies']
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   323
    #args = ['-l','testNB.log','-o','../tmp/','--statistics','--init','--inputDir','../data/Jinja/','--depFile','mash_atp_dependencies','--snow']    
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   324
    #args = ['-i', '../data/Jinja/mash_commands','-p','../tmp/testNB.pred','-l','../tmp/testNB.log','--snow','-o','../tmp/','--statistics','--saveStats','../tmp/JinjaIsarNB.stats','--cutOff','500','--depFile','mash_atp_dependencies']
1e71f9d3cd57 more changes to MaSh Python program (by Daniel K.)
blanchet
parents: 50434
diff changeset
   325
50399
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   326
52d9720f7a48 made Python code compile again (by Daniel K.)
blanchet
parents: 50388
diff changeset
   327
    
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   328
    #startTime = time()
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   329
    #sys.exit(main(args))
50388
a5b666e0c3c2 added weights to MaSh (by Daniel Kuehlwein)
blanchet
parents: 50222
diff changeset
   330
    #print 'New ' + str(round(time()-startTime,2))
50220
90280d85cd03 moved MaSh's Python code into Isabelle
blanchet
parents:
diff changeset
   331
    sys.exit(main())