All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sosy_lab.java_smt.test.Fuzzer Maven / Gradle / Ivy

The newest version!
// This file is part of JavaSMT,
// an API wrapper for a collection of SMT solvers:
// https://github.com/sosy-lab/java-smt
//
// SPDX-FileCopyrightText: 2020 Dirk Beyer 
//
// SPDX-License-Identifier: Apache-2.0

package org.sosy_lab.java_smt.test;

import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import java.util.Random;
import org.sosy_lab.common.UniqueIdGenerator;
import org.sosy_lab.java_smt.api.BooleanFormula;
import org.sosy_lab.java_smt.api.BooleanFormulaManager;
import org.sosy_lab.java_smt.api.FormulaManager;

/** Boolean fuzzer, useful for testing. */
class Fuzzer {
  private final BooleanFormulaManager bfmgr;

  private final UniqueIdGenerator idGenerator;
  private BooleanFormula[] vars = new BooleanFormula[0];
  private final Random r;

  private static final String varNameTemplate = "VAR_";

  Fuzzer(FormulaManager pFmgr, Random pRandom) {
    bfmgr = pFmgr.getBooleanFormulaManager();
    idGenerator = new UniqueIdGenerator();
    r = pRandom;
  }

  public BooleanFormula fuzz(int formulaSize, int maxNoVars) {
    vars = new BooleanFormula[maxNoVars];
    populateVars();
    return recFuzz(formulaSize);
  }

  public BooleanFormula fuzz(int formulaSize, BooleanFormula... pVars) {
    vars = pVars;
    return recFuzz(formulaSize);
  }

  @SuppressFBWarnings(value = "DMI_RANDOM_USED_ONLY_ONCE")
  private BooleanFormula recFuzz(int formulaSize) {
    if (formulaSize == 1) {

      // The only combination of size 1.
      return getVar();
    } else if (formulaSize == 2) {

      // The only combination of size 2.
      return bfmgr.not(getVar());
    } else {
      formulaSize -= 1;

      int pivot = formulaSize / 2;
      switch (r.nextInt(3)) {
        case 0:
          return bfmgr.or(recFuzz(pivot), recFuzz(formulaSize - pivot));
        case 1:
          return bfmgr.and(recFuzz(pivot), recFuzz(formulaSize - pivot));
        case 2:
          return bfmgr.not(recFuzz(formulaSize));
        default:
          throw new UnsupportedOperationException("Unexpected state");
      }
    }
  }

  @SuppressFBWarnings(value = "DMI_RANDOM_USED_ONLY_ONCE")
  private BooleanFormula getVar() {
    return vars[r.nextInt(vars.length)];
  }

  private void populateVars() {
    for (int i = 0; i < vars.length; i++) {
      vars[i] = getNewVar();
    }
  }

  private BooleanFormula getNewVar() {
    return bfmgr.makeVariable(varNameTemplate + idGenerator.getFreshId());
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy