예제 #1
0
        /*
         * Deze methode geeft een Valuatie terug die de gegeven Formule vervult.
         * Wanneer zo'n Valuatie niet bestaat geeft hij de waarde null terug.
         *
         * Deze methode roept de gelijknamige recursieve methode met 3 parameters aan, met de volgende initiele waarden:
         * - formule       de gegeven Formule,
         * - variabelen    de Set van alle variabelen uit de Formule, verkregen door eerst de methode Verzamel aan te roepen,
         * - valuatie      de lege valuatie.
         */
        public static Valuatie Vervulbaar(IFormule formule)
        {
            if (formule == null)
            {
                return(null);
            }

            SortedSet <string> variabelen = new SortedSet <string>();

            formule.Verzamel(variabelen);

            Valuatie valuatie = new Valuatie();

            return(Vervulbaar(formule, variabelen, valuatie));
        }
예제 #2
0
 /*
  * Deze recursieve methode krijgt een Formule, een Set van nog te valueren variabelen,
  * en een Valuatie voor een deel van de variabelen.
  *
  * Deze methode geeft een Valuatie terug die de gegeven formule vervult.
  * Wanneer zo'n Valuatie niet bestaat geeft hij de waarde null terug.
  */
 private static Valuatie Vervulbaar(IFormule formule, SortedSet <string> variabelen, Valuatie valuatie)
 {
     // TODO: schrijf de methode die een Valuatie vindt die een formule vervult
     return(null);
 }
예제 #3
0
 public bool MogelijkOnwaar(Valuatie valuatie)
 {
     return(true);
 }
예제 #4
0
        /*
         * Het hoofdprogramma leest een regel van de standaardinvoer, en zet die om naar een formule.
         * We zoeken een valuatie die de formule vervult.
         * Als dat lukt, printen we "SAT" op de eerste regel van de standaarduitvoer, en op de tweede regel de valuatie.
         * Als de formule niet vervulbaar is, printen we alleen "UNSAT" op de eerste regel.
         */
        public static void Main()
        {
            while (true)
            {
                try
                {
                    String invoer = Console.ReadLine();


                    IFormule formule = Parser.ParseFormule(invoer);
                    Console.WriteLine(formule.ToString());  // deze regel kun je gebruiken om de parser te testen

                    DateTime start    = DateTime.Now;
                    Valuatie valuatie = Solver.Vervulbaar(formule);
                    DateTime eind     = DateTime.Now;

                    invoer = Console.ReadLine();
                    if (invoer == "p")
                    {
                        Console.WriteLine(formule.ToString());
                    }
                    else if (invoer == "e")
                    {
                    }
                    else if (invoer == "t")
                    {
                    }
                    else if (invoer == "u")
                    {
                    }
                    else if (invoer == "v")
                    {
                    }
                    else if (invoer == "n")
                    {
                        if (valuatie == null)
                        {
                            Console.Write($"SAT\n{valuatie}");
                        }
                    }
                    else if (invoer == "y")
                    {
                        if (valuatie == null)
                        {
                            Console.WriteLine("UNSAT");
                        }
                        else
                        {
                            Console.WriteLine($"SAT\n{valuatie}");
                        }
                    }



                    Console.WriteLine($"oplostijd: {(eind - start).Ticks / 1E7} seconde");   // deze regel kun je gebruiken om het solve-proces te timen
                }
                catch (Exception exc)
                {
                    // De parser kan exceptions opwerpen als de formule syntaxfouten bevat
                    Console.WriteLine($"FOUT: {exc.Message}");
                }

                break;          // in de definitieve versie moet deze break staan, zodat er maar 1 formule wordt verwerkt.
                                // tijdens het testen kun je hem tijdelijk weghalen, zodat je meerdere formules na elkaar kunt proberen.
            }
            Console.ReadLine(); // in de definitieve versie moet dit weg, maar tijdens interactief testen voorkomt dit dat het window meteen wegflitst
        }
예제 #5
0
 public bool MogelijkOnwaar(Valuatie valuatie)
 {
     return(formule.MogelijkWaar(valuatie));
 }