コード例 #1
0
        private static Formula ReduceTuringMachineToSat(TuringMachineInfo pTmInfo)
        {
            Operator and = new Operator(Operator.Types.And);

            Formula formula = new Formula
            {
                HeadExactlyInOnePlace(pTmInfo),
                and,
                HeadInTheBeginningAtTheStart(),
                and,
                InTheBeginningStartState(),
                and,
                InitialiseTape(pTmInfo),
                and,
                NotMoreThanOneSymbolPerCell(pTmInfo),
                and,
                AtLeastOneSymbolPerCell(pTmInfo),
                and,
                AlwaysOnlyOneState(pTmInfo),
                and,
                SomeTimeAcceptance(pTmInfo),
                and,
                TransitionFunction(pTmInfo)
            };


            return(formula);
        }
コード例 #2
0
        private static Bracket SomeTimeAcceptance(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #3
0
        private static Bracket TransitionFunction(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #4
0
        private static Bracket AlwaysOnlyOneState(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #5
0
        private static Bracket AtLeastOneSymbolPerCell(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #6
0
        private static Bracket NotMoreThanOneSymbolPerCell(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #7
0
        private static Bracket InitialiseTape(TuringMachineInfo pTmInfo)
        {
            Bracket formula = new Bracket();



            return(formula);
        }
コード例 #8
0
        private static Bracket HeadExactlyInOnePlace(TuringMachineInfo pTmInfo)
        {
            Operator not = new Operator(Operator.Types.Not);
            Operator or  = new Operator(Operator.Types.Or);

            Bracket formula = new Bracket();

            new Bracket()
            {
                not,
                new Variable("Hi,k"),
                or,
                not,
                new Variable("Hi,k")
            };

            return(formula);
        }